Time Management
This workflow defines state transitions and notifications based on the amount of time an issue spends in a specific state.
File Name | jetbrains-youtrack-timeManagement |
---|---|
Auto-attached | no |
Rules | Time Management (state-machine) |
Use Case
This workflow was originally taken from a submitted request (JT-6331).
The user who submitted this issue wanted to track issues reported by customers, prospects and team members and make sure issues are resolved within a specific time frame.
When a customer reports an issue:
- The support engineers have one hour to acknowledge the issue.
- The support engineers then have four hours to reproduce the case or to engage in a discussion to reproduce it
- If the issue is classified as a bug, the issue is assigned to the R&D department.
Rules
This rule defines the state transitions for issue in the project and determines the amount of time an issue can spend in each state.
Time Management
- The initial state is Submitted.
- When the issue enters the Submitted state, the Subsystem field is set to Support. The support engineer is set as the Assignee.
- From the Submitted state, the issue can transition to one of the following states:
- When the state is set to Overdue, a notification is sent to the Assignee (if the issue is assigned), subsystem owner (if the owner of the Support subsystem is defined), or the Project Lead (if none of the previous conditions are true).
- From the Overdue state, the issue can transition to one of the following states:
- From the Open state, the issue can transition to one of the following states:
- From the Wait for reproduce state, the issue can transition to one of the following states:
- If the state is unchanged after one day, notification is sent to the owner of the Support subsystem (if defined) or the Project Lead.
- If the state is unchanged after three days, a separate notification is sent to the owner of the Support subsystem (if defined) or the Project Lead.
- On event (action) approved the state is set to Approved.
- On event (action) incomplete the state is set to Incomplete.
- On event (action) can't reproduce the state is set to Can't Reproduce.
- When the state is set to Approved, the rule verifies that the Assignee is also set.
- From the Approved state, the issue can transition to one of the following states:
- From the Fixed state,the issue can transition to one of the following states:
- From Can't Reproduce, Incomplete, Obsolete and Verified states, the issue can transition to the Open state upon action reopen.
statemachine Time Management for field State {
initial state Submitted {
enter {
Subsystem = {Support};
}
exit {
Assignee.required(l10n ( Responsible support engineer is required! ));
}
in 1 hour[always] do {<define statements>} transit to Overdue
on reproducing[always] do {<define statements>} transit to Open
on incomplete[always] do {<define statements>} transit to Incomplete
}
state Overdue {
enter {
var user;
if (Assignee != null) {
user = Assignee;
} else if (Subsystem.owner != null) {
user = Subsystem.owner;
} else {
user = project.leader;
}
user.notify(l10n ( Acknowledgment needed ), l10n ( Issue {getId()} is waiting for acknowledgment. ));
}
on incomplete[always] do {<define statements>} transit to Incomplete
on reproducing[always] do {<define statements>} transit to Open
}
state Open {
in 4 hours[always] do {<define statements>} transit to Wait for reproduce
on approved[always] do {<define statements>} transit to Approved
on incomplete[always] do {<define statements>} transit to Incomplete
on can't reproduce[always] do {<define statements>} transit to Can't Reproduce
}
state Wait for reproduce {
in 1 day[always] do {
var user;
if (Subsystem.owner != null) {
user = Subsystem.owner;
} else {
user = project.leader;
}
user.notify(l10n ( Issue is not reproduced in 1 day ),
l10n ( Issue {getId()} is still waiting for reproduction steps. ));
// Notify sales?
}
in 3 days[always] do {
var user;
if (Subsystem.owner != null) {
user = Subsystem.owner;
} else {
user = project.leader;
}
user.notify(l10n ( Issue is not reproduced in 4 days ),
l10n ( Issue {getId()} is not reproduced, it's better to visit customer on his site. ));
// Notify sales?
}
on approved[always] do {<define statements>} transit to Approved
on can't reproduce[always] do {<define statements>} transit to Can't Reproduce
on incomplete[always] do {<define statements>} transit to Incomplete
}
state Can't Reproduce {
on reopen[always] do {<define statements>} transit to Open
}
state Incomplete {
on reopen[always] do {<define statements>} transit to Open
}
state Approved {
enter {
Assignee.required(fail message);
}
on fixed[always] do {<define statements>} transit to Fixed
on obsolete[always] do {<define statements>} transit to Obsolete
}
state Fixed {
on verify[always] do {<define statements>} transit to Verified
on reopen[always] do {<define statements>} transit to Open
}
state Obsolete {
on reopen[always] do {<define statements>} transit to Open
}
state Verified {
on reopen[always] do {<define statements>} transit to Open
}
}
Last modified: 18 April 2017