Skip to content

Latest commit

 

History

History
executable file
·
45 lines (26 loc) · 2.5 KB

CONTRIBUTING.md

File metadata and controls

executable file
·
45 lines (26 loc) · 2.5 KB

Contributing

Thanks for choosing to contribute!

The following are a set of guidelines to follow when contributing to this project.

Code Of Conduct

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].

Contributor License Agreement

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!

Code Reviews

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.

Error Handling

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 and Releasing

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.