Thank you for your interest in contributing to our open-source project, MQ-Ansible.
To ensure that the codebase is always healthy and does not result in deployment issues when forked and used, it is important that you pre-check your additions and updates for any potential code conflicts before uploading your changes to the GitHub Repository.
Therefore, the following steps should be followed to submit your contributions:
- Fork the repository
- Create and run Ansible Test Playbooks
- Commit/Push changes to your fork
- Create a Pull Request
To fork the repository:
- Get started by clicking on "Fork" from the top-right corner of the main repository page.
- Choose a name and description for your fork.
- Select the option "Copy the main branch only", as in most cases, you will only need the default branch to be copied.
- Click on "Create fork".
Once you have forked the repository, you can then clone your fork to your computer locally. In order to do that:
- Click on "Code" (the green button on your forked repository).
- Copy the forked repository URL under HTTPS.
- Type the following on your terminal:
git clone <the_forked_repository_url>
You can set up Git to pull updates from the MQ-Ansible repository into the local clone of your fork when you fork a project in order to propose changes to the MQ-Ansible repository. In order to do that, run the following command:
git remote add upstream https://github.com/ibm-messaging/mq-ansible
To verify the new upstream repository you have specified for your fork, run the following command:
git remote -v
You should see the URL for your fork as origin, and the URL for the MQ-Ansible repository as upstream.
Now, you can work locally and commit to your changes to your fork. This will not impact the main branch.
Before committing changes, ensure that they work with the main codebase.
In the repository, navigate to “~/tests/playbooks”. You will find a group of YAML playbooks that will ensure the deployment is still successful with your proposed changes.
For any additions you contribute with, you will also need to write “assert that” statements to confirm that your changes will not break the codebase or cause any issues. You can go through the Python files in the directory to get an idea of how these Test Playbooks should be structured.
After writing your Test Playbooks, make sure to include them in the “main.py” file to execute all of the Test Playbooks at once. It will look something like this:
subprocess.run(['ansible-playbook', '--inventory', 'inventory.ini', 'playbook_name.yml'])
If the playbook runs successfully and no errors are displayed, then proceed to Step #3.
If you are looking to add all the files you have modified in a particular directory, you can stage them all with the following command:
git add .
If you are looking to recursively add all changes including those in subdirectories, you can type:
git add -A
Alternatively, you can type git add -all for all new files to be staged.
Once you are ready to submit your changes, ensure that you commit them to your fork with a message. The commit message is an important aspect of your code contribution; it helps the maintainers of MQ-Ansible and other contributors to fully understand the change you have made, why you made it, and how significant it is.
You can commit your changes by running:
git commit -m "Brief description of your changes/additions"
To push all your changes to the forked repo:
git push
Merge any changes that were made in the original repository’s main branch:
git merge upstream/main
Before creating a Pull Request, ensure you have read the IBM Contributor License Agreement. By creating a PR, you certify that your contribution:
- is licensed under Apache Licence Version 2.0, The MIT License, or any BSD License.
- does not result in IBM MQ proprietary code being statically or dynamically linked to Ansible runtime.
Once you have carefully read and agreed to the terms mentioned in the CLA, you are ready to make a pull request to the original repository.
Navigate to your forked repository and press the New pull request button. Then, you should add a title and a comment to the appropriate fields and then press the Create pull request button.
The maintainers of the original repository will then review your contribution and decide whether or not to accept your pull request.