[Zope-Checkins] CVS: Zope3/lib/python/Zope/App/Workflow/doc - WorkflowSprintNotes.txt:1.1.2.1
Paul Everitt
paul@zope.com
Tue, 5 Mar 2002 04:02:26 -0500
Update of /cvs-repository/Zope3/lib/python/Zope/App/Workflow/doc
In directory cvs.zope.org:/tmp/cvs-serv19885/doc
Added Files:
Tag: Zope-3x-branch
WorkflowSprintNotes.txt
Log Message:
Notes from Saarbrucken sprint
=== Added File Zope3/lib/python/Zope/App/Workflow/doc/WorkflowSprintNotes.txt ===
Workflow Sprint
Dates were Mar 4-6. Attendees were Alastair Burt, Florent
Guillaume, Vincenzo di Somma, Daniele Tarini, Tres Seaver, Paul
Everitt.
Agenda
o Bootstrapping (getting CVS setup, etc.)
o Planning game
o Lunch
o Zope3 tutorial
o Task signup
o Pairing
Scope
o Workflow architecture proposal
o Exploratory code for architecture
Stories
o WorkflowShepherdWritesProposal
- IWorkflowDefinition
o SiteManagerConfiguresWorkflowEnactmentService
- Global/placeless
- Placeful
o WorkflowDesignerCreatedProcessDefinition
o WorkflowDeveloperImplementsProcessDefinition (import?)
o SiteManagerInstallsProcessDefinition
o SiteManagerIntegratesWorkflowService
o WorkflowDeveloerTestsProcessDefinition
o ExternalProcessInitiatesWorkflowAction
o WorkflowEngineInitiatesRemoteProcessInst
o UserInitiatesWorkflowActivity
o UserQueriesWorklist
o UserCompletesActivity
o SiteManagerQueriesAggregatedHistory
Notes
Started with configuration.
(Tres) This sprint model came out of a desire to do XP, but only for
a short period of time. The first when at ZC in Nov was less than a
week. How to do XP for just a short period of time? Worked pretty
well. XP worked and Zope3 got started.
Third goal became to open the base of people contributing to Zope3.
This includes growing leadership.
Some sprints are topic-focused. They need to focus on an achievable
goal, a small step, rather than trying to accomplish too much. Thus
planning is important to make sure something important but
realistically accomplishable is targetted.
For this sprint, a document needs to describe the workflow
architecture. Hopefully, people in the room will take over the
leadership of workflow in Zope3.
Classic XP says the customer needs to be in the room. We have to
pretend to proxy for the customer. So we need a mental image of the
customer. Who will that be?
Tres speculates that, in OpenFlow, the site manager is the workflow
customer.
(Daniele). The life of a process instance is connected to the
content, but also to resources outside. That is, there is content
in the process instance as well as the item moving through the
workflow.
(Vincenzo) Usually you put in the process instance what is called
"workflow relevant data". Every other object or information you
want to store, you are free to use the process instance.
(Tres) In the CMF, a workflow is bound to a piece of content. The
idea is that the workflow itself, all objects of the same content
type share a process definition (a "workflow"). The data you track
in a process instance can be stored in a number of ways, like
stashing it in the content instance. *Note*: in the CMF
architecture, there isn't really a process instance.
(Florent) First, they didn't want strict association of content type
to workflow. Not flexible enough. They changed to workflow tool.
A workflow aware object is consulted by the workflow tool. It can
add or remove steps. Second, they are working on non-local
workflows. If you have a resource deep in a tree, workflow managers
can be stored in a parent rather than a content type.
Acronym alert! PI is *process instance*. PD is *process
definition*.
Tres wrote up agreement on jargon between CMF and OpenFlow:
o workflow == process definition
o monitor events == process instance
There was a discussion about the object hub and the event channel,
what they are, and how they might impact workflow for Zope 3.
Back to workflow customer. The site manager has to be able to
configure workflows or PD and make sure that all policies are moved
into configuration files. The developer has to design applications
that are workflow aware.
Paul asks if the audience of workflow implentors is valid? That is,
besides the basic idea of Zope 3 to allow multiple implementations
of an interface, should this project do extra work to address this
audience? Will there be extra use cases if there is more than one
workflow engine used in a site? The consensus seems to be that no
special work will be needed for this audience.
Decision: two main audiences are site managers and component
developers.
Interfaces (derived from OpenFlow, might change)
o IWorkflowService
o IWorkflowProcessInstance
o IWorkflowProcessDefinition
o IWorkflowActivity
o IWorkflowTransition
o IWorkflowWorkItem
Events
o objectCreation
o objectDestruction
o objectRename/Move
o objectModification
o objectExpiration?
o timeTick
o userRoleModification
- scheduled
o workflowActionBegin
o workflowActionComplete
o workflowActionSuspended
o workflowItemAssign
o WPIActivated
o WPITerminated
o WPICompleted
o WPISuspended
UI Synthesis
o listObjectActions -> [ActivityInfo]
o listUserActions -> [ActivityInfo]
IActivityInfo
o getID()
o getCategory()
o getTitle()
o getDescription()
o getActionURL()
o getPermission()
o getRole()
o getCondition()
o getSource()
- kickdown to work item, transition, etc.
Goals
o Shared understanding of OpenFlow and DCWorkflow.
o Bootstrap more people for Zope 3.
o Establish leadership for Zope 3 workflow.
o Proposal for workflow in Zope 3.
Lessons Learned
o Try to get people setup with contributor forms and writeable
checkouts (with correct Python etc.) beforehand.
o Remind people about the convention of XXX in comments.
o When doing a build, rm the .so and .o files.
o Should we buy a wireless hub with 4 fast ethernet ports?
o Update tutorial presentation, wiki pages, etc. to point out the
mailing lists that people should subscribe to
o Mention the tkinter pyunit