tree: 92f83a802265389120db26c99090324fde1d880b [path history] [tgz]
  1. clients/
  2. openstack/
  3. tools/
  4. README.md
acceptance/README.md

Gophercloud Acceptance tests

The purpose of these acceptance tests is to validate that SDK features meet the requirements of a contract - to consumers, other parts of the library, and to a remote API.

Note: Because every test will be run against a real API endpoint, you may incur bandwidth and service charges for all the resource usage. These tests should remove their remote products automatically. However, there may be certain cases where this does not happen; always double-check to make sure you have no stragglers left behind.

Step 1. Set environment variables

A lot of tests rely on environment variables for configuration - so you will need to set them before running the suite. If you're testing against pure OpenStack APIs, you can download a file that contains all of these variables for you: just visit the project/access_and_security page in your control panel and click the "Download OpenStack RC File" button at the top right. For all other providers, you will need to set them manually.

Authentication

NameDescription
OS_USERNAMEYour API username
OS_PASSWORDYour API password
OS_AUTH_URLThe identity URL you need to authenticate
OS_TENANT_NAMEYour API tenant name
OS_TENANT_IDYour API tenant ID

General

NameDescription
OS_REGION_NAMEThe region you want your resources to reside in

Compute

NameDescription
OS_IMAGE_IDThe ID of the image your want your server to be based on
OS_FLAVOR_IDThe ID of the flavor you want your server to be based on
OS_FLAVOR_ID_RESIZEThe ID of the flavor you want your server to be resized to
OS_POOL_NAMEThe Pool from where to obtain Floating IPs
OS_NETWORK_NAMEThe network to launch instances on

Shared file systems

NameDescription
OS_SHARE_NETWORK_IDThe share network ID to use when creating shares

2. Run the test suite

From the root directory, run:

./script/acceptancetest

Alternatively, add the following to your .bashrc:

gophercloudtest() {
  if [[ -n $1 ]] && [[ -n $2 ]]; then
    pushd  ~/go/src/github.com/gophercloud/gophercloud
    go test -v -tags "fixtures acceptance" -run "$1" github.com/gophercloud/gophercloud/acceptance/openstack/$2 | tee ~/gophercloud.log
    popd
fi
}

Then run either groups or individual tests by doing:

$ gophercloudtest TestFlavorsList compute/v2
$ gophercloudtest TestFlavors compute/v2
$ gophercloudtest Test compute/v2

3. Notes

Compute Tests

  • In order to run the TestBootFromVolumeMultiEphemeral test, a flavor with ephemeral disk space must be used.
  • The TestDefSecRules tests require a compatible network driver and admin privileges.