First off, thanks for taking the time to contribute!
The following is a set of guidelines for contributing to Moira and its packages, which are hosted in the Moira Organization on GitHub. These are mostly guidelines, not rules. Use your best judgment, and feel free to propose changes to this document in a pull request.
If you find bugs or you want propose an idea that you think will be suitable for Moira you can create an issue. The main issue tracker is https://github.com/moira-alert/moira/issues. Issues that belong to moira backend and web are placed here. Issues that are related to documentation, python client and ansible role should be placed in issue tracker for related repo(docs, python client, ansible role).
We have templates for two types of issues: a Feature Request and a Bug. If you want to submit a bug please be patient and fill all required fields. This will help us to define the problem.
Try to follow this advice to fill a great issue:
- Check that issue tracker does not contain issues similar to your.
- Use a clear and descriptive title for the issue to identify the suggestion.
- Provide a step-by-step description of the suggested enhancement in as many details as possible.
- Provide specific examples to demonstrate the steps. Include copy/pasteable snippets which you use in those examples, as Markdown code blocks.
- Describe the current behavior and explain which behavior you expected to see instead and why.
- Include screenshots and animated GIFs which help you demonstrate the steps to reproduce issue.
- Explain why this enhancement would be useful to most Moira users.
- Specify which version of Moira you're using.
If you want to contribute a code you should choose an issue and comment that you want to work on it. If you cannot find an issue for your contribution please fill an issue first. Please DO NOT work on code before you file an issue and comment about your wish to work on it.
Here you can find issues that are good for first time contributors.
During implementation and submission of code follow style guides listed below.
The main source of knowledge about Moira is a documentation that is hosted on Read the Docs service. You can help improve the Moira guides or the API reference by making them more coherent, consistent, or readable, adding missing information, correcting factual errors, fixing typos, or bringing them up to date with the latest Moira release. Check moira-alert/doc for sources of documentation.
One of our goals is to provide beautiful and clear documentation of Moira API. If you familiar with Go and OpenAPI specification you can add description of missing API methods to swagger file located in api
folder of moira-alert/doc repository.
We are using Conventional Commits philosophy to submit the code. If you are not familiar with Conventional Commits it's highly recommended to read documentation about it.
In general the rules for commits are following:
- Commit message should have three blocks: title, body and footer divided with empty lines.
- At least title should be specified.
- Start first line with type of commit. You can find commit types below.
- Place summary in the first line.
- If applicable specify the scope of commit.
- In body describe the changes you did. Write mostly why you did changes instead what you changed.
- You can split a body to multiple paragraphs using blank lines.
- In footer place an additional information about your commit. Specify issue number in footer with
Relates
orCloses
label.
Structure of commit:
<type>[optional scope]: <description>
[optional body]
[optional footer(s)]
We are using following commit types in our repo:
- build: Changes that affect the build system or external dependencies
- ci: Changes to our CI configuration files and scripts
- docs: Documentation only changes
- feat: A new feature
- fix: A bug fix
- perf: A code change that improves performance
- 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
Good commit message example:
fix(notifier): Handle nil pointer dereference
At notifier/plotting.go inside fetchAvailableSeries in case of error
returned from `metricsSource.Fetch` only
`local.ErrEvaluateTargetFailedWithPanic` was checked. Another errors did
not handled properly and function was trying to call methods of fetch
result which became nil. That caused Nil Pointer Dereference panic. Add
proper error handling to prevent nil pointer dereference.
Closes #437
We are using GolangCI-Lint to check our code for following the code style. Check your code with make lint
before you will submit it. Code with broken style will not pass the CI and will not be reviewed.
We are using unit and integration tests to check that Moira behaviour satisfies our expectations and we expect that contributors will cover with tests changed code as much as possible. Use tests skipping in short mode for tests that uses database. If you fix a bug first cover a bug with test that reproduce this bug then fix it.
To build and run tests you need local redis listening on port 6379. Easiest way to get redis is via docker:
docker run -p 6379:6379 -d redis:alpine
To run test use go test ./...
or run GoConvey:
go get github.com/smartystreets/goconvey
goconvey
For full local deployment of all services, including web, graphite and metrics relay (may be slow on first launch) use:
docker-compose up
Before pushing your changes don't forget about linter:
make lint