-
Notifications
You must be signed in to change notification settings - Fork 53
Project Management notes on processes
Issues will be categorized into "types" on a regular basis with input from the project team. During weekly meetings, the status of the issues will be updated and will also be prioritized. Subsequently, issues will be assigned to milestones to organize the deliverable. Below is a description of the labels to help clarify the organization of each issue.
Each issue should be labeled as one of the following types:
- [bug] - OpenGrid is not behaving in a manner that you expected
- [enhancement] - a request for a new feature or capabilities of the platform. See below for guidelines on how to best request an enhancement.
- [question] - issue is predominately a question with no specific issue or feature being requested
- [documentation] - pertaining to the documentation in the repo, such as
README.md
,CONTRIBUTING.md
,docs/
, or inline comments in the code.
After an issue is classified into a type, these labels inform everyone on the status of an issue:
- [ready] - issue ready to be worked on and can be worked on by the project team or other contributors requested will not be prioritized by the team--likely because it doesn't fit within the vision of the OpenGrid project.
- [in progress] - item is currently being worked on by the project team or partner
- [on dev] - issue has been deployed to the
dev
branch for final testing before released on themaster
branch. - Closed - Unless labelled [wontfix], the bug has been resolved or the enhancement incorporated
- [wontfix] - the issue won't be addressed by the project team, often because it doesn't fit into OpenGrid's product vision.
- [invalid] - the [bug] reported is not a bug
- [duplicate] - the issue is similar enough to another issue and the issue will be closed to help centralize discussions into a few threads. Check the comments to see which issue is closest to the duplicated issue.
An issue is prioritized into one of these levels. Work will be prioritized accordingly
- [Priority 1] - highest importance
- [Priority 2], [Priority 3], [Priority 4] - intermediate importance levels from higher to lower
- [Priority 5] - lowest importance
Milestones reflect the desired tasks in the current iteration of work. Milestones are aligned to dates, which should produce the next stable release of OpenGrid (e.g., 1.x.y). Issues are associated with each milestone to communicate which issues should be attempted in the sprint. The priority labels can also inform which issues are most important in each milestone.
Prior to the meeting, the project manager should:
- Review notes from the existing work throughout the week, closing any issues that were addressed and updating status
- Label existing and new issues in the repo (or note which ones that are unclear)
- Close issues
- Determine if others should be invited to the meeting
- Prepare a preliminary agenda
Each weekly meeting should review work that is in progress or completed since the last meeting; review existing and new pull requests;
- Review new issues as a group, ensuring there is an understanding of the issue. Determine if there is a prima facie reason to close the issue and communicate with the user for clarification as needed.
- If the issue
Review pull requests that have been opened on the repo. All pull requests must pass all "checks", which currently includes the contributor signing the Contributor License Agreement (CLA), pass the Travis-CI build process, pass the AppVeyor build process, does not significantly reduce code coverage, nor introduces out-of-date or insecure Node dependencies.
Pull requests can be classified into two types:
- Minor pull request - provides a modification to a trivial section of the repository, such as user documentation, and cannot possibly pose any technical harm or modifies the application. These pull requests can be accepted within the meeting if there is a consensus that it would not: cause a merge conflict, modify the functionality of the application, provide a security risk, or make any other significant modification that requires UAT and test deployment.
- Major pull request - a non-minor request that must be reviewed by the project team. The pull request should be reviewed and discussed as a group, but one or more team members will be assigned to do an in-depth review of the code which likely includes deployment to UAT.
Most pull requests will be classified as "major".
- Ensure the pull request passes all automated checks: CLA signature, Travis-CI (Ubuntu) test build and unit tests, AppVeyor (Windows) test build and unit tests, and equivalent or greater code coverage.
- Visual inspection of code for consistency
- "Codeword" match of functions against oft-used functions that can introduce security risks.
- Test the deployment using Covarity
- Ensure new unit tests have been written and adequately test any new function or functionality
If the pull requests satisfies these requirements, it may be accepted and integrated into the dev
branch.
In addition to automated testing, another party should conduct smoke tests and UAT tests. Below are the testing protocol that should be followed:
- Desktop device testing protocol
- Mobile device testing protocol
The conclusion of each milestone/sprint, should result in a new, stable version of the code. Once it passes all smoke tests, UAT, and unit tests, a new "release" should be announced.
Each release should be accompanied by informative release notes. At the minimum, the release notes should outline the features introduced or bugs that were fixed since the last stable release. Preferably, the release notes should link back to the issues and pull requests that were specifically addressed in the release.
The version number should be determined at the conclusion of each milestone following Semantic Versioning 2.0.0.
The new releases can be announced in a number of ways. Where as bug fixes should only have limited communication, minor and major releases should be communicated in a number of ways, including, but not limited to:
- GitHub Releases page
- Chicago Digital
- @ChicagoCDO Twitter account
- ChiHackNight meeting or Slack channel
- Code for America Slack channel
Once a new release has been deployed, need to work with the team to deploy the changes to WindyGrid and chicago.opengrid.io. Use the integration map to start on those activities.
- 2020-01-13
- 2019-09-30
- 2019-08-26
- 2019-06-10
- 2019-06-03
- 2019-05-13
- 2019-05-06
- 2019-04-29
- 2019-04-22
- 2019-02-25
- 2019-01-28
- 2019-01-07
- 2018-12-10
- 2018-12-03
- 2018-11-26
- 2018-11-19
- 2018-11-05
- 2018-10-29
- 2018-10-22
- 2018-10-15
- 2018-10-01
- 2018-09-24
- 2018-09-17
- 2018-09-10
- 2018-08-27
- 2018-08-20
- 2018-08-13
- 2018-08-06
- 2018-07-30
- 2018-07-23
- 2018-07-16
- 2018-07-09
- 2018-07-02
- 2018-06-25
- 2018-06-18
- 2018-06-11
- 2018-06-04
- 2018-05-21
- 2018-05-14
- 2018-05-07
- 2018-04-30
- 2018-04-23
- 2018-04-16
- 2018-04-09
- 2018-04-02
- 2018-03-26
- 2018-03-19
- 2018-03-12
- 2018-02-26
- 2018-02-05
- 2018-01-22
- 2018-01-22
- 2017-12-04
- 2017-10-30
- 2017-10-23
- 2017-10-02
- 2017-09-25
- 2017-09-11
- 2017-08-14
- 2017-08-07
- 2017-07-31
- 2017-07-24
- 2017-07-10
- 2017-06-26
- 2017-06-12
- 2017-05-22
- 2017-05-08
- 2017-05-01
- 2017-04-17
- 2017-03-28
- 2017-03-20
- 2017-03-13
- 2017-02-15
- 2017-02-06
- 2017-01-25
- 2017-01-20
- 2017-01-13
- 2017-01-06
- 2016-12-16
- 2016-12-09
- 2016-12-01
- 2016-11-09
- 2016-11-04
- 2016-10-28
- 2016-10-21
- 2016-10-14
- 2016-10-07
- 2016-09-30
- 2016-09-23
- 2016-09-16
- 2016-09-09
- 2016-09-01
- 2016-08-26
- 2016-08-19
- 2016-08-12
- 2016-08-04
- 2016-07-29
- 2016-07-22
- 2016-07-15
- 2016-07-08
- 2016-06-30
- 2016-06-24
- 2016-06-17
- 2016-06-10
- 2016-06-03
- 2016-05-27
- 2016-05-20
- 2016-05-13
- 2016-05-06
- 2016-04-29
- 2016-04-22
- 2016-04-15
- 2016-04-08
- 2016-04-01
- 2016-03-25
- 2016-03-18
- 2016-03-11
- 2016-02-26
- 2016-02-19
- 2016-02-05
- 2016-01-28