Diff for "VersionThreeDotO/Foundations"

Not logged in - Log In / Register

Differences between revisions 3 and 10 (spanning 7 versions)
Revision 3 as of 2008-11-24 23:02:39
Size: 16752
Editor: flacoste
Comment:
Revision 10 as of 2009-01-11 21:31:52
Size: 17235
Editor: flacoste
Comment:
Deletions are marked like this. Additions are marked like this.
Line 12: Line 12:
|| || [[VersionThreeDotO/Foundations#merge-javascript-tests|Automatic JavaScript test running]] || ||
|| 3 || [[/Delivered#login-freshness-openid-extension|Login-freshness OpenID extension]] || ||
|| 3 || [[VersionThreeDotO/Foundations#inline-text-editing|Inline text editing]] || ||
|| 8 || [[VersionThreeDotO/Foundations#5-minutes-pqm-merge| 5 minutes PQM merge]] || ||
|| ? || [[VersionThreeDotO/Foundations#ec2-test-runner| EC2 Test Runner]] || ||
|| 3 || [[VersionThreeDotO/Foundations#lazr.config|lazr.config]] || ||
|| 2 || [[/Delivered#login-freshness-openid-extension|Login-freshness OpenID extension]] || 2.1.11 ||
|| 2 || [[/Delivered#ajax-patch|AJAX PATCH]] || 2.1.11 ||
|| 1 || [[/Delivered#private-team-rpconfig|Configure access to private teams in +rpconfig]] || 2.1.11 ||
|| ? || [[/Delivered#prepopulating-ajax-cache|Prepopulating AJAX cache]] || 2.2.1 ||
|| ? || [[/Delivered#entry-etag|Entry ETag]] || 2.1.12 ||
|| 8 || [[VersionThreeDotO/Foundations#5-minutes-pqm-merge|5 minutes PQM merge]] || in-progress ||
|| ? || [[/Delivered#ec2-test-runner| EC2 Test Runner]] || 2.1.12 ||
|| ? || [[VersionThreeDotO/Foundations#person-account-separation|Person/Account Separation]] || ||
|| ? || [[/Delivered#lazr-js-framework|Lazr-JS Project Bootstrap]] || 2.2.1 ||
|| ? || [[/Delivered#lazr-js-reference-widget|Lazr-JS Reference Widget ]] || 2.1.12 ||
|| ? || [[/Delivered#lazr-js-green-flash|Lazr-JS Green Flash]] || 2.1.12 ||
|| 3 || [[/Delivered#lazr.config|lazr.config]] || 2.1.12 ||
|| ? || [[VersionThreeDotO/Foundations#sso-authentication-during-upgrade|SSO Authentication available during upgrade]] || in-progress ||
|| ? || [[/Delivered#lazr-js-error-widget|Lazr Error Widget]] || obsolete ||
|| 3 || [[VersionThreeDotO/Foundations#inline-text-editing|Inline text editing]] || in-progress ||
|| || [[/Delivered#api-customized-auto-generated-adapter|API customized auto-generated adapter]] || no use cases ||
|| || [[VersionThreeDotO/Foundations#multi-hit-api|Multi-hit API's]] || in progress ||
Line 19: Line 30:
|| || [[VersionThreeDotO/Foundations#merge-javascript-tests|Automatic JavaScript test running]] || ||
Line 24: Line 36:
|| || [[VersionThreeDotO/Foundations#api-customized-auto-generated-adapter|API customized auto-generated adapter]] || ||
Line 27: Line 38:
|| || [[VersionThreeDotO/Foundations#multi-hit-api|Multi-hit API's]] || ||
Line 131: Line 141:
     from Landscape)      from Landscape and ubunet)
       * lp:~ubunet-pqm-team/ubunet/wsgi-oops
Line 399: Line 410:
<<Anchor(person-account-separation)>>
=== Person/Account Separation ===

  **Story Points:** ?

  As a Landscape User,\\
  when I registered an account on the SSO service, I don't want a Launchpad
  profile page created for me,\\
  so that my anonimity is preserved.


<<Anchor(sso-authentication-during-upgrade)>>
=== SSO Authentication available during upgrade ===

  As a Launchpad SSO user,\\
  I want to be able to log in when Launchpad is going through maintenance;\\
  so that my other services aren't affected by the monthly Launchpad down-time.


<<Anchor(multi-hit-api)>>
=== Multi-Hit API ===

  **Story Points:**

  As a webservice client,\\
  I want to be able to invoke a particular named operation or setting an
  attribute to a certain value on a set of objects;\\
  so that mass-change operation can be done efficiently.

  **Notes:**

<<Anchor(easy-a-b-testing)>>
=== Easy A-B Testing ===

  **Story Points:**

  As a launchpad developer,\\
  I want to be able to configure two different views to be served from
  the same URL, each user receiving a random one;\\
  so that I can easily do A-B testing.

  **Notes:**
    * Need to record in the log which view was used in each request case.


<<Anchor(automatic-javascript-tests)>>
=== Automatic JavaScript test running ===

  **Story Points:**

  As a Launchpad developer,\\
  I want my Javascript tests automatically run by PQM on merge;\\
  so that I can prevent regressions in Javascript code.

  **Notes:**
    * Need to record in the log which view was used in each request case.

Line 412: Line 481:

<<Anchor(ec2-test-runner)>>
=== EC2 Test Runner ===

  **Story Points:** ?

  As a Launchpad developer,\\
  I want an easy way to run the test suite on EC2;\\
  so that I can submit a branch to PQM with confidence that the test suite
  will pass.

<<Anchor(person-account-separation)>>
=== Person/Account Separation ===

  **Story Points:**

  As a Landscape User,
  when I registered an account on the SSO service, I don't want a Launchpad
  profile page created for me,
  so that my anonimity is preserved.

  **Notes:**



<<Anchor(api-customized-auto-generated-adapter)>>>
=== API customized auto-generated adapter ===

  **Story Points:**

  As a Launchpad developer,\\
  I want to be able to customize the IEntry and ICollection adapters generated
  automatically by the annotations,\\
  so that webservice-specific optimization might be made, while retaining the
  convenience of the annotated API.
  
  **Notes:**
    * Bug [[https://bugs.edge.launchpad.net/launchpad-foundations/+bug/294858|#294858]].


<<Anchor(multi-hit-api)>>
=== Multi-Hit API ===

  **Story Points:**

  As a webservice client,
  I want to be able to invoke a particular named operation or setting an
  attribute to a certain value on a set of objects,
  so that mass-change operation can be done efficiently.

  **Notes:**

<<Anchor(easy-a-b-testing)>>
=== Easy A-B Testing ===

  **Story Points:**

  As a launchpad developer,
  I want to be able to configure two different views to be served from
  the same URL, each user receiving a random one,
  so that I can easily do A-B testing.

  **Notes:**
    * Need to record in the log which view was used in each request case.

<<Anchor(automatic-javascript-tests)>>
=== Automatic JavaScript test running ===

  **Story Points:**

? As a Launchpad developer,
    I want my Javascript tests automatically run by PQM on merge;
    so that I can prevent regressions in Javascript code.

  **Notes:**
    * Need to record in the log which view was used in each request case.

Priorities for the Foundations team

SP Feature Delivered
3 Make API Cacheable 2.1.9
3 Make API Cacheable - client side 2.1.9
1 YUI Integration 2.1.10
5 JavaScript Testing 2.1.10
5 API JS Access 2.1.10
8 Initial API JavaScript Library 2.1.10
8 Zope 3.4 Upgrade 2.1.10
2 Login-freshness OpenID extension 2.1.11
2 AJAX PATCH 2.1.11
1 Configure access to private teams in +rpconfig 2.1.11
? Prepopulating AJAX cache 2.2.1
? Entry ETag 2.1.12
8 5 minutes PQM merge in-progress
? EC2 Test Runner 2.1.12
? Person/Account Separation
? Lazr-JS Project Bootstrap 2.2.1
? Lazr-JS Reference Widget 2.1.12
? Lazr-JS Green Flash 2.1.12
3 lazr.config 2.1.12
? SSO Authentication available during upgrade in-progress
? Lazr Error Widget obsolete
3 Inline text editing in-progress
API customized auto-generated adapter no use cases
Multi-hit API's in progress
8 Use zc.buildout for deployment
Automatic JavaScript test running
8 Site-wide notifications
3 Test tree layout improvements
XXX Allowing admins to hide bug and answer comments
5 Nominating spam by users
XXX Update pagetests helpers to use lxml2
1 Export GPG keys through OpenId
XXX Automatic decorator pattern (for performance)
XXX ZCML-less views (Martian integration)
XXX Kill pagetitles.py
XXX Batch navigation to specific pages
XXX Base tabular view
XXX Librarian generation of OOPSes
XXX Sanitize the database dump
XXX Easily set up logging for scripts into a logfile
XXX OOPS zip formats
XXX Include log information in OOPS reports
XXX Include currently running queries in OOPS reports
XXX Include machine process status in OOPS reports
XXX Design for content class split into facets
XXX Upgrade to Python 2.5
XXX Simple status editing
Easy A-B Testing
20 API Versioning
3 Export mutators as writable attributes
8 Expose factory methods for scoped collections
5 Expose factories as POST to collection
5 Make it possible for the default GET on a collection to take optional arguments
3 DELETE resource
1 delete() method in launchpadlib
13 lazr.oops
XXX lazr.testing.pages
XXX Controlled sample data setup
Spam control (via qualification mechanisms)
8 Simple graphing/plotting framework
XXX Storing text edit history
LP Connection Limiting
GPG-activated accounts
20 Wiki markup engine
XXX Generalize Participation (for PackageSets)
Providing an API to update karma events with the object they operate on (Bug:ID, Branch:ID, etc)
XXX Factor out batch notification code

User Stories

This section contains the story cards for the above.

Simple graphing/plotting framework

Story Points: 8

As a mailing list user,
I want to see the number of mailing list posts over time in a graph;
so that I can have an idea of the number of emails I might get when subscribing to the list.

Notes:

  • Server-side generation or client-side? (use cases for both)
  • Hard work in generating and cleaning up the data.
  • Cron script parse the archive.
  • Though not a perfect use-case for sparklines the concept is the same in that we need graph creation support.

Use zc.buildout for deployment

Story Points: 8

As a Launchpad developer,
I want to be able to add a CheeseShop python library by adding a simple dependency to our configuration;
so that I can use and deploy easily non-packaged python library without involving IS.

Notes:

  • Unpackaged eggs.
  • Maintain a binary cache in version control (so that eggs are not fetched over the package.)
  • Only packages not changed from upstream and already in the cheeseshop

Tree layout improvements

Story Points: 3

As a Launchpad developer,
I want to be able to find the pagetests related to a particular application;
so that I can easily run the pagetests while I work on an application.

Notes:

  • Moving existing directory by applications.

lazr.oops

Story Points: 13

As python web developer,
I want to download lazr.oops from the Cheeseshop;
so that I can have detailed diagnostic reports of problems on my web application.

Notes:

  • Documentation.
  • Extract the OOPS system from Launchpad
  • Refactor oops tools and system for extensible format (integrate changes from Landscape and ubunet)
  • lp:ubunet-pqm-team/ubunet/wsgi-oops
  • Make pluggable extension for database logging.
  • Setup-tools and all release-related stuff.

lazr.config

Story Points: 3

As a python developer,
I want to download lazr.config from the Cheeseshop;
so that I can use it for process configuration in my project.

Notes:

  • Why not brand it as canonical? Find a top-level package name.
  • Missing some documentation.
  • Convert setup tools.
  • Reorganize project directory structure.
  • License? For all of lazr?

API Versioning

Story Points: 20

As a developer,
I want to be able to annotate certain aspects of the API as being removed from a particular version onward;
so that I can make backward incompatible change.

Notes:

{{{ @export_factory_method_as('new_team', version=3) def new_team_all(...): }}}

  • Only necessary when we need to break backwards compatibility
  • what can be versioned: resource type, operations, fields.
  • list of ordered version number.

Wiki markup engine

Story Points: 20

As a Launchpad user,
I want to be able to enter wiki-like syntax to have rich-text formatting in project description (as well as bug, questions, and comments);
So that I can use typography to convey emphasis and format code-samples properly

Notes:

  • How users will discover?
  • Requires content-type.
  • Preview button?
  • Full-text indexing?
  • How will the markup come out in the web service or +text?

Site-wide notifications

Story Points: 8

As a Launchpad administrator,
I want to be able to post notifications to users that they will see on every page and can acknowledge;
so that I can announce downtime and other general service-related announcement.

Notes:

  • Simple on/off setting.
  • Acknowledgment in database.

Expose factory methods for scoped collections

Story Points: 8

As a developer,
I can annotate a method of an interface to be the method invoked when the client makes a POST request to a scoped collection;
so that the way to use a factory is consistent across resources.

Notes:

  • Needs to represent scoped collection as resources in WADL.

Expose factories as POST to collection

Story Points: 5

As a developer,
I can annotate one of a FooSet interface's methods to be the method invoked when the client makes a POST request;
so that the way to use a factory is consistent across resoureces.

Notes:

  • `PersonSet` POST must include a description of whether you're creating a person or team; or, we must expose seperate collections for people and teams, and you POST to the appropriate one.
  • Updating existing Set to annotate default factory.

Nominating spam by users

Story Points: 5

As a Launchpad user,
I want to be able to report any user-editable content as SPAM;
so that Launchpad admins can remove it.

Notes:

  • Button sends an email with who clicked the button and the link to the content.
  • Standard button on IUserGeneratedContent pages, which fire an event. As a start, the event subscriber will just send an email to a specific team / email
  • Mark all spammable content objects and integrate the button in the templates.

Make it possible for the default GET on a collection to take optional arguments

Story Points: 5

As a developer,
I want operation parameters to be supported in the default GET method for a collection;
so that users can use the same HTTP operation to retrieve all of the collection or a filtered subset.

Notes:

  • add methods to eg. IPersonSet that work with this system
  • add a method to launchpadlib
  • update the generated adapter find() signature and implementation

DELETE resource

Story Points: 3

As a developer,
I can annotate one of an interface's methods to be the method invoked when the client makes a DELETE request to the appropriate kind of resource;
so that the way to delete resources is consistent.

Notes:

  • The DELETE request has the effect of irrevocably removing the underlying object from view through the interface. Attempts to access this object will subsequently result in a 404 error.

Export mutators as writable attributes

Story Points: 3

As a developer,
I can annotate one of an interface's methods to be the method invoked when the client makes a PUT or PATCH request that modifies the value of a particular field;
so that the interface to modify most attributes is consistent.

Export GPG keys through OpenId

Story Points: 1

As a relaying party,
I want to be able to retrieve GPG keys associated with the user during openid authentication;
so that I can pre-populate their account information.

Notes:

  • Define a sreg extension.
  • Not much point in going to openid.ax for this.

delete() method in launchpadlib

Story Points: 1

As a launchpadlib user,
I can delete a resource by calling the delete() method on the appropriate object.

Notes:

  • Resources supporting DELETE will be shown in the WADL file as having a <method> tag with a name of "DELETE".

Spam control (via qualification mechanisms)

Story Points: ??

As Launchpad,
I ask every new non-qualified users to enter a captcha on every form;
so that robots cannot post SPAM automatically.

Notes:

  • Might hinder LP use.
  • How is somebody qualified?

LP Connection Limiting

Story Points: ??

As a XXX,
I want XXX;
so that XXX.

Notes:

  • We should adapt some code that gustavo wrote for landscape to limit the connections that are accepted from the network into the webapp based on the size of the queue of connections waiting for app threads. That will keep launchpad responsive even in situations that look like the one described by tom in bug 224623.

GPG-activated accounts

Story Points: ??

As a XXX,
I want XXX;
so that XXX.

Notes:

  • Allowing for people with GPG keys to be considered valid even without them actually having passwords.

Inline text editing

Story Points: 3

As a Launchpad developer, I want a way to associate an inline text widget with the rendered element of a content field in view, so that I can easily add inline editing to text fields.

Notes:

{{{ view/bug_title_inlinet_widget bug_title_inline_widget = InlineTextWidget(self.context, 'title') }}}

Person/Account Separation

Story Points: ?

As a Landscape User,
when I registered an account on the SSO service, I don't want a Launchpad profile page created for me,
so that my anonimity is preserved.

SSO Authentication available during upgrade

As a Launchpad SSO user,
I want to be able to log in when Launchpad is going through maintenance;
so that my other services aren't affected by the monthly Launchpad down-time.

Multi-Hit API

Story Points:

As a webservice client,
I want to be able to invoke a particular named operation or setting an attribute to a certain value on a set of objects;
so that mass-change operation can be done efficiently.

Notes:

Easy A-B Testing

Story Points:

As a launchpad developer,
I want to be able to configure two different views to be served from the same URL, each user receiving a random one;
so that I can easily do A-B testing.

Notes:

  • Need to record in the log which view was used in each request case.

Automatic JavaScript test running

Story Points:

As a Launchpad developer,
I want my Javascript tests automatically run by PQM on merge;
so that I can prevent regressions in Javascript code.

Notes:

  • Need to record in the log which view was used in each request case.

5 minutes PQM merge Theme

Story Points: 8

As a Launchpad developer,
I want a continuous integration system that will notify me when a commit I made breaks the test suite;
so that I can merge to PQM without running tests.

Notes:

  • Need to deploy only known good branch.
  • Uses buildbot.

VersionThreeDotO/Foundations (last edited 2009-04-29 14:00:24 by leonardr)