ansible-nas/CONTRIBUTING.md
2022-08-24 09:28:54 +01:00

1.8 KiB

Contributing

Contributing to Ansible-NAS is easy! Add your functionality, then raise a pull request on GitHub. A few things to bear in mind:

  • Restrict pull requests to one piece of functionality or bugfix at a time.
  • Test your new functionality or bugfix using the included tests/test-vagrant.sh script to spin up a test VM.
  • Run ansible-lint against the playbook before committing. (There is a VSCode task set up to run the right command for you)
  • Ensure that your PR only changes files required for your functionality or bugfix. Random changes in other files will result in your PR being rejected

If you're adding a new application:

  • It must be structured in an Ansible role.
  • Ensure that the new application is disabled by default.
  • Add a documentation page to docs/applications/ - use an existing application as an example.
  • Add to the list of Available Applications in README.md
  • Add the frontend port to docs/configuration/application_ports.md, ensuring you've not clashed with an existing application.

Things to bear in mind

  • If you break the build with your PR, it'll need to be fixed before it's merged.
  • Pull requests that unintentionally touch files, or that show files as removed then re-added will be rejected.
  • Don't mess with line endings, or tabs vs. spaces.
  • Please know that your efforts are appreciated, thanks! 👍

Development Environment

  • Development of Ansible-NAS is carried out in Visual Studio Code - you'll get some nice recommended extensions and task setups if you do the same.
  • You'll need a working Python 3 environment, and pre-commit installed - pip install pre-commit.