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 || { |
| 38 | for suite in $SUITES; do |
| 39 | mkdir -p tests/integration/$suite/$VERIFIER |
| 40 | done |
| 41 | mkdir -p tests/integration/helpers/$VERIFIER/ |
| 42 | touch $_/spec_helper.rb |
| 43 | } |
| 44 | |
| 45 | |
| 46 | # .KITCHEN.YML |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 47 | ################################### |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 48 | |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 49 | test -e .kitchen.yml || \ |
Alena Holanova | 58406c1 | 2016-07-19 13:49:41 +0200 | [diff] [blame] | 50 | 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] | 51 | |
Petr Michalec | 221b232 | 2016-07-26 07:33:42 +0200 | [diff] [blame] | 52 | [[ "$driver" != "docker" ]] && { |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 53 | test -e .kitchen.docker.yml || \ |
Petr Michalec | 1eac0ef | 2016-07-26 20:56:55 +0200 | [diff] [blame^] | 54 | 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] | 55 | } |
| 56 | |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 57 | test -e .kitchen.openstack.yml || \ |
Alena Holanova | 58406c1 | 2016-07-19 13:49:41 +0200 | [diff] [blame] | 58 | 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] | 59 | |
| 60 | |
| 61 | |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 62 | # UPDATE README, etc... |
| 63 | ################################### |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 64 | |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 65 | grep -Eoq 'Development and testing' README.* || { |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 66 | |
| 67 | KITCHEN_LIST=$(kitchen list|tail -n+2) |
| 68 | cat >> README.* <<-\EOF |
| 69 | |
| 70 | Development and testing |
| 71 | ======================= |
| 72 | |
| 73 | Development and test workflow with `Test Kitchen <http://kitchen.ci>`_ and |
| 74 | `kitchen-salt <https://github.com/simonmcc/kitchen-salt>`_ provisioner plugin. |
| 75 | |
| 76 | Test Kitchen is a test harness tool to execute your configured code on one or more platforms in isolation. |
| 77 | There is a ``.kitchen.yml`` in main directory that defines *platforms* to be tested and *suites* to execute on them. |
| 78 | |
| 79 | Kitchen CI can spin instances locally or remote, based on used *driver*. |
| 80 | For local development ``.kitchen.yml`` defines a `vagrant <https://github.com/test-kitchen/kitchen-vagrant>`_ or |
| 81 | `docker <https://github.com/test-kitchen/kitchen-docker>`_ driver. |
| 82 | |
| 83 | To use backend drivers or implement your CI follow the section `INTEGRATION.rst#Continuous Integration`__. |
| 84 | |
| 85 | A listing of scenarios to be executed: |
| 86 | |
| 87 | .. code-block:: shell |
| 88 | |
| 89 | $ kitchen list |
| 90 | |
| 91 | Instance Driver Provisioner Verifier Transport Last Action |
| 92 | |
| 93 | EOF |
| 94 | |
| 95 | echo "$KITCHEN_LIST" | sed 's/^/ /' >> README.* |
| 96 | |
| 97 | cat >> README.* <<-\EOF |
| 98 | |
| 99 | The `Busser <https://github.com/test-kitchen/busser>`_ *Verifier* is used to setup and run tests |
| 100 | implementated in `<repo>/test/integration`. It installs the particular driver to tested instance |
| 101 | (`Serverspec <https://github.com/neillturner/kitchen-verifier-serverspec>`_, |
| 102 | `InSpec <https://github.com/chef/kitchen-inspec>`_, Shell, Bats, ...) prior the verification is executed. |
| 103 | |
| 104 | |
| 105 | Usage: |
| 106 | |
| 107 | .. code-block:: shell |
| 108 | |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 109 | # list instances and status |
| 110 | kitchen list |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 111 | |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 112 | # manually execute integration tests |
| 113 | kitchen [test || [create|converge|verify|exec|login|destroy|...]] [instance] -t tests/integration |
| 114 | |
| 115 | # use with provided Makefile (ie: within CI pipeline) |
| 116 | make kitchen |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 117 | |
| 118 | EOF |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 119 | } |
Petr Michalec | d1ff7bd | 2016-07-14 10:43:13 +0200 | [diff] [blame] | 120 | |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 121 | test -e INTEGRATION.rst || \ |
Alena Holanova | 5364af3 | 2016-07-19 13:42:55 +0200 | [diff] [blame] | 122 | curl -skL "${SOURCE_REPO_URI}/INTEGRATION.rst" -o INTEGRATION.rst |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 123 | |
| 124 | |
| 125 | # ADD CHANGES TO GIT |
| 126 | ################################### |
| 127 | |
| 128 | # update Makefile, but do not auto-add to git |
Alena Holanova | 5364af3 | 2016-07-19 13:42:55 +0200 | [diff] [blame] | 129 | curl -skL "${SOURCE_REPO_URI}/Makefile" -o Makefile |
Petr Michalec | 993e3fa | 2016-07-15 15:56:34 +0200 | [diff] [blame] | 130 | |
| 131 | git add \ |
| 132 | .gitignore \ |
| 133 | .kitchen*yml \ |
| 134 | INTEGRATION.rst \ |
| 135 | README.rst |
| 136 | |
Petr Michalec | a347c80 | 2016-07-20 21:49:52 +0200 | [diff] [blame] | 137 | git status |