Skip to content

Latest commit

 

History

History
44 lines (35 loc) · 2.7 KB

CONTRIBUTING.md

File metadata and controls

44 lines (35 loc) · 2.7 KB

Contributing to the SOTA Client CPP Project

We welcome code contributions from the community and are very happy to receive feedback, issue reports and code in the form of pull requests.

Issue Tracker

This project uses the Github issue tracker. Please report bugs, issues and feature requests here

Contributing Code

All code should be developed according to the Google C++ style guide. In addition, the code should conform to the following guidelines:

  • Code should be covered by tests
    • Wherever possible, automated testing should be used
    • Tests cases should at least exercise all documented requirements
    • If automated testing is not possible, manual test cases should be described
  • It must be easy for a developer checking out a project to run the test suite based on the information in the README.md file
  • All code must pass all unit tests before a merge request is made
    • Tests that don't pass should be marked pending (with justification) or should be fixed.
  • Features should be developed in feature branches
  • Only working code should go into the master branch.
    • master should always be in a deployable state
    • Undeployable code should stay on feature branches
      • Code failing the active unit or integration tests for a project is undeployable
      • Functionally incomplete code is not necessarily undeployable
  • Feature branches should only contain single features
    • Developers should not create large, week-long, multiple-feature branches
    • Developers should try to have their code merged at least once every two days
  • All code must be reviewed before it is merged to a master branch.
    • The reviewer can not be the code author
    • All the reviewer's concerns must be resolved to reviewer's satisfaction
    • Reviews should enforce the coding guidelines for the project
  • Bugs reported against code on a master branch should be reproduced with a failing test case before they are resolved
    • Reviewers of code including bug fixes should check that a covering test has been included with the fix

Making a Pull Request

When you start developing a feature, please create a feature branch that includes the type of branch, the ID of the issue, and a brief description. For example feat/9/https-support, bugfix/11/fix-token-expiry or refactor/13/tidy-up-imports. Please do not mix feature development, bugfixes and refactoring into the same branch.

When your feature is ready, push the branch and make a pull request. We will review the request and give you feedback. Once the code passes the review it can be merged into master and the branch can be deleted.