summaryrefslogtreecommitdiffstats
path: root/ansible_collections/cisco/meraki/contributing.md
diff options
context:
space:
mode:
Diffstat (limited to 'ansible_collections/cisco/meraki/contributing.md')
-rw-r--r--ansible_collections/cisco/meraki/contributing.md80
1 files changed, 80 insertions, 0 deletions
diff --git a/ansible_collections/cisco/meraki/contributing.md b/ansible_collections/cisco/meraki/contributing.md
new file mode 100644
index 00000000..207fed6f
--- /dev/null
+++ b/ansible_collections/cisco/meraki/contributing.md
@@ -0,0 +1,80 @@
+# Contributing
+
+Contributions are welcome, and they are greatly appreciated! This is a one man show
+so help is fantastic!
+
+You can contribute in many ways:
+
+## Types of Contributions
+
+### Report Bugs
+
+Report bugs at https://github.com/CiscoDevNet/ansible-meraki/issues.
+
+### Fix Bugs or Complete Enhancements
+
+Look through the GitHub issues for bugs. Anything without a pull request associated is
+open.
+
+### Submit Feedback
+
+Request new features at https://github.com/CiscoDevNet/ansible-meraki/issues
+
+If you are proposing a feature:
+
+- Explain in detail how it would work.
+- Keep the scope as narrow as possible, to make it easier to implement.
+- Remember that this is a volunteer-driven project, and that contributions are welcome :)
+
+## Get Started!
+
+Ready to contribute some code? Here's how to set up `cisco.meraki` for local development.
+
+1. Install Python 3.8 or higher, along with Ansible
+
+ Newer versions of Ansible require 3.8 so please target those versions.
+
+2. Fork the `cisco.meraki` repo on GitHub
+
+3. Clone your fork locally, using a special directory name so that Ansible understands it as a collection:
+
+```
+$ mkdir -p ansible_collections/meraki
+$ git clone https://github.com/your-username/ansible-meraki.git ansible_collections/cisco/meraki/
+```
+
+4. Create a branch for local development
+
+```
+$ cd ansible_collections/cisco/meraki
+$ git checkout -b name-of-your-bugfix-or-feature
+```
+
+5. Make your changes in the new branch
+
+ You can test any changes by developing integration tests. These are in the `tests/integration/targets/module_name` directory.
+
+6. Setup integration test Meraki variables template
+
+ If integration tests need to be run. Copy the `tests/integration/inventory.networking.template` file to `tests/integration/inventory.networking` and fill out the values. This should never be committed into git.
+
+7. Execute integration tests
+
+```
+$ ansible-test network-integration --allow-unsupported module_name
+```
+
+8. When you're done making changes, check that your changes pass `ansible-test sanity`:
+
+```
+$ ansible-test sanity --local
+```
+9. Commit your changes and push your branch to GitHub:
+
+```
+$ git add -A
+$ git commit -m "Your detailed description of your changes."
+$ git push origin name-of-your-bugfix-or-feature
+```
+
+10. Submit a pull request through the GitHub website.