1. Propósito
O objetivo é compilar uma lista completa de ferramentas que facilitam a configuração / código do Ansible em três editores populares: VS Code, Atom, JetBrains PyCharm (nesse caso, é mais fácil considerar esse IDE como editor). Por ferramentas, quero dizer: linter, formatadores (falante em inglês!), Destaque de sintaxe, preenchimento automático. A atividade atual no desenvolvimento de ferramentas será considerada e meu julgamento subjetivo-avaliativo sobre o que deveria estar na ferramenta "ideal" será proposto. Eu usei apenas uma das ferramentas revisadas, para que a revisão não seja minha avaliação subjetiva do usuário, apenas o que eu pude encontrar em domínio público.
2. Critérios de avaliação
Há uma lista mais ou menos padrão:
- Classificação no mercado. Cada um dos editores tem seu próprio "mercado" de extensões / plug-ins, onde é possível deixar comentários.
- Número de downloads. As informações são retiradas do mercado.
- O número de estrelas no Github.
- O número de linhas de código. O utilitário cloc foi usado . A saída do programa será exibida parcialmente, para não aumentar o tamanho do artigo. Os idiomas cuja contribuição for inferior a 5% serão removidos.
- Data da última confirmação.
- Funções implementadas retiradas do README.
3. Visão Geral
3.1 Revisões existentes
3.1.1 Pesquisa
Vamos ver quais revisões já estão em russo e inglês, para não repetir a mesma informação duas vezes. A pesquisa foi realizada no Google. De acordo com quais palavras eu procurei no segmento russo:
- Ansible Tools Review → 0 resultados relevantes.
- revisar ide ansible → 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 .