2019-01-03 11:35:49 +00:00
# Contributing
Contributing to Ansible-NAS is easy! Add your functionality, then raise a pull request on GitHub. A few things to bear in mind:
2022-08-24 08:27:24 +00:00
* **Restrict pull requests to one piece of functionality or bugfix at a time.**
2019-01-03 11:35:49 +00:00
* 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)
2022-08-20 18:05:54 +00:00
* 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
2019-01-03 11:35:49 +00:00
If you're adding a new application:
2022-08-20 18:05:54 +00:00
* It must be structured in an [Ansible role ](https://docs.ansible.com/ansible/latest/user_guide/playbooks_reuse_roles.html ).
2019-01-03 11:35:49 +00:00
* Ensure that the new application is disabled by default.
* Add a documentation page to `docs/applications/` - use an existing application as an example.
2020-05-06 07:36:14 +00:00
* Add to the list of Available Applications in `README.md`
2020-01-05 09:14:42 +00:00
* Add the frontend port to `docs/configuration/application_ports.md` , ensuring you've not clashed with an existing application.
## Things to bear in mind
2022-08-20 18:05:54 +00:00
* If you break the build with your PR, it'll need to be fixed before it's merged.
2020-01-05 09:14:42 +00:00
* Pull requests that unintentionally touch files, or that show files as removed then re-added will be rejected.
2022-07-25 20:18:57 +00:00
* Don't mess with line endings, or tabs vs. spaces.
2020-01-05 09:14:42 +00:00
* Please know that your efforts are appreciated, thanks! :+1:
2022-07-25 20:18:57 +00:00
## Development Environment
2020-01-05 09:14:42 +00:00
* Development of Ansible-NAS is carried out in [Visual Studio Code ](https://code.visualstudio.com/ ) - you'll get some nice
2020-04-25 21:27:15 +00:00
recommended extensions and task setups if you do the same.
2022-08-24 08:27:24 +00:00
* You'll need a working Python 3 environment, and [pre-commit ](https://pre-commit.com ) installed - `pip install pre-commit` .