-
Do not open a Github issue if the bug concerns {php}IPAM and not the ansible modules.
-
Make sure the bug is not already opened by another user.
-
If you can't find an open issue which reflects your observed problem, go ahead and open a new bug.
-
Provide as much information as mentioned in the bug report template.
-
Open new pull request containing the patch.
-
Provide a clear description which describes the problem and the solution. Link the existing bug to the PR.
-
Make sure there isn't already a feature request.
-
If you can't find an open feature request which describes your feature idea or parts of it, feel free to open a new feature request.
-
Suggest your feature idea within the created feature request.
-
Provide as much description as possible to enable others to have a good understanding of what you are doing.
-
Point out that you want to start to work on the new feature
-
If you want to start to work on a new module we suggest to read How to write new phpipam modules@codeaffen.org.
Fork our repository and create a new branch for your feature. Then start to work on your feature.
To make sure that your feature is working as expected and to make sure that it is not breaking any existing functionality, you should add tests for your new feature. To do so, you
- need to have a working phpipam installation.
- export the following environment variables:
- PHPIPAM_URL - the URL of your phpipam installation (e.g.
https://localhost
) - PHPIPAM_USERNAME - the username to login to phpipam
- PHPIPAM_PASSWORD - the password to login to phpipam
- PHPIPAM_APPID - the appid to login to phpipam
- PHPIPAM_URL - the URL of your phpipam installation (e.g.
- add a new task definition for your new feature in tests/test_playbooks/tasks/
- add a vars definition for your new feature in tests/test_playbooks/vars/
- add a crud playbook for your new feature in tests/test_playbooks/
The playbook should contain the following steps:
- import vars files
vars/server.yml
andvars/<yourtest>.yml
- tasks for
- create a new entity
- create a new entity again to make sure that it will not changed
- update the entity
- delete the entity
- import vars files
- run your test with
ansible-playbook --inventory=tests/inventory/hosts tests/test_playbooks/<yourtest>.yml -vvv
to make sure that your feature is working as expected - run your test again with
make test-<yourtest>
- run all tests with
make test-all
to make sure that your feature does not break any existing functionality
When you are done, push your changes to your fork and create a pull request. Please make sure that you have squashed your changes before you create the pull request. Provide a clear description of your feature and the changes you made.
-
Fork me.
-
Create a documentation branch.
-
Write your documentation changes.
-
Open a PR with your changes.
-
Discuss with the team about your changes.
We will thank you for heeding the contribution guidelines and we encourage you to contribute and join the team.