Tests that will NOT be introduced here are ones which could be tested at the component level.
NOTE: Because we want to parallelize execution, tests should be written in such a way as to be runnable individually. This means that tests should not depend on state in other tests, and should not modify the CF state in such a way as to impact other tests.
Set up your golang development environment, per golang.org.
See cf CLI for instructions on installing the go version of cf
. The latest CF CLI version are recommended.
Make sure that the go version of cf
is accessible in your $PATH
.
You will also need a running Cloud Foundry deployment with the AutoScaler installed to run these acceptance tests against.
You must set an environment variable $CONFIG
which points to a JSON file that contains several pieces of data that will be used to configure the acceptance tests, e.g. telling the tests how to target your running Cloud Foundry deployment.
The following can be pasted into a terminal and will set up a sufficient $CONFIG
to run the core test suites against a BOSH-Lite deployment of CF.
cat > integration_config.json <<EOF
{
"api": "api.bosh-lite.com",
"admin_user": "admin",
"admin_password": "admin",
"apps_domain": "bosh-lite.com",
"skip_ssl_validation": true,
"use_http": true,
"service_name": "autoscaler",
"service_plan": "autoscaler-free-plan",
"aggregate_interval": 120,
"autoscaler_api": "autoscaler.bosh-lite.com",
"service_offering_enabled": true
}
EOF
export CONFIG=$PWD/integration_config.json
The full set of config parameters is explained below:
-
service_name
(required): The name of the registered auto-scaler service, usecf marketplace
to determine the name. -
service_plan
(required): The plan name of the registered auto-scaler service, usecf marketplace
to determine the plan. -
aggregate_interval
(required): How frequently metrics are aggregated. This value must match the value configured in your deployment. -
autoscaler_api
(required) AutoScaler API endpoint -
api
(required): Cloud Controller API endpoint. -
admin_user
(required): Name of a user in your CF instance with admin credentials. This admin user must have thedoppler.firehose
scope if running thelogging
firehose tests. -
admin_password
(required): Password of the admin user above. -
apps_domain
(required): A shared domain that tests can use to create subdomains that will route to applications also craeted in the tests. -
service_offering_enabled
(optional): Set to true if auto-scaler is offered as a cloudfoundry service. The value should be the consistent with the one in app-autoscaler deployment. Default is true. -
skip_ssl_validation
(optional): Set to true if using an invalid (e.g. self-signed) cert for traffic routed to your CF instance; this is generally always true for BOSH-Lite deployments of CF. -
use_existing_user
(optional): The admin user configured above will normally be used to create a temporary user (with lesser permissions) to perform actions (such as push applications) during tests, and then delete said user after the tests have run; set this totrue
if you want to use an existing user, configured via the following properties. -
keep_user_at_suite_end
(optional): If using an existing user (see above), set this totrue
unless you are okay having your existing user being deleted at the end. You can also set this totrue
when not using an existing user if you want to leave the temporary user around for debugging purposes after the test teardown. -
existing_user
(optional): Name of the existing user to use. -
existing_user_password
(optional): Password for the existing user to use. -
use_existing_organization
(optional): The admin user configured above will normally create a temporary organization during tests, and then delete the organization after the tests have run; set this totrue
if you want to use an existing organization, configured via the following properties. -
existing_organization
(optional): Name of the existing organization to use. -
use_existing_space
(optional): The admin user configured above will normally create a temporary space during tests, and then delete the space after the tests have run; set this totrue
if you want to use an existing space, configured via the following properties. -
existing_space
(optional): Name of the existing space to use. -
add_existing_user_to_existing_space
(optional): The admin user configured above will normally set the user to beadmin/develop/auditor
of the new-created/existing space. Set this tofalse
if you are using an existing user and space, and the existing user is already the space admin/develop/auditor of the existing space. (This option is useful when the set-space-role command is restricted in some of the cf environments.) -
artifacts_directory
(optional): If set,cf
CLI trace output from test runs will be captured in files and placed in this directory. See below for more. -
default_timeout
(optional): Default time (in seconds) to wait for polling assertions that wait for asynchronous results. -
cf_push_timeout
(optional): Default time (in seconds) to wait forcf push
commands to succeed. -
long_curl_timeout
(optional): Default time (in seconds) to wait for assertions thatcurl
slow endpoints of test applications. -
test_password
(optional): Used to set the password for the test user. This may be needed if your CF installation has password policies. -
timeout_scale
(optional): Used primarily to scale default timeouts for test setup and teardown actions (e.g. creating an org) as opposed to main test actions (e.g. pushing an app). -
use_http
(optional): Set to true if you would like CF Acceptance Tests to use HTTP when making api and application requests. (default is HTTPS) -
node_memory_limit
(optional): the memory limit of node.js test application, should be greater than 128 (MB) -
java_buildpack_name
(optional) See below. -
nodejs_buildpack_name
(optional) See below.
Many tests specify a buildpack when pushing an app, so that on diego the app staging process completes in less time. The default names for the buildpacks are as follows; if you have buildpacks with different names, you can override them by setting different names:
java_buildpack_name: java_buildpack
nodejs_buildpack_name: nodejs_buildpack
If you set a value for artifacts_directory
in your $CONFIG
file, then you will be able to capture cf
trace output from failed test runs. When a test fails, look for the node id and suite name ("Applications" and "2" in the example below) in the test output:
=== RUN TestLifecycle
Running Suite: Applications
====================================
Random Seed: 1389376383
Parallel test node 2/10. Assigned 14 of 137 specs.
The cf
trace output for the tests in these specs will be found in CF-TRACE-Applications-2.txt
in the artifacts_directory
.
There are several different test suites, and you may not wish to run all the tests in all contexts, and sometimes you may want to focus individual test suites to pinpoint a failure. The default set of tests can be run via:
./bin/test_default
For more flexibility you can run ./bin/test
and specify many more options, e.g. which suites to run, which suites to exclude (e.g. if you want to run all but one suite), whether or not to run the tests in parallel, the number of parallel nodes to use, etc. Refer to ginkgo documentation for full details.
For example, to execute all test suites, and have tests run in parallel across four processes one would run:
./bin/test -r -nodes=4
Be careful with this number, as it's effectively "how many apps to push at once", as nearly every example pushes an app.
To execute the acceptance tests for a specific suite, e.g. broker
, run the following:
./bin/test broker
The suite names correspond to directory names.
To see verbose output from ginkgo
, use the -v
flag.
./bin/test broker -v
Most of these flags and options can also be passed to the bin/test_default
scripts as well.