Thanks for choosing to contribute!
The following are a set of guidelines to follow when contributing to this project.
This project adheres to the Adobe code of conduct. By participating, you are expected to uphold this code. Please report unacceptable behavior to [email protected].
All third-party contributions to this project must be accompanied by a signed contributor license agreement. This gives Adobe permission to redistribute your contributions as part of the project. Sign our CLA. You only need to submit an Adobe CLA one time, so if you have submitted one previously, you are good to go!
All submissions should come in the form of pull requests and need to be reviewed by project committers. Read GitHub's pull request documentation for more information on sending pull requests.
Please follow the pull request template when submitting a pull request. Following the requirements for semantic releases (as described in the next section), each pull request should contain a single change and be comprised of a single commit.
In order to ensure proper error handling, individual commands should generally not handle errors themselves. Commands should throw errors and allow them to be caught by the catch
method in BaseCommand
. There may be exceptions specifically around errors that are non-fatal. Thrown errors should be defined in either ValidationErrors
or ConfigurationErrors
.
Hooks should work in a similar fashion -- see the prerun check-ims-context-config
hook as a point of reference.
Commits (generally via merged pull requests) to the main
branch of this repository will automatically generate semantically versioned releases. To accomplish this, commit messages must follow the Conventional Commits syntax, specifically:
For bug fixes:
fix(scope): <description> fixes #<issue number>
[optional content]
For features:
feat(scope): <description> fixes #<issue number>
[optional content]
In general, the scope should be the command name or topic, but there may be exceptions. The description of feature and fix issues should contain a reference to a github issue, e.g. fixes #200.