Please take a moment to review this document in order to make the contribution process easy and effective for everyone involved.
Feature requests stem from a business need. Also be sure to find out whether your idea fits with the scope and aims of the project of if this serves to address a personal/local scenario. It is up to you to make a strong case to convince the project's managers of the merits of this feature. Please provide as much detail and context as possible.
A bug is defined by: "A demonstrable problem that is caused by a file in the repository." Good bug reports are extremely helpful - thank you!
Guidelines for bug reports:
- Use the search option under Issues — check if the issue has already been reported
- Check if the issue has been fixed — try to reproduce it using the latest master or development branch in the repository
- Isolate the problem — ideally create a reduced test case and a live example
A good bug report shouldn't leave others needing to chase you up for more information. Please try to be as detailed as possible in your report. What is your environment? What steps will reproduce the issue? What parameters experience the problem? What would you expect to be the outcome? All these details will help people to fix any potential bugs.
Poor bug reports will be reassigned back to the creator for revision prior to any additional investigation.
No one other than repository managers have direct access to the repository. For all pull requests you must first fork the project to your own Github account.
All new work that is to be considered for merging with the MASTER
branch must start from a new feature branch of work. This feature branch should be in response to either a bug or a new business requirement.
The name of the feature branch should be descriptive as to the nature of the work and please include any references to the story or bug work item ID.
This project utilizes Conventional Commits to auto-generate release verions, based on the Angular Commit Message Guidelines.
<type>[optional scope]: <description>
All commit messages must be prefixed with a specific type so that the semver release configuration can analyze the commit and apply the correct version release. Please see the following types with their respective meanings.
For a MAJOR release, you MUST follow this template. The use of perf:
and BREAKING CHANGE:
are needed in order to push a major release.
perf(pencil): remove graphiteWidth option
BREAKING CHANGE: The graphiteWidth option has been removed.
The default graphite width of 10mm is always used for performance reasons.
feat(pencil): add 'graphiteWidth' option
fix(pencil): stop graphite breaking when too much pressure applied
type | description |
---|---|
build | Changes that affect the build system or external dependencies (example scopes: gulp, broccoli, npm) |
ci | Changes to our CI configuration files and scripts (example scopes: Travis, Circle, BrowserStack, SauceLabs) |
docs | Documentation only changes |
feat | A new feature (this correlates with MINOR in semantic versioning) |
fix | A bug fix (this correlates with PATCH in semantic versioning) |
perf | A code change that improves performance (correlating with MAJOR in semantic versioning) |
BREAKING CHANGE | A code change that is not backwards compatable (correlating with MAJOR in semantic versioning) |
refactor | A code change that neither fixes a bug nor adds a feature |
style | Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc) |
test | Adding missing tests or correcting existing tests |
Once you have completed your feature update, please commit all changes to the branch. All commit messages should use an imperative mood.
Imperative mood simply means “spoken or written as if giving a command or instruction”. A few examples are:
- Clean your room
- Close the door
- Take out the trash
A properly formed Git commit subject line should always be able to complete the following sentence:
"If applied, this commit will [your subject line here]."
For example:
- If applied, this commit will
refactor component X for accessibility
- If applied, this commit will
add feature Y to component X
Example messages when using Conventional Commits:
$ build: update to Gulp 4.x
$ docs: address issue #14, typo in install instructions
$ perf: restructure API to comply with new feature spec
$ feat: add ability to consume large data as an array versus string
$ fix: address issue #57 in regards to color output
One you have committed new work to your feature branch, be sure to push your updates to the Github repository. Depending on your IDE or CLI configuration this may be a manual or automatic step.
To submit a new pull request, please go to https://github.com/AlaskaAirlines to find your project and submit the Pull Request.
On the pull request page, the new pull request should be [your-new-branch] into [master]
Please be sure to follow the Pull Request template that appears on the comment window.
You must select up to two reviews from your team to validate that the update is correct, solves the problem presented by the story and meets all the requirements for a new merge.
Finally, click the Create
button.
Once a pull request has been created, the assigned reviewers should have received notifications. Each reviewer is expected to view the pull request and review all the data per this request.
A reviewer has the option to leave comments, ask questions and reject the pull request.
Once two reviewers have approved the work, the pull request can then be completed.