Michael Kutý | f0c0aa7 | 2015-11-19 21:51:21 +0100 | [diff] [blame] | 1 | cookiecutter-salt-formula |
| 2 | ========================= |
Ales Komarek | 7792c70 | 2015-10-19 20:41:02 +0200 | [diff] [blame] | 3 | |
Filip Pytloun | 38c74a3 | 2018-01-18 13:03:41 +0100 | [diff] [blame] | 4 | A cookiecutter template for Salt Formula. |
Ales Komarek | 7792c70 | 2015-10-19 20:41:02 +0200 | [diff] [blame] | 5 | |
Filip Pytloun | 38c74a3 | 2018-01-18 13:03:41 +0100 | [diff] [blame] | 6 | Installation |
Michael Kutý | f0c0aa7 | 2015-11-19 21:51:21 +0100 | [diff] [blame] | 7 | ============ |
Ales Komarek | 7792c70 | 2015-10-19 20:41:02 +0200 | [diff] [blame] | 8 | |
Michael Kutý | f0c0aa7 | 2015-11-19 21:51:21 +0100 | [diff] [blame] | 9 | .. code-block:: bash |
Ales Komarek | 7792c70 | 2015-10-19 20:41:02 +0200 | [diff] [blame] | 10 | |
Petr Michalec | 84d2504 | 2016-11-15 23:42:12 +0100 | [diff] [blame] | 11 | pip install cookiecutter |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 12 | |
Filip Pytloun | 38c74a3 | 2018-01-18 13:03:41 +0100 | [diff] [blame] | 13 | cd cookiecutter |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 14 | |
Filip Pytloun | 38c74a3 | 2018-01-18 13:03:41 +0100 | [diff] [blame] | 15 | cookiecutter salt-formula |
| 16 | |
Oleksandr Shyshko | 50756c3 | 2019-02-07 10:41:12 +0200 | [diff] [blame^] | 17 | Procedure of Data model and Schemas validation. |
| 18 | =============================== |
| 19 | |
| 20 | run_tests.sh script is able to validate data model by schemas and test pillars. |
| 21 | It supports versioned and unversioned schemas and pillars. Schemas and pillars must contains yaml format. |
| 22 | |
| 23 | Unversioned items must be avaible in: |
| 24 | |
| 25 | .. code-block:: text |
| 26 | |
| 27 | {FORMULA_NAME}/{FORMULA_NAME}/schemas/ |
| 28 | {FORMULA_NAME}/tests/pillar/ |
| 29 | |
| 30 | Versioned items must be avaible in: |
| 31 | |
| 32 | .. code-block:: text |
| 33 | |
| 34 | {FORMULA_NAME}/{FORMULA_NAME}/schemas/{version}/ |
| 35 | {FORMULA_NAME}/tests/pillar/{version}/ |
| 36 | |
| 37 | You can run run_tests.sh by following command: |
| 38 | |
| 39 | .. code-block:: shell |
| 40 | |
| 41 | # cd <formula repository> |
| 42 | ./tests/run_tests.sh |
| 43 | |
| 44 | You can run run_tests.sh which inlude schema validation if schemas present by following command: |
| 45 | |
| 46 | .. code-block:: shell |
| 47 | |
| 48 | # cd <formula repository> |
| 49 | ./tests/run_tests.sh model-validate |
| 50 | |
| 51 | Example schemas: |
| 52 | |
| 53 | .. code-block:: yaml |
| 54 | |
| 55 | %YAML 1.1 |
| 56 | --- |
| 57 | "$schema": "http://json-schema.org/draft-06/schema#" |
| 58 | title: {{cookiecutter.service_name}} daemon role |
| 59 | description: | |
| 60 | {{cookiecutter.service_name|capitalize}} daemon, server role |
| 61 | type: object |
| 62 | additionalProperties: false |
| 63 | |
| 64 | required: |
| 65 | - enabled |
| 66 | |
| 67 | properties: |
| 68 | enabled: |
| 69 | description: | |
| 70 | Enables {{cookiecutter.service_name}} daemon service |
| 71 | type: boolean |
| 72 | |
| 73 | Example pillar: |
| 74 | |
| 75 | .. code-block:: yaml |
| 76 | {{cookiecutter.service_name}}: |
| 77 | {{cookiecutter.role_name}}: |
| 78 | enabled: true |
| 79 | |
| 80 | You can read more about it here: |
| 81 | http://json-schema.org/implementations.html |
| 82 | http://github.com/Julian/jsonschema |
Filip Pytloun | 38c74a3 | 2018-01-18 13:03:41 +0100 | [diff] [blame] | 83 | |
| 84 | Init Test Kitchen configuration |
| 85 | =============================== |
| 86 | |
| 87 | Follow the `salt formula testing <https://salt-formulas.readthedocs.io/en/latest/develop/testing-formulas.html>`_ guidelines and |
| 88 | automated CI in the main `documentation <https://salt-formulas.readthedocs.io/en/latest/develop/testing.html>`_. |
| 89 | |
| 90 | To generate ``.kitchen.yml`` for new or existing project: |
| 91 | |
| 92 | - install `envtpl`, renders jinja2 templates with shell environment variables |
| 93 | - install required gems, it depends on drivers configured to be used (docker by default) |
| 94 | |
| 95 | .. code-block:: shell |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 96 | |
| 97 | pip install envtpl |
Filip Pytloun | 38c74a3 | 2018-01-18 13:03:41 +0100 | [diff] [blame] | 98 | gem install kitchen-docker kitchen-salt [kitchen-openstack kitchen-vagrant kitchen-inspec busser-serverspec] |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 99 | |
Filip Pytloun | 38c74a3 | 2018-01-18 13:03:41 +0100 | [diff] [blame] | 100 | Once you create your `tests/pillar` structure (required if you want to auto-populate kitchen yaml with test suites) |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 101 | |
Filip Pytloun | 38c74a3 | 2018-01-18 13:03:41 +0100 | [diff] [blame] | 102 | .. code-block:: shell |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 103 | |
Filip Pytloun | 38c74a3 | 2018-01-18 13:03:41 +0100 | [diff] [blame] | 104 | # cd <formula repository> |
| 105 | ../kitchen-init.sh |
| 106 | |
| 107 | Instantly, to add kitchen configuration into existing repository: |
| 108 | |
| 109 | .. code-block:: shell |
| 110 | |
| 111 | # cd <formula repository> |
Filip Pytloun | 80ff5b0 | 2018-01-18 13:28:43 +0100 | [diff] [blame] | 112 | curl -skL "https://raw.githubusercontent.com/salt-formulas/cookiecutter-salt-formula/master/kitchen-init.sh" | bash -s -- |
Filip Pytloun | 38c74a3 | 2018-01-18 13:03:41 +0100 | [diff] [blame] | 113 | |
Petr Ruzicka | 8ebb5c7 | 2018-01-19 13:32:43 +0100 | [diff] [blame] | 114 | |
| 115 | Docker way |
| 116 | =============================== |
| 117 | |
| 118 | .. code-block:: bash |
| 119 | |
Petr Ruzicka | 9d1d97c | 2018-01-30 16:07:07 +0100 | [diff] [blame] | 120 | MY_NEW_SALT_FORMULA_DIR="watchdog" |
Petr Ruzicka | 8ebb5c7 | 2018-01-19 13:32:43 +0100 | [diff] [blame] | 121 | mkdir $MY_NEW_SALT_FORMULA_DIR |
| 122 | git clone https://github.com/salt-formulas/cookiecutter-salt-formula.git |
| 123 | docker run --rm -it -u $(id -u):$(id -g) --env HOME=/$MY_NEW_SALT_FORMULA_DIR -v $PWD/$MY_NEW_SALT_FORMULA_DIR:/$MY_NEW_SALT_FORMULA_DIR -v $PWD/cookiecutter-salt-formula:/cookiecutter-salt-formula:ro cookiecutter/cookiecutter /cookiecutter-salt-formula --output-dir /$MY_NEW_SALT_FORMULA_DIR |
Petr Ruzicka | 9d1d97c | 2018-01-30 16:07:07 +0100 | [diff] [blame] | 124 | service_name [some_service]: watchdog |
| 125 | role_name [server]: |
| 126 | initial_version [2018.1]: |
| 127 | copyright_year [2018]: |
| 128 | copyright_holder [Your Name et al.]: Mirantis, Inc. |
| 129 | author_name [John Doe]: Petr Ruzicka |
| 130 | author_contact [jdoe@domain.com]: pruzicka@mirantis.com |
| 131 | homepage [https://github.com/salt-formulas]: |
| 132 | debian_version [xenial]: |
| 133 | kitchen_driver [docker]: |
| 134 | kitchen_verifier [inspec]: |
| 135 | kitchen_formula [watchdog]: |
| 136 | kitchen_suites []: server |