-
Notifications
You must be signed in to change notification settings - Fork 31
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'building-collection' of github.com:priyamsahoo/ansible-…
…dev-tools into building-collection
- Loading branch information
Showing
6 changed files
with
89 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,86 @@ | ||
# Building Ansible Collection using with Unified Tooling | ||
|
||
This guide illustrates a comprehensive Ansible development workflow that showcases the integration of various tools within the Ansible ecosystem to create an Ansible collection. The tools featured in this workflow include: | ||
|
||
- [ansible-creator](https://github.com/ansible/ansible-creator) | ||
- [ansible-development-environment (pip4a)](https://github.com/ansible/ansible-development-environment) | ||
- [ansible-lint](https://github.com/ansible/ansible-lint) | ||
- [ansible-navigator](https://github.com/ansible/ansible-navigator) | ||
- [VS Code Ansible extension](https://github.com/ansible/vscode-ansible) | ||
|
||
## Scaffolding collection using ansible-creator | ||
|
||
- Open VS Code and click the Ansible icon in the activity bar to access Ansible Creator section. Click on "Get Started" under that section to open the menu page of Ansible Creator in VS Code. | ||
|
||
- Check system requirements and install ansible-creator if needed. Ensure all requirements in the `system requirements` box have green ticks. | ||
|
||
![ansible-creator-menu](../media/ansible-creator-menu-installed.png) | ||
|
||
- Click "Initialize a collection" to open the "Init" interface. Fill the form with the collection name, initialization path, verbosity, and logging options. Click "Create" for scaffolding the collection in the desired location. You have the open to review the logs or open the log file in VS Code editor for details. | ||
|
||
- Click on `Open collection` button to add collection folder to the workspace. | ||
|
||
![scaffold-collection](../media/create-collection.png) | ||
|
||
NOTE: For a more detailed explanation about using Ansible Creator in the VS Code Ansible Extension, refer to [doc: ansible-creator]. | ||
|
||
## Installing collection using ansible-development-environment | ||
|
||
- With the initial collection structure in place, use 'ansible-development-environment' to install the newly created collection in editable mode, similar to Python modules. | ||
|
||
- Navigate to the collection directory and run: | ||
|
||
```console | ||
$ ansible-development-environment install -e . | ||
``` | ||
|
||
- This installation method adds the collection in the system paths so that ansible knows about it. Additionally, it enhances the development process by allowing on-the-go changes to the module code. | ||
|
||
- You can check if the collection is installed or not by using ansible-galaxy command. In the terminal, running the following command should show the name of the newly created collection: | ||
|
||
```console | ||
$ ansible-galaxy collection list | ||
``` | ||
|
||
## Add python code to bring the collection to life | ||
|
||
- Navigate to the collection directory and navigate to plugins/modules/. Add create a [module-name].py file and documentation, examples and logic to the module. | ||
|
||
- Due to its installation method using pip4a, you have the ability to change module code dynamically and observe the effects during playbook execution. | ||
|
||
NOTE: for details regarding the module development, refer to the [ansible module development docs](https://docs.ansible.com/ansible/latest/dev_guide/developing_modules_general.html). | ||
|
||
## Using ansible-lint to check module syntax in the playbook | ||
|
||
- Leverage vscode-ansible extension and ansible-lint to gain insights into the collection without running the playbook | ||
|
||
- Create a simple playbook under the 'playbooks' directory. | ||
|
||
- Once you have completed writing the playbook that uses the newly collection module, saving the file will automatically run ansible-lint on the playbook. | ||
|
||
- With its integration in the extension, ansible-lint can detect mistakes, such as incorrect option values and missing required options, along with other rules for ansible best practices by providing feedback in the editor (red and yellow squiggly lines) and it the `Problems` tab in the vscode. | ||
|
||
![ansible-lint](../media/ansible-lint.gif) | ||
|
||
## Using ansible-navigator to tun the playbook with the collection module | ||
|
||
- The ansible extension in VS Code has the ability to detect the playbook files and provide several | ||
ansible related options for it. One such option is to run the playbook without having to leave the editor. | ||
|
||
- Right-click on the opened playbook in the editor and choose `Run Ansible Playbook via`. This provides options to run the playbook via ansible-navigator or ansible-playbook. | ||
|
||
- Select `Run playbook via ansible-navigator run` to execute the playbook in the terminal within VS Code. | ||
|
||
![ansible-navigator](../media/ansible-navigator-run.png) | ||
|
||
## Adapting to changes in the module code | ||
|
||
- This is a good time to experiment with the power of `installing collection in editable mode`. Make changes in the module code by adding new functionality and/or modifying the existing the functionalities. | ||
|
||
- Repeat the previous two steps to observe how the extension and ansible-lint seamlessly adapt to the changes. | ||
|
||
- The Ansible extension along with ansible-lint continues to provide linting functionalities for the updated module code and running the playbook using ansible-navigator incorporates the new module code seamlessly. | ||
|
||
This unified development suite, incorporating ansible-creator, pip4a, ansible-lint, ansible-navigator, and vscode-ansible extension, enables content developers with an enhanced and efficient method for their Ansible development workflow. | ||
|
||
The integration of these tools streamlines the development process, offering a cohesive experience for building Ansible Collections. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters