⭐ Thanks for taking the time to contribute ⭐
This document outlines the different ways you can contribute to the UNiDAYS repositories, guidelines on how to do it and some of our standardisations. Everything is open to improvement and all of these are guidelines. If you can think of something we can change or are missing in this doc - you can even open a pull request for making that kind of change.
What should I know before I get started?
When issuing a bug report please include as many of details on the bug report template as possible. If you find a Closed issue that seems like it is the same thing that you're experiencing, open a new issue and include a link to the original issue in the body of your new one. Please label the any bug report issues with bug
.
Enhancements may include completely new features and minor improvements to existing functionality. Following these guidelines helps maintainers and the community understand your suggestion and find related suggestions.
First of all please do a search on the issues already present to see if it's an enhancement that hasn't previously been suggested. If it has, maybe join the discussion on the pre-existing issue. This is to help reduce duplication of issues. If it hasn't been raised previously, please include as many details as you can using the feature request template. Label the raised feature request as enhancement
Label | Purpose |
---|---|
up-for-grabs | An issue that is ready and has enough information to be picked up |
docs | An issue that only relates to writing docs |
easy | Difficulty level: any level of experience can pick this issue up |
medium | Difficulty level: some experience of the domain or language will be needed to pick this issue up |
hard | Difficulty level: a lot of experience of the domain or language will be needed to pick this issue up |
insane | Difficulty level: you need to be a total wizard to figure this out |
enhancement | Making things better but without fixing an issue |
fix | Fixing a pre-existing problem with the code |
- Create branch. If there is an issue, have the branch name related to the linked issue, otherwise give it a descriptive name relating to what the work covers. See some examples below.
PR-prefix | Purpose | Example |
---|---|---|
issuenumber_ | When it relating to a pre-existing issues | issuenumber_583 |
enhancement | Making things better but without fixing an issue | enhancement_improveperformanceofquery |
fix | Fixing a pre-existing problem with the code that isn't an issue | fix_acceptnullsforinput |
-
Open a Pull Request with the details listed in the pull request template. The sections of this template should show in the body of any new pull request automatically.
-
Please ensure that any changes you make comply with our style guides.
-
Include screenshots and animated GIFs in your pull request whenever possible.
-
Make a comment with the pull request in any issues it relates to.
We will make efforts to label issues with beginner
if we think they should only require a few lines of code, and a test or two. This is in order to help those who want to contribute but don't necessarily have much experience in doing so.
We request that, where possible, you stick to the following format for your commit messages.
- Use the present tense ("Add feature" not "Added feature")
- Use the imperative mood ("Move cursor to..." not "Moves cursor to...")
- Limit the first line to 72 characters or less
- After the first line, be descriptive about what has been done in the commit.
For reference, this blog encourages a similar style.
In this project our tests are written using xUnit and Fluent Assertions. We would appreciate if you test cover your code using the same tooling and try to keep to a similar style that's in the project. This is to help it remain consistent and easier to maintain.
For anything changing the user experience or externally visible implementation, please update the README.md as part of your pull request.
If it's something cool, new and funky that you are contributing, please ensure it's covered with an MIT licence.