Changes between Version 5 and Version 6 of TracTickets
- Timestamp:
- 2021-04-21T12:44:16+02:00 (4 years ago)
Legend:
- Unmodified
- Added
- Removed
- Modified
-
TracTickets
v5 v6 1 = The Trac Ticket System =1 = The Trac Ticket System 2 2 [[TracGuideToc]] 3 3 4 The Trac ticket database providessimple but effective way to track issues and software bugs within a project.4 The Trac ticket system provides a simple but effective way to track issues and software bugs within a project. 5 5 6 6 As the central project management element of Trac, tickets can be used for '''project tasks''', '''feature requests''', '''bug reports''', '''software support issues''' among others. 7 7 8 As with the TracWiki, this subsystem has been designed with the goal of makinguser contribution and participation as simple as possible.8 As with the TracWiki, this subsystem has been designed to make user contribution and participation as simple as possible. 9 9 10 10 An issue is assigned to a person who must resolve it or reassign the ticket to someone else. All tickets can be edited, annotated, assigned, prioritized and discussed at any time. 11 11 12 12 [=#edit-permissions] 13 However, a Trac installation may place restrictions on who can change what. For example, the default installation doesn't permit to non-authenticated users ("anonymous" users) to change anything, even to comment on an issue, for obvious spam prevention reasons. Check the local contributing policy, which you can usually find on the front page WikiStart, or contact your local Trac administrator.13 However, a Trac installation may place restrictions on who can change what. For example, the default installation doesn't permit to non-authenticated users ("anonymous" users) to change anything, even to comment on an issue, for obvious spam prevention reasons. Check the local contributing policy, which you can usually find on the front page of WikiStart, or contact your local Trac administrator. 14 14 15 == Ticket Fields ==15 == Ticket Fields 16 16 17 17 A ticket contains the following information: 18 18 19 19 * '''Reporter''' — The author of the ticket. 20 * '''Type''' — The category of the ticket. The default types are `defect`, 21 * '''Component''' — The project module or subsystem th is ticket concerns.20 * '''Type''' — The category of the ticket. The default types are `defect`, `enhancement` and `task`. 21 * '''Component''' — The project module or subsystem that this ticket concerns. 22 22 * '''Version''' — Version of the project that this ticket pertains to. 23 * '''Keywords''' — Keywords that a ticket is marked with. Useful for searching and report generation.24 * '''Priority''' — The importance of this issue, ranging from ''trivial'' to ''blocker''. A pull-down if differentpriorities are defined.25 * '''Milestone''' — Due date of when this issue should be resolved. A pull-down menu containing a list ofmilestones.23 * '''Keywords''' — Keywords that a ticket is tagged with. Useful for searching and report generation. 24 * '''Priority''' — The importance of this issue, ranging from ''trivial'' to ''blocker''. A dropdown list when multiple priorities are defined. 25 * '''Milestone''' — Due date of when this issue should be resolved. A dropdown list containing the milestones. 26 26 * '''Assigned to/Owner''' — Principal person responsible for handling the issue. 27 * '''Cc''' — A comma-separated list of other users or email addresses to notify. ''Note that this does not imply responsibility or any other policy.''27 * '''Cc''' — A comma-separated list of other users or email addresses to notify. Note that this does not imply responsibility or any other policy. 28 28 * '''Resolution''' — Reason for why a ticket was closed. One of {{{fixed}}}, {{{invalid}}}, {{{wontfix}}}, {{{duplicate}}}, {{{worksforme}}}. 29 29 * '''Status''' — What is the current status? The statuses are defined in the [TracWorkflow#BasicTicketWorkflowCustomization ticket workflow]. For the default workflow the statuses are `new`, `assigned`, `accepted`, `closed` and `reopened`. … … 34 34 - Versions of Trac prior to 0.9 did not have the ''type'' field, but instead provided a ''severity'' field and different default values for the ''priority'' field. This change was done to simplify the ticket model by removing the somewhat blurry distinction between ''priority'' and ''severity''. However, the old model is still available if you prefer it: just add/modify the default values of the ''priority'' and ''severity'', and optionally hide the ''type'' field by removing all the possible values through [wiki:TracAdmin trac-admin]. 35 35 36 - The [trac:TicketTypes type], [trac:TicketComponent component], version, priority and severity fields can be managed with [wiki:TracAdmin trac-admin] or with the [trac:WebAdmin WebAdmin] plugin.36 - The [trac:TicketTypes type], [trac:TicketComponent component], version, priority and severity fields can be managed with [wiki:TracAdmin trac-admin] or through the !WebAdmin. 37 37 38 - Description of the builtin ''priority'' values is available at [trac:T icketTypes#Whyistheseverityfieldgone TicketTypes]38 - Description of the builtin ''priority'' values is available at [trac:TracDev/Proposals/TicketTypes#Whyistheseverityfieldgone TicketTypes]. 39 39 40 == Changing and Commenting Tickets ==40 == Changing and Commenting Tickets 41 41 42 42 With appropriate permissions, as already mentioned [#edit-permissions above], a ticket entered into Trac can at any time be modified by '''annotating'''. … … 44 44 Then, annotations like changes and comments to the ticket are logged as a part of the ticket itself. When viewing a ticket, the history of changes will appear below the main ticket area. 45 45 46 Comment editing (available since 0.12) is meant to be used to make small corrections to comments, like fixing formatting, forgotten WikiFormatting or spelling errors, not major edits. For longer edits, you should be adding a new comment instead. Editing a comment will not produce a new entry on [/timeline]while entering a new comment or other changes will do.46 Comment editing (available since Trac version 0.12) is meant to be used to make small corrections to comments, like fixing formatting, forgotten WikiFormatting or spelling errors, not major edits. For longer edits, you should be adding a new comment instead. Editing a comment will not produce a new entry on [/timeline], while entering a new comment or other changes will do. 47 47 48 48 All edits (field changes, new comments, comment edits) update the "last changed" time of the ticket. 49 50 49 51 50 '''Notes:''' … … 56 55 - See TracWorkflow for information about the state transitions (ticket lifecycle), and how this workflow can be customized. 57 56 58 == Default Values for Drop-Down Fields ==57 == Default Values for Drop-Down Fields 59 58 60 59 The option selected by default for the various drop-down fields can be set in [wiki:TracIni trac.ini], in the `[ticket]` section: 61 60 62 * `default_component`: Name of the component selected by default 63 * `default_milestone`: Name of the default milestone 64 * `default_priority`: Default priority value 65 * `default_severity`: Default severity value 66 * `default_type`: Default ticket type 67 * `default_version`: Name of the default version 61 * `default_component`: Name of the component selected by default. 62 * `default_milestone`: Name of the default milestone. 63 * `default_priority`: Default priority value. 64 * `default_severity`: Default severity value. 65 * `default_type`: Default ticket type. 66 * `default_version`: Name of the default version. 68 67 * `default_owner`: Name of the default owner. If set to the text `< default >` (the default value), the component owner is used. 69 68 70 If any of these options are omitted, the default value will either be the first in the list, or an empty value, depending on whether the field in question is required to be set. Some of these can be chosen through the [trac:WebAdmin WebAdmin] plugin in the "Ticket System" section, others can be set in the [[wiki:TracIni#ticket-section|"[ticket]"]] section in `trac.ini`.69 If any of these options are omitted, the default value will either be the first in the list, or an empty value, depending on whether the field in question is required to be set. Some of these can be chosen through the !WebAdmin in the "Ticket System" section, others can be set in the [[wiki:TracIni#ticket-section|"[ticket]"]] section in `trac.ini`. 71 70 72 73 == Hiding Fields and Adding Custom Fields == 71 == Hiding Fields and Adding Custom Fields 74 72 75 73 Many of the default ticket fields can be hidden from the ticket web interface simply by removing all the possible values through [wiki:TracAdmin trac-admin]. This of course only applies to drop-down fields, such as ''type'', ''priority'', ''severity'', ''component'', ''version'' and ''milestone''. … … 77 75 Trac also lets you add your own custom ticket fields. See TracTicketsCustomFields for more information. 78 76 77 == Assign-to as Drop-Down List 79 78 80 == Assign-to as Drop-Down List == 79 If the list of possible ticket owners is finite, you can change the ''assign-to'' ticket field from a text input to a drop-down list. This is done by setting the `restrict_owner` option of the `[ticket]` section in [wiki:TracIni trac.ini] to `true`. In that case, Trac will populate the list with all users who **have an authenticated session** and possess the `TICKET_MODIFY` [TracPermissions permissions]. 81 80 82 If the list of possible ticket owners is finite, you can change the ''assign-to'' ticket field from a text input to a drop-down list. This is done by setting the `restrict_owner` option of the `[ticket]` section in [wiki:TracIni trac.ini] to `true`. In that case, Trac will populate the list with all users who have authenticated with the project and possess the `TICKET_MODIFY` [TracPermissions permissions]. 81 An authenticated session will be created the first time a user authenticates with the project. You can manually add an authenticated session using the ["TracAdmin#?session add" trac-admin] `session add` command. The `:1` suffix on the session id (i.e. username) is the key to creating an authenticated session: 82 {{{#!sh 83 trac-admin /path/to/projenv session add <sid>:1 [name] [email] 84 }}} 83 85 84 86 You may find the dropdown list is //overpopulated// with users that are no longer active in the project. Revoking authentication privileges will not remove the session data that is used to populate the dropdown list. The [wiki:TracAdmin trac-admin] command can be used to list and remove sessions: … … 96 98 97 99 '''Notes:''' 98 - If you need serious flexibility and aren't afraid of a little plugin coding of your own, see [http://trac-hacks.org/wiki/FlexibleAssignToPlugin FlexibleAssignTo]. 100 - If you need more flexibility, then use subclass `ConfigurableTicketWorkflow` and override the `get_allowed_owners` method (see [trac:#12807 Trac ticket 12807]). 101 102 - Activating this option may cause some performance degradation. Read more about this in the [trac:TracPerformance#Configuration Trac performance] page. 99 103 100 - Activating this option may cause some performance degradation. Read more about this in the [trac:TracPerformance#Configuration Trac performance] page. 101 102 == Preset Values for New Tickets == 104 == Preset Values for New Tickets 103 105 104 106 To create a link to the new-ticket form filled with preset values, you need to call the `/newticket?` URL with `variable=value` separated by `&`. Possible variables are: 105 107 106 * '''type''' — The type droplist 107 * '''reporter''' — Name or email of the reporter 108 * '''summary''' — Summary line for the ticket 109 * '''description''' — Long description of the ticket 110 * '''component''' — The component droplist 111 * '''version''' — The version droplist 112 * '''severity''' — The severity droplist 113 * '''keywords''' — The keywords 114 * '''priority''' — The priority droplist 115 * '''milestone''' — The milestone droplist 116 * '''owner''' — The person responsible for the ticket 117 * '''cc''' — The list of emails for notifying about the ticket change 108 * '''type''' — The type droplist. 109 * '''reporter''' — Name or email of the reporter. 110 * '''summary''' — Summary line for the ticket. 111 * '''description''' — Long description of the ticket. 112 * '''component''' — The component dropdown list. 113 * '''version''' — The version dropdown list. 114 * '''severity''' — The severity dropdown list. 115 * '''keywords''' — The keywords or tags. 116 * '''priority''' — The priority dropdown list. 117 * '''milestone''' — The milestone dropdown list. 118 * '''cc''' — The list of emails for notifying about the ticket change. 118 119 119 Example: ''`[/newticket?summary=Compile%20Error&version=1.0&component=gui]`'' 120 Example: `[/newticket?summary=Compile%20Error&version=1.0&component=gui]` 121 122 To set the ticket owner the workflow action may also need to be selected. For the [TracWorkflow#TicketCreateAction default workflow], the //create and assign// action can be selected with `action=create_and_assign` and the owner specified by assigning `action_create_and_assign_reassign_owner`. Alternatively, you could avoid needing to select the action by using the [TracWorkflow#BasicTicketWorkflowCustomization default attribute] to make //create and assign// the default action. 123 124 For other custom workflow actions, determine the variable names by inspecting the `name` attribute of the //action// radio button and the //owner// input or select element. 125 126 == Deleting Tickets 127 128 Ticket delete and ticket change delete functions are enabled through an optional component. To enable the functionality edit the [TracIni#components-section "[components]"] section of TracIni: 129 {{{#!ini 130 [components] 131 tracopt.ticket.deleter.* = enabled 132 }}} 133 134 The //Delete// buttons appears next to the //Reply// buttons in the ticket description and ticket change areas. `TICKET_ADMIN` permission is required for deleting tickets and ticket changes. 120 135 121 136 ---- 122 See also: TracGuide, TracWiki,TracTicketsCustomFields, TracNotification, TracReports, TracQuery137 See also: TracTicketsCustomFields, TracNotification, TracReports, TracQuery