First Cut of Build Branch to Archive

The purpose of this page is to outline the work that we are going to do for the initial cut, and the proposed (loose) order for getting it done.

The rationale behind this is we'd like to have something actually happen when we get to the stage of having a user use the user interface to create a recipe.

I suggest that we work back end forward. We can use the object factory for all the tests, page tests included. Use the factory inside the harness to see how things are looking for secondary pages - like the recipes for a branch.

Note: nothing is set in concrete

URLs may change, recipe internals may change, we may all turn into flying monkeys.

Canonical URL for recipes

A canonical url for a recipe will be: ~owner/+recipe/recipename

IHasRecipes

The following content classes will be adaptable to IHasRecipes:

Pages for a recipe

Recipe Index

RecipeView

The index page will have links to edit all the editable fields. The recipe contents will be editable in a separate view from the rest of the recipe. Eventually, we can probably use the lazr-js widgets that correspond with each form field for editing inline.

Recipe Build History

This is a simple page that shows the complete build history with links to the build records, etc.

Add Recipe

RecipeAdd

Eventually, we'd like to implement a better method for creating a recipe (like a wizard that will actually write the recipe contents for the user (making it easier to create a recipe). For now, we'll prepopulate the debian version string field, and automatically start the recipe contents with the bzr-builder version string.

Edit Recipe

Basic editing page... This flow provides for people without javascript enabled.

Recipe Listings

RecipeListing

The listing view will be available for all content classes providing IHasRecipes.

Request builds

Request builds

The page for requesting a build of a given recipe.

Branch Index New Recipe Portlet

On a branch page, we'll add a portlet for viewing the build history of all related recipes, with a link to view the recipe listings as well as a link to create a new recipe for the branch.

RecipeBranchPortlet

API

A recipe should be exposed as a web service entry.

Still left to do

Aaron brought up the fact that we aren't showing the next planned build of the recipe, which is actually pretty important. Something needs to be displayed in the recipe build history and the recipe listings like "Build scheduled in 2 hours" or "Build pending - ETA 30 minutes"

BuildBranchToArchiveUI/InitialCut (last edited 2010-03-19 16:28:59 by abentley)