Skip to content

Commit

Permalink
Merge pull request #303 from inspire-eu-validation/release-strategy
Browse files Browse the repository at this point in the history
Release strategy PR to master for Helpdesk Management
  • Loading branch information
MarcoMinghini authored May 11, 2020
2 parents 08c2d0a + 93d4cb4 commit f3be90d
Show file tree
Hide file tree
Showing 4 changed files with 67 additions and 0 deletions.
64 changes: 64 additions & 0 deletions helpdesk management/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
# Table of contents
- [Introduction](#introduction)
- [Helpdesk management workflow](#helpdesk-management-workflow)
* [GitHub labels](#github-labels)
* [GitHub milestones](#github-milestones)
* [GitHub project board](#github-project-board)

# Introduction
The establishment of a proper communication with the INSPIRE Validation community is a key asset for the operation, maintenance and update of the INSPIRE Reference Validator. The [helpdesk of the INSPIRE Reference Validator](https://github.com/inspire-eu-validation/community/issues) is the core of the communication strategy, since it is the platform where users can report bugs, propose new features and start discussions on the Validator. The objective of this document is to illustrate the systematic workflow adopted by the INSPIRE Validation team to organise, address and manage the issues reported by users in the Validator helpdesk.

<!-- For this, the issue management functionalities offered by GitHub are being used, providing assistance to the users' requests, as well as offering detailed information of the changes and hotfixes that will be included in the different versions.
In this way, a workflow is established for the Helpdesk Management that allows to carry out in a systematic and organized way the management of the different issues that are incorporated to the Community repository.
So, the aim of this document is to explain in detail the procedure established for the issues management in order to have a proper understanding in the defined process for its management. -->

# Helpdesk management workflow
The helpdesk management workflow defines the actions performed by the INSPIRE Validation team to address and solve the problems reported by the users of the INSPIRE Validator. The workflow makes use of a number of GitHub artifacts: labels, milestones and the project board.

## GitHub labels <!-- could be removed, if not needed -->
To be able to know the status of each issue reported in the helpdesk (from the initial assessment to the final implementation of a solution for it), a number of labels are used. These are listed on [this page](https://github.com/inspire-eu-validation/community/labels) and are described in more detail below in the chronological order in which they are used while managing each Validator issue:

* **_under analysis_**: this label is assigned after the issue has been opened, and indicates that the INSPIRE Validation Team is performing a first analysis to figure out what is the problem and how to address it; in case this requires further information from the user, the INSPIRE Validation Team asks the user to provide it in the issue discussion.
* **_discussion_**: this label is assigned to the issue, in case the initial analysis reveals that it is neither a bug of the INSPIRE Reference Validator nor a new requested feature; in other words, the issue will remain open for community discussion but no further action will be made by the INSPIRE Validation Team;
* **_under development_**: in case the initial analysis reveals that a change in the INSPIRE Reference Validator is needed, this label is assigned to the issue to indicate that the INSPIRE Validation team is developing a solution for the problem reported;
* **_ready for testing_**: this label is assigned to the issue, to indicate that a solution for the problem reported has been developed by the INSPIRE Validation team and is ready to be tested in the [Staging instance](http://staging-inspire-validator.eu-west-1.elasticbeanstalk.com/etf-webapp/) of the INSPIRE Reference Validator; in the issue discussion, the user who originally reported the problem is invited to test the solution and provide feedback;
* **_solved_**: this label is assigned to the issue after the user has tested the developed solution in the [Staging instance](http://staging-inspire-validator.eu-west-1.elasticbeanstalk.com/etf-webapp/) of the INSPIRE Reference Validator and has confirmed in the issue discussion that it actually solved the problem; no issue is marked as _solved_ without such a written confirmation from the user.
* **_deployed in reference validator_**: this label is assigned to the issue, when the developed solution is also included in the [Production instance](https://inspire.ec.europa.eu/validator/) of the INSPIRE Reference Validator; the release schedule of the Production instance is described [here](https://github.com/inspire-eu-validation/community/tree/master/release%20strategy). Once the solution has been included in the Production instance, the issue is finally closed.

The diagram below shows the full helpdesk management cycle for each issue, from the initial stage when it is opened to the final stage when it is closed. The two swim lanes identify the actions expected/required from the user (on the left) and from the INSPIRE Validation team (on the right). In addition to the labelling rules described above, the diagram shows that after the initial analysis the GitHub issue is assigned to the developer in charge of producing the solution, and then to the user once the solution has been included in the Staging instance.

![Helpdesk Management Workflow](./img/HelpdeskWorkflowPublic.png "Helpdesk Management Workflow")

## GitHub milestones
To inform users in advance about when the solution to each issue will be included in the [Production instance](https://inspire.ec.europa.eu/validator/) of the INSPIRE Reference Validator, each issue is assigned to a specific milestone. Milestones are listed in [this page](https://github.com/inspire-eu-validation/community/milestones) and their names have a 1:1 correspondence with the release versions of the INSPIRE Reference Validator. The release schedule of the INSPIRE Reference Validator, which lists the expected release dates for each specific version, is available [here](https://github.com/inspire-eu-validation/community/tree/master/release%20strategy). Once a new version of the INSPIRE Reference Validator is released, the corresponding milestone is closed and moved to the [list of closed milestones](https://github.com/inspire-eu-validation/community/milestones?state=closed).

## GitHub project board
A third way for users to know the status of each issue reported in the helpdesk is to check the project board, which is available [here](https://github.com/inspire-eu-validation/community/projects/1). Based on the label associated to each issue, the project board automatically classifies the issues into 6 blocks corresponding to the status of development of the corresponding solution:

* **_For discussion_**, including the issues currently labeled as _discussion_;
* **_To do_**, including the issues currently labeled as _under analysis_;
* **_In progress_**, including the issues currently labeled as _under development_;
* **_Staging: for acceptance_**, including the issues currently labeled as _ready for testing_;
* **_Staging: in release planning_**, including the issues currently labeled as _solved_;
* **_Production: latest release_**, including the issues currently labeled as _deployed in reference validator_.

The issues are automatically moved from one block to the other as soon as its label is changed as described above.

<!-- Below is a diagram describing the workflow of an issue, along with the states in which it can be found and which actor takes action on it.
In the diagram above, the workflow is triggered by the submission of an issue in GitHub by a community user.
In the first instance, the Validation Team contacts the user and sets a tag "under analysis" to proceed to collect the necessary information to solve the issue. At this point, it is possible to iterate with the user to request more detail about the submitted issue.
Once there is enough information, the issue is classified either as "discussion", in case it is not an issue directly related to the Validator or it is related with a new feature request, or as "under development", so the tasks associated to its resolution are carried out.
After the development of the tasks for the resolution of the issue and its integration in the INSPIRE Reference Validator Staging environment, the issue is marked as "ready for testing". At this stage, the explicit validation of the user is requested to ensure that the resolution of the issue provides, in fact, enough coverage to the needs initially requested.
If the resolution of the issue covers the needs raised, it is incorporated into the INSPIRE Reference Validator roadmap and, once this issue is deployed in the production environment, the issue is marked as "closed". Otherwise, the workflow may go back in order to iterate until the issue is finally closed.
In this way, the workflow for attending to incidents related to the INSPIRE Reference Validator is completed. -->


<!-- In order to establish a proper issues management procedure, it has been created a workflow that allows to know at any moment the state of an issue. This workflow defines a set of actions for the resolution of issues in which both the users and the Validation Team will participate.
In this Helpdesk Management Workflow, issues go through a series of status that are marked by means of the use of labels that identify in a simple way the actions taken until the moment and the next actions to take.
In summary, the tags that an issue can be assigned with are the following:
* under analysis: indicates that the Validation Team is performing an analysis of the scope of the issue
* under development: shows that the Validation Team is running a development according to the analysis of the issue
* ready for testing: the development associated with the issue has been carried out and is available to the user for validation in the INSPIRE Reference Validator Staging environment
* solved: once the user has confirmed that the development carried out is adequate, the issue is marked as solved. Please note that only the issues of which the developed solution is accepted by the users will be incorporated to the next release in the Production environment
* closed: an issue is tagged as "closed" when it has been deployed in the INSPIRE Reference Validator environment
* discussion: if it is not an issue directly related with the INSPIRE Reference Validator or it is a new feature requested by an user, it is labeled for discussion -->
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions helpdesk management/img/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
community/helpdesk management/img is a directory to store images related to the helpdesk management
2 changes: 2 additions & 0 deletions release strategy/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,8 @@ Each release of the INSPIRE Reference Validator is fully managed and made availa

* a **GitHub package**, published on the [Packages section of the _community_ repository](https://github.com/inspire-eu-validation/community/packages), including the instructions and resources needed to deploy the corresponding release of the INSPIRE Reference Validator through the use of Docker.


* update of the **[GitHub issue tracker of the _community_ repository](https://github.com/inspire-eu-validation/community/issues)** by changing the label of the issues solved within the corresponding release from _solved_ to _deployed in reference validator_ and by closing them;


* update of the **[Validator issues project board](https://github.com/inspire-eu-validation/community/projects/1)** by moving all the issues labeled as _deployed in reference validator_ to the column _Production: latest release_.

0 comments on commit f3be90d

Please sign in to comment.