Skip to content

cloudfoundry/cf-performance-tests

Repository files navigation

cf-performance-tests

Performance tests for the Cloud Foundry API (Cloud Controller).

Goals

These tests are intended to:

  • Help debug slow endpoints
  • Analyse performance impact of changes to Cloud Controller codebase
  • Ensure that query times do not scale exponentially with database size

Anti-goals

These tests are not intended to:

  • Test parallelism of a specific webserver
  • Load test the Cloud Controller
  • Assist with scaling decisions of CAPI deployments

Test automation

The tests in the main branch are running regularly on a public concourse, which can be found here. The repo containing the concourse pipeline for bootstrapping of the CF foundation and running the tests, can be found here. The test results and generated charts can be found there as well.

Running tests

Tests in this repository are written using Ginkgo using the GOmega GMeasure testing package. This package allows the user to:

  • Set up a new experiment
  • Measure the duration of the experiment (in this suite's case, this mostly means the duration of curls to different endpoints as different users)
  • Generate reports based on the tests that include different statistics (min time, max time, mean, standard deviation, etc).

The test suite uses Viper for configuration of parameters such as API endpoint, credentials etc. Viper will look for a configuration file in both the $HOME directory and the working directory that tests are invoked from. See the Config struct for available configuration parameters.

To run the tests, create a configuration file that Viper can find, e.g. config.yml in the project's root folder:

api: "<CF API endpoint>"
use_http: false  (the default value)
skip_ssl_validation: false (the default value)
cf_deployment_version: "<used for generated report>"
capi_version: "<used for generated report>"
large_page_size: 500  (the default value)
large_elements_filter: 100  (the default value)
samples: 5  (the default value)
basic_timeout: 60  (the default value)
long_timeout: 180  (the default value)
users:
  admin:
    username: "<admin username>"
    password: "<admin password>"
  existing:  (optional block)
    username: "<non-admin username>"
    password: "<non-admin password>"
database_type: "postgres" (default) or "mysql"
ccdb_connection: "<connection string for CCDB>"
uaadb_connection: "<connection string for UAADB>"  (optional, used to cleanup the created test user)
results_folder: "../../test-results" (the default value)
test_resource_prefix: "perf" (the default value)

The test_resource_prefix string must match the prefix of the test resources names. Note that some performance tests delete lists of resources. Using a test_resource_prefix ensures that only test resources are deleted.

Then run:

ginkgo -r

Contributing

The goal of the tests is to have long term comparable results. Therefore, after creating a test suite, the test should never be changed again. Otherwise, the results will differ because of differences in the test setup and not because of changes in the codebase of the Cloud Contoller. If changes to the test are necessary a new version of the test suite must be created.

Before changing the implementation of an endpoint in the Cloud Controller with the goal of improving its performance, a test should be created, to be able to see the performance change in the tests.

About

No description, website, or topics provided.

Resources

License

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published