Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 1 | #!/bin/bash |
| 2 | |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 3 | # Script to add Kitchen configuration to existing formulas. |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 4 | # usage: |
Alena Holanova | 5364af3 | 2016-07-19 13:42:55 +0200 | [diff] [blame] | 5 | # curl -skL "https://git.tcpcloud.eu/cookiecutter-templates/cookiecutter-salt-formula/raw/master/kitchen-init.sh" | bash -s -- |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 6 | |
| 7 | |
| 8 | # CONFIG |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 9 | ################################### |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 10 | |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 11 | export driver=${driver:-vagrant} # vagrant, dokken, openstack, ... |
| 12 | export verifier=${verifier:-inspec} # serverspec, pester |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 13 | |
Petr Michalec | a347c80 | 2016-07-20 21:49:52 +0200 | [diff] [blame] | 14 | export formula=${formula:-$(awk -F: '/^name/{gsub(/[\ \"]/,"");print $2}' metadata.yml)} |
Petr Michalec | 60b1b21 | 2016-07-26 07:37:39 +0200 | [diff] [blame] | 15 | export suites=$(ls tests/pillar|xargs -I{} basename {} .sls) |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 16 | |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 17 | export SOURCE_REPO_URI="https://git.tcpcloud.eu/cookiecutter-templates/cookiecutter-salt-formula/raw/master/%7B%7Bcookiecutter.project_name%7D%7D" |
| 18 | |
Petr Michalec | 1eac0ef | 2016-07-26 20:56:55 +0200 | [diff] [blame] | 19 | which envtpl &> /dev/null || { |
| 20 | echo "ERROR: missing prerequisite, install 'envtpl' first : pip install envtpl" |
| 21 | exit 1 |
| 22 | } |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 23 | |
| 24 | # INIT |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 25 | ################################### |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 26 | test ! -e .kitchen.yml || { |
Petr Michalec | 1eac0ef | 2016-07-26 20:56:55 +0200 | [diff] [blame] | 27 | kitchen init -D kitchen-vagrant -P kitchen-salt --no-create-gemfile |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 28 | echo .kitchen >> .gitignore |
| 29 | rm -rf test |
| 30 | rm -f .kitchen.yml |
| 31 | rm -f chefignore |
| 32 | } |
| 33 | |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 34 | |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 35 | # CONFIGURE & SCAFFOLD TEST DIR |
| 36 | ################################### |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 37 | test -d tests/integration || { |
Petr Michalec | 59566fb | 2016-07-26 22:39:50 +0200 | [diff] [blame^] | 38 | for suite in $(echo $suites|xargs); do |
Petr Michalec | 3e89e1b | 2016-07-26 21:43:17 +0200 | [diff] [blame] | 39 | mkdir -p tests/integration/$suite/$verifier |
| 40 | touch tests/integration/$suite/$verifier/default_spec.rb |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 41 | done |
Petr Michalec | 3e89e1b | 2016-07-26 21:43:17 +0200 | [diff] [blame] | 42 | mkdir -p tests/integration/helpers/$verifier/ |
Petr Michalec | 59566fb | 2016-07-26 22:39:50 +0200 | [diff] [blame^] | 43 | touch tests/integration/helpers/$verifier/spec_helper.rb |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 44 | } |
| 45 | |
| 46 | |
| 47 | # .KITCHEN.YML |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 48 | ################################### |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 49 | |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 50 | test -e .kitchen.yml || \ |
Alena Holanova | 58406c1 | 2016-07-19 13:49:41 +0200 | [diff] [blame] | 51 | envtpl < <(curl -skL "${SOURCE_REPO_URI}/.kitchen.yml" -- | sed 's/cookiecutter\.kitchen_//g') > .kitchen.yml |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 52 | |
Petr Michalec | 221b232 | 2016-07-26 07:33:42 +0200 | [diff] [blame] | 53 | [[ "$driver" != "docker" ]] && { |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 54 | test -e .kitchen.docker.yml || \ |
Petr Michalec | 1eac0ef | 2016-07-26 20:56:55 +0200 | [diff] [blame] | 55 | envtpl < <(curl -skL "${SOURCE_REPO_URI}/.kitchen.docker.yml" -- | sed 's/cookiecutter\.kitchen_//g' ) > .kitchen.docker.yml |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 56 | } |
| 57 | |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 58 | test -e .kitchen.openstack.yml || \ |
Alena Holanova | 58406c1 | 2016-07-19 13:49:41 +0200 | [diff] [blame] | 59 | envtpl < <(curl -skL "${SOURCE_REPO_URI}/.kitchen.openstack.yml" -- | sed 's/cookiecutter\.kitchen_//g') > .kitchen.openstack.yml |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 60 | |
| 61 | |
| 62 | |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 63 | # UPDATE README, etc... |
| 64 | ################################### |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 65 | |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 66 | grep -Eoq 'Development and testing' README.* || { |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 67 | |
| 68 | KITCHEN_LIST=$(kitchen list|tail -n+2) |
| 69 | cat >> README.* <<-\EOF |
| 70 | |
| 71 | Development and testing |
| 72 | ======================= |
| 73 | |
| 74 | Development and test workflow with `Test Kitchen <http://kitchen.ci>`_ and |
| 75 | `kitchen-salt <https://github.com/simonmcc/kitchen-salt>`_ provisioner plugin. |
| 76 | |
| 77 | Test Kitchen is a test harness tool to execute your configured code on one or more platforms in isolation. |
| 78 | There is a ``.kitchen.yml`` in main directory that defines *platforms* to be tested and *suites* to execute on them. |
| 79 | |
| 80 | Kitchen CI can spin instances locally or remote, based on used *driver*. |
| 81 | For local development ``.kitchen.yml`` defines a `vagrant <https://github.com/test-kitchen/kitchen-vagrant>`_ or |
| 82 | `docker <https://github.com/test-kitchen/kitchen-docker>`_ driver. |
| 83 | |
| 84 | To use backend drivers or implement your CI follow the section `INTEGRATION.rst#Continuous Integration`__. |
| 85 | |
| 86 | A listing of scenarios to be executed: |
| 87 | |
| 88 | .. code-block:: shell |
| 89 | |
| 90 | $ kitchen list |
| 91 | |
| 92 | Instance Driver Provisioner Verifier Transport Last Action |
| 93 | |
| 94 | EOF |
| 95 | |
| 96 | echo "$KITCHEN_LIST" | sed 's/^/ /' >> README.* |
| 97 | |
| 98 | cat >> README.* <<-\EOF |
| 99 | |
| 100 | The `Busser <https://github.com/test-kitchen/busser>`_ *Verifier* is used to setup and run tests |
| 101 | implementated in `<repo>/test/integration`. It installs the particular driver to tested instance |
| 102 | (`Serverspec <https://github.com/neillturner/kitchen-verifier-serverspec>`_, |
| 103 | `InSpec <https://github.com/chef/kitchen-inspec>`_, Shell, Bats, ...) prior the verification is executed. |
| 104 | |
| 105 | |
| 106 | Usage: |
| 107 | |
| 108 | .. code-block:: shell |
| 109 | |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 110 | # list instances and status |
| 111 | kitchen list |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 112 | |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 113 | # manually execute integration tests |
| 114 | kitchen [test || [create|converge|verify|exec|login|destroy|...]] [instance] -t tests/integration |
| 115 | |
| 116 | # use with provided Makefile (ie: within CI pipeline) |
| 117 | make kitchen |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 118 | |
| 119 | EOF |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 120 | } |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 121 | |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 122 | test -e INTEGRATION.rst || \ |
Alena Holanova | 5364af3 | 2016-07-19 13:42:55 +0200 | [diff] [blame] | 123 | curl -skL "${SOURCE_REPO_URI}/INTEGRATION.rst" -o INTEGRATION.rst |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 124 | |
| 125 | |
| 126 | # ADD CHANGES TO GIT |
| 127 | ################################### |
| 128 | |
| 129 | # update Makefile, but do not auto-add to git |
Alena Holanova | 5364af3 | 2016-07-19 13:42:55 +0200 | [diff] [blame] | 130 | curl -skL "${SOURCE_REPO_URI}/Makefile" -o Makefile |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 131 | |
| 132 | git add \ |
| 133 | .gitignore \ |
| 134 | .kitchen*yml \ |
| 135 | INTEGRATION.rst \ |
| 136 | README.rst |
| 137 | |
Petr Michalec | a347c80 | 2016-07-20 21:49:52 +0200 | [diff] [blame] | 138 | git status |