1
0
mirror of https://github.com/nikoksr/notify.git synced 2025-01-10 00:28:36 +02:00
notify/CONTRIBUTING.md
2022-09-16 10:08:30 +03:00

57 lines
1.8 KiB
Markdown

## Contributing to Notify
We want to make contributing to this project as easy and transparent as possible.
## Tests
Ideally, unit tests should accompany every newly introduced exported function. We're always striving to increase the project's test coverage.
If you need to mock an interface in your tests, follow the next steps:
1. Comment the interface you'd like to mock following the example below
```go
//go:generate mockery --name=nameOfClient --output=. --case=underscore --inpackage
type nameOfClient interface {
...
}
```
> Remember to set the `--name` argument accordingly. For real-life implementation examples, check out existing services, for example [fcm](https://github.com/nikoksr/notify/blob/bda5705e4ee1cbf6b02bbb12679ed597334dee51/service/fcm/fcm.go#L27).
2. Run `make mock`
> The first time you'll also need to run `make setup` to download the packages required to generate your mocks
3. Use the mocked interface in your tests
```go
mockClient := newMockNameOfClient(t)
```
## Commits
Commit messages should be well formatted, and to make that "standardized", we are using Conventional Commits.
You can follow the documentation on [their website](https://www.conventionalcommits.org).
## Pull Requests
We actively welcome your pull requests.
1. Fork the repo and create your branch from `main`.
2. If you've added code that should be tested, add tests.
3. If you've changed or added exported functions or types, document them.
4. Ensure the test suite passes (`make ci`).
## Issues
We use GitHub issues to track public bugs. Please ensure your description is clear and has sufficient instructions to be
able to reproduce the issue.
## License
By contributing to notify, you agree that your contributions will be licensed under the LICENSE file in the root
directory of this source tree.