| 13 |  | [[Image(htdocs:../common/guide/original-workflow.png)]] | 
          
            |  | 13 | {{{#!Workflow width=500 height=240 | 
          
            |  | 14 | leave = * -> * | 
          
            |  | 15 | leave.operations = leave_status | 
          
            |  | 16 | leave.default = 1 | 
          
            |  | 17 | accept = new -> assigned | 
          
            |  | 18 | accept.permissions = TICKET_MODIFY | 
          
            |  | 19 | accept.operations = set_owner_to_self | 
          
            |  | 20 | resolve = new,assigned,reopened -> closed | 
          
            |  | 21 | resolve.permissions = TICKET_MODIFY | 
          
            |  | 22 | resolve.operations = set_resolution | 
          
            |  | 23 | reassign = new,assigned,reopened -> new | 
          
            |  | 24 | reassign.permissions = TICKET_MODIFY | 
          
            |  | 25 | reassign.operations = set_owner | 
          
            |  | 26 | reopen = closed -> reopened | 
          
            |  | 27 | reopen.permissions = TICKET_CREATE | 
          
            |  | 28 | reopen.operations = del_resolution | 
          
            |  | 29 | }}} | 
        
        
          
            | 23 |  | [[Image(htdocs:../common/guide/basic-workflow.png)]] | 
          
            |  | 39 | {{{#!Workflow width=700 height=300 | 
          
            |  | 40 | leave = * -> * | 
          
            |  | 41 | leave.operations = leave_status | 
          
            |  | 42 | leave.default = 1 | 
          
            |  | 43 | accept = new,assigned,accepted,reopened -> accepted | 
          
            |  | 44 | accept.permissions = TICKET_MODIFY | 
          
            |  | 45 | accept.operations = set_owner_to_self | 
          
            |  | 46 | resolve = new,assigned,accepted,reopened -> closed | 
          
            |  | 47 | resolve.permissions = TICKET_MODIFY | 
          
            |  | 48 | resolve.operations = set_resolution | 
          
            |  | 49 | reassign = new,assigned,accepted,reopened -> assigned | 
          
            |  | 50 | reassign.permissions = TICKET_MODIFY | 
          
            |  | 51 | reassign.operations = set_owner | 
          
            |  | 52 | reopen = closed -> reopened | 
          
            |  | 53 | reopen.permissions = TICKET_CREATE | 
          
            |  | 54 | reopen.operations = del_resolution | 
          
            |  | 55 | }}} | 
        
        
          
            |  | 148 | === How to combine the `tracopt.ticket.commit_updater` with the testing workflow === | 
          
            |  | 149 |  | 
          
            |  | 150 | The [[trac:source:trunk/tracopt/ticket/commit_updater.py|tracopt.ticket.commit_updater]] is the optional component that [[TracRepositoryAdmin#trac-post-commit-hook|replaces the old trac-post-commit-hook]], in Trac 0.12. | 
          
            |  | 151 |  | 
          
            |  | 152 | By default it reacts on some keywords found in changeset message logs like ''close'', ''fix'' etc. and performs the corresponding workflow action. | 
          
            |  | 153 |  | 
          
            |  | 154 | If you have a more complex workflow, like the testing stage described above and you want the ''closes'' keyword to move the ticket to the ''testing'' status instead of the ''closed'' status, you need to adapt the code a bit. | 
          
            |  | 155 |  | 
          
            |  | 156 | Have a look at the [[trac:wiki:0.11/TracWorkflow#How-ToCombineSVNtrac-post-commit-hookWithTestWorkflow|Trac 0.11 recipe]] for the `trac-post-commit-hook`, this will give you some ideas about how to modify the component. | 
          
            |  | 157 |  | 
        
        
          
            | 222 |  | ''Look into the [th:wiki:AdvancedTicketWorkflowPlugin]'s `triage` operation.'' | 
          
            |  | 262 | ''Look into the [http://trac-hacks.org/wiki/AdvancedTicketWorkflowPlugin AdvancedTicketWorkflowPlugin]'s `triage` operation.'' | 
          
            |  | 263 |  | 
          
            |  | 264 | * I'd wish to have an option to perform automatic status changes. In my case, I do not want to start with "new", but with "assigned". So tickets in state "new" should automatically go into state "assigned". Or is there already a way to do this and I just missed it? | 
          
            |  | 265 | ''Have a look at [http://trac-hacks.org/wiki/TicketCreationStatusPlugin TicketCreationStatusPlugin] and [http://trac-hacks.org/wiki/TicketConditionalCreationStatusPlugin TicketConditionalCreationStatusPlugin]'' | 
          
            |  | 266 |  | 
          
            |  | 267 | * I added a 'testing' state. A tester can close the ticket or reject it. I'd like the transition from testing to rejected to set the owner to the person that put the ticket in 'testing'. The [http://trac-hacks.org/wiki/AdvancedTicketWorkflowPlugin AdvancedTicketWorkflowPlugin] is close with set_owner_to_field, but we need something like set_field_to_owner. | 
          
            |  | 268 |  | 
          
            |  | 269 | * I'd like to track the time a ticket is in each state, adding up 'disjoints' intervals in the same state. |