Skip to content
This repository has been archived by the owner on Dec 13, 2024. It is now read-only.

Latest commit

 

History

History
51 lines (42 loc) · 2.61 KB

CONTRIBUTING.md

File metadata and controls

51 lines (42 loc) · 2.61 KB

This file

This file should describe the development process for this project and include instruction on how to run/build your project. Any environment settings/requirements?

Development guidelines

The general proces is as follows:

  • Create a branch on your local working copy
  • make code modifications, including tests, documentation, etc
  • commit/push changes to remote/origin
  • submit a pull request for merging into master
  • Discuss with code reviewer if/what changes are needed
  • when all discussions are resolved, the PR will be merged by the reviewer
  • Update Changelog!

Code Quality guide lines

Quality guide lines serve to improve quality. They should not be busy work nor work against developers. They should be of value.

Code review

  • Every commit should be created on its own branch and submitted per pull request to be merged with the main branch.
  • Every pull request must be reviewed by at least one other developer and all comments must be resolved.
  • No linting issues may remain before merging.
  • No type checking issues may remain before merging.
  • Code reviews are not about distrust. They are about sharing knowledge about the code base, sharing knowledge about writing code and increasing quality by collaboration.

Documentation

  • Every function must have documentation explaining what the function does in a summary and explaining each argument and return type.

Linting

  • Linting maintains a shared quality of the code base across repositories.
  • Rules of the linter may only be ignored when approved by the software leads. Prefer to silence individual lines by '

Type checking

  • Every function must have a return type and an argument list annotated with functions.
  • Rules of the type checker may only be ignored when approved by the software leads.

Testing

Unit testing

  • Every function should be covered by a unit test. Some functions allow more easily for unit tests and some are not worth unit testing. This is up to the teams discretion.
  • A unit test should test some significant amount of code. If the test function is similar or equal to the logic being tested, the amount of code being tested is too small. If the test function tests whole modules or multiple layers of code, the amount of code being tested is too big. The amount of code being tested is referred to as the 'unit-under-test'.
  • Use mocks to isolate 'unit-under-test' where applicable.
  • Coverage percentage should be >80%. This is a guideline, not a hard rule. Breaking this guideline is allowed if the arguments has swayed the developersteam and not just the developer and reviewer.