1. Objectif
L'objectif est de compiler une liste complĂšte d'outils qui facilitent l'Ă©criture de la configuration / du code Ansible dans trois Ă©diteurs populaires: VS Code, Atom, JetBrains PyCharm (dans ce cas, il est plus facile de considĂ©rer cet IDE comme un Ă©diteur). Par outils, je veux dire: linter, formateurs (haut-parleur anglais!), Mise en Ă©vidence de la syntaxe, auto-complĂ©tion. L'activitĂ© actuelle dans le dĂ©veloppement d'outils sera considĂ©rĂ©e et mon jugement subjectif-Ă©valuatif sur ce qui devrait ĂȘtre dans l'outil "idĂ©al" sera proposĂ©. Je n'ai utilisĂ© qu'un seul des outils examinĂ©s, donc l'examen ne sera pas mon Ă©valuation subjective par l'utilisateur, seulement ce que j'ai pu trouver dans le domaine public.
2. CritÚres d'évaluation
Il existe une liste plus ou moins standard:
- Ăvaluation sur le marchĂ©. Chacun des Ă©diteurs a son propre "marchĂ©" pour les extensions / plugins, oĂč il est possible de laisser des commentaires.
- Nombre de téléchargements. Les informations proviennent du marché.
- Le nombre d'étoiles sur Github.
- Le nombre de lignes de code. L'utilitaire cloc a été utilisé . La sortie du programme sera partiellement affichée, afin de ne pas gonfler la taille de l'article. Les langues dont la contribution est inférieure à 5% seront supprimées.
- Date du dernier commit.
- Fonctions implémentées issues de README.
3. Présentation
3.1 Examens existants
3.1.1 Recherche
Voyons quels sont les avis dĂ©jĂ en russe et en anglais, afin de ne pas rĂ©pĂ©ter deux fois la mĂȘme information. La recherche a Ă©tĂ© effectuĂ©e dans Google. Selon quels mots j'ai recherchĂ© dans le segment russe:
- Examen des outils Ansible â 0 rĂ©sultats pertinents.
- revoir ansible ide â 0 rĂ©sultats pertinents.
- ansible â 0 .
Ansible , - .
:
- ansible tools â 1 .
- review ansible ide â 1 .
.
Ansible. 95% Ansible, YAML Jinja2.
. , Ansible. , .
3.2 VS Code
3.2.1
VS Code, . "ansible", (13 ), .
:
- â 3.4 5 (12 ).
- â 224 950.
- Github â 54.
- â 21.08.2019. 2 .
README:
- Auto completion. Auto completion Ansible directives, modules and plugins from Ansible doc, Auto completion for variables. Disable auto completion by setting ansible.autocompletion to false.
- Code snippets. Press Ctrl + Space, Ansible playbook code snippets will show up.
- Syntax highlighting. Enable syntax highlighting by setting files.associations to ansible in settings.json.
- Yaml validation. Yaml validation by leverage Yaml language server.
- Code navigation by Symbols, press Ctrl + Shift + O.
- Hover over module names, to show module documentation. Disable hovering over by setting ansible.hover to false.
- Run playbook from Docker.
- Run playbook from local Ansible installation.
- Run playbook from Cloud Shell.
- Run playbook remotely via ssh.
- Auto File Copy to remote host on saving.
cloc:
63 text files.
63 unique files.
6 files ignored.
-------------------------------------------------------------------
Language files blank comment code
-------------------------------------------------------------------
JSON 14 0 0 451226
TypeScript 33 669 80 2943
Markdown 6 79 0 249
-------------------------------------------------------------------
SUM: 58 767 81 454543
-------------------------------------------------------------------
, PR issue , .
:
- â 4.2 5 (6 ).
- â 92 212.
- Github â 10.
- â 15.01.2018.
( , README:
- Jinja language
- Jinja expressions for ansible conditions (when, changed_when, failed_when, check_mode)
- Some YAML block scalar
, 6 .
cloc:
10 text files.
10 unique files.
4 files ignored.
-------------------------------------------------------------------
Language files blank comment code
-------------------------------------------------------------------
YAML 1 16 6 132
JSON 3 0 0 95
Markdown 3 13 0 60
-------------------------------------------------------------------
SUM: 7 29 6 287
-------------------------------------------------------------------
:
- â 5 5 (2 ).
- â 62 185.
- Github â 2.
- â 20.11.2017.
README . Atom, .
cloc:
17 text files.
17 unique files.
5 files ignored.
-------------------------------------------------------------------
Language files blank comment code
-------------------------------------------------------------------
JSON 7 7 0 148305
TypeScript 4 44 5 199
Python 2 28 2 132
Markdown 1 2 0 3
-------------------------------------------------------------------
SUM: 14 81 7 148639
-------------------------------------------------------------------
3.3 Atom
3.3.1
. "ansible" , . , 11 . , VS Code.
:
- ( Github) â 51.
- â 60 823.
- Github â 18.
- â 22.04.2020. .
README:
- Linter-Ansible-Linting aims to provide functional and robust Ansible-Lint linting functionality within Atom.
cloc:
20 text files.
20 unique files.
3 files ignored.
-------------------------------------------------------------------
Language files blank comment code
-------------------------------------------------------------------
JavaScript 3 46 28 565
Markdown 3 23 0 96
YAML 11 28 14 90
JSON 1 0 0 49
-------------------------------------------------------------------
SUM: 18 97 42 800
-------------------------------------------------------------------
:
- ( Github) â 25.
- â 24 819.
- Github â 4.
- â 22.04.2020. .
README:
- Linter-Ansible-Syntax aims to provide functional and robust Ansible syntax check linting functionality within Atom.
cloc:
19 text files.
19 unique files.
5 files ignored.
-------------------------------------------------------------------
Language files blank comment code
-------------------------------------------------------------------
JavaScript 3 34 18 315
Markdown 3 17 0 64
YAML 8 12 10 56
JSON 1 0 0 48
-------------------------------------------------------------------
SUM: 15 63 28 483
-------------------------------------------------------------------
3.4 PyCharm
IDE JetBrains, . "ansible" 1 .
:
- â 3.7 5.0 (9 ).
- â 464 115.
- Github â 191.
- â 01.06.2017.
README:
- Goto role (Ctrl-N)
- Goto task (Ctrl-N)
- Goto var/property (Ctrl-Alt-Shift-N)
- Role/Jinja var reference on Ctrl-Click
- Module doc lookup
- lexer, parser (internal)
- syntax highlighting
- comment/uncomment
- bracket / parenthesis matching
- role completion
cloc:
147 text files.
146 unique files.
42 files ignored.
-------------------------------------------------------------------
Language files blank comment code
-------------------------------------------------------------------
YAML 28 1045 232 7276
Java 68 686 464 3344
Bourne Shell 1 21 22 129
-------------------------------------------------------------------
SUM: 107 1806 726 10970
-------------------------------------------------------------------
YAML , 1 fork Ansible , cloc. , Java.
4.
VS Code PyCharm . ansible-lint, ansible-playbook --syntax-check, yamllint. YAML, Ansible, . , ( Docker ), ( , YAML, ).
CI, . deprecation warnings . Atom Ansible.
, Ansible Atom. , , .
. 2-3 , Ansible 8 , . , , Ansible .