1. PropĂłsito
El objetivo es compilar una lista completa de herramientas que faciliten la escritura de configuraciĂłn / cĂłdigo Ansible en tres editores populares: VS Code, Atom, JetBrains PyCharm (en este caso, es más fácil considerar este IDE como editor). Por herramientas quiero decir: linter, formateadores (¡hablante inglĂ©s!), Resaltado de sintaxis, autocompletado. Se considerará la actividad actual en el desarrollo de herramientas y se propondrá mi juicio subjetivo-evaluativo de lo que deberĂa estar en la herramienta "ideal". UtilicĂ© solo una de las herramientas revisadas, por lo que la revisiĂłn no será mi evaluaciĂłn subjetiva por parte del usuario, solo lo que pude encontrar en el dominio pĂşblico.
2. Criterios de evaluaciĂłn
Hay una lista más o menos estándar:
- CalificaciĂłn en el mercado. Cada uno de los editores tiene su propio "mercado" para extensiones / complementos, donde es posible dejar comentarios.
- NĂşmero de descargas. La informaciĂłn se toma del mercado.
- El nĂşmero de estrellas en Github.
- El nĂşmero de lĂneas de cĂłdigo. Se utilizĂł la utilidad cloc . El resultado del programa se mostrará parcialmente, para no inflar el tamaño del artĂculo. Se eliminarán los idiomas cuya contribuciĂłn sea inferior al 5%.
- Fecha de la Ăşltima confirmaciĂłn.
- Funciones implementadas tomadas de README.
3. DescripciĂłn general
3.1 Revisiones existentes
3.1.1 BĂşsqueda
Veamos qué reseñas ya están en ruso y en inglés, para no repetir la misma información dos veces. La búsqueda se realizó en Google. Según las palabras que busqué en el segmento ruso:
- Revisión de Herramientas Ansibles → 0 resultados relevantes.
- revisar ansible ide → 0 resultados relevantes.
- 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 .