1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
|
# Acceptance Testing for Chef Client
This folder contains acceptance tests that are required for Chef client
release readiness.
## Getting started
The tests use the _chef-acceptance_ gem as the high level framework.
All the gems needed to run these tests can be installed with Bundler.
### Important Note!
Before running chef-acceptance, you *MUST* do the following on your current session:
```
export APPBUNDLER_ALLOW_RVM=true
```
## Pre-requisites / One time set up
### Set up for local VM (Vagrant)
If you intend to run the acceptance tests on a local VM, the supported solution is to use Vagrant.
Ensure that Vagrant is installed on the machine that tests will run from, along with a
virtualization driver (E.g.: VirtualBox).
Set up the KITCHEN_DRIVER environment variable appropriately (value should be "vagrant"). E.g.:
```
export KITCHEN_DRIVER=vagrant
```
Add this to your shell profile or startup script as needed.
### Set up for cloud VM (EC2)
If you intend to run the acceptance tests on a cloud VM, the supported solution is to use EC2.
The steps you will need to do are:
1. Add your AWS credentials to the machine - e.g., to the ~/.aws/credentials directory.
- The easiest way to do this is to download the aws command line (`brew install awscli` on OS/X) and run `aws configure`.
2. Create or import a SSH key to AWS. (If you already have one, you can skip the import/create)
- In the AWS console, click Key Pairs, then Create Key Pair or Import Key Pair.
3. Copy or move the private key file (USERNAME.pem) to the SSH folder (e.g. `~/.ssh/USERNAME.pem`).
- If you Created a key pair in step 2, download the private key and move it to `~/.ssh`.
- If you Importd a key pair in step 2, just ensure your private key is in `~/.ssh` and has the same name as the key pair (`~/.ssh/USERNAME` or `~/.ssh/USERNAME.pem`).
4. Set AWS_SSH_KEY_ID to the SSH key name.
- This is **optional** if your AWS SSH key name is your local username.
- You may want to set this in your shell `.profile`.
```shell
export AWS_SSH_KEY_ID=name-of-private-key
```
5. Set the private key to only be readable by root
```shell
chmod 0400 ~/.ssh/USERNAME.pem
```
6. Set up the KITCHEN_DRIVER environment variable appropriately (value should be "ec2"). (This is optional, as ec2 is the default.) E.g.:
```shell
export KITCHEN_DRIVER=ec2
```
Add this to your shell profile or startup script as needed.
7. **Connect to Chef VPN**. The instances you create will not have public IPs!
## Setting up and running a test suite
To get started, do a bundle install from the acceptance directory:
```shell
chef/acceptance$ bundle install --binstubs
```
To get some basic info and ensure chef-acceptance can be run, do:
```shell
chef/acceptance$ bin/chef-acceptance info
```
To run a particular test suite, do the following:
```shell
chef/acceptance$ bin/chef-acceptance test TEST_SUITE
```
To restrict which OS's will run, use the KITCHEN_INSTANCES environment variable:
```shell
chef/acceptance$ export KITCHEN_INSTANCES=*-ubuntu-1404
chef/acceptance$ bin/chef-acceptance test cookbook-git
```
If KITCHEN_INSTANCES is not specified, the default instances are default-ubuntu-1404 and default-windows-windows-2012r2. All selected instances will be run in *parallel* if the driver supports it (ec2 does, vagrant doesn't).
## Optional Settings
In addition to the environment settings above, there are a number of
key values that are available to set for changing the way the acceptance
tests are run.
### KITCHEN_CHEF_CHANNEL
Use this setting to specify which channel we will pull the chef build from.
The default is to use the "current" channel, unless the ARTIFACTORY_USERNAME is set
(which normally happens when running under Jenkins), in which case the default is
changed to "unstable".
```shell
export KITCHEN_CHEF_CHANNEL=name-of-channel
```
### KITCHEN_CHEF_VERSION
Use this setting to override the version of the Chef client that is installed. The default is to get the latest version in the desired channel.
```shell
export KITCHEN_CHEF_VERSION=version-of-chef-client
```
### ARTIFACTORY_USERNAME / ARTIFACTORY_PASSWORD
If the desired channel to get the Chef client from is "unstable", the following settings need to be exported:
```shell
export ARTIFACTORY_USERNAME=username
export ARTIFACTORY_PASSWORD=password
```
## Future Work
Currently, there is no simple mechanism for chef-acceptance
to build an Omnibus package of the developers local chef
instance and run acceptance tests on it - the only packages
that can be exercised are ones that come from one of the
pipeline channels (unstable, current or stable).
This is not an issue when adding acceptance tests for pre-existing functionality (as that functionality is presumed
to already be in a build in one of the pipeline channels).
|