This document walks you through the process of testing your app on Bitbucket using the Data Center App Performance Toolkit. These instructions focus on producing the required performance and scale benchmarks for your Data Center app.
In this document, we cover the use of the Data Center App Performance Toolkit on two types of environments:
Development environment: Bitbucket Data Center environment for a test run of Data Center App Performance Toolkit and development of app-specific actions.
Enterprise-scale environment: Bitbucket Data Center environment used to generate Data Center App Performance Toolkit test results for the Marketplace approval process.
Running the tests in a development environment helps familiarize you with the toolkit. It'll also provide you with a lightweight and less expensive environment for developing app-specific actions. Once you're ready to generate test results for the Marketplace Data Center Apps Approval process, run the toolkit in an enterprise-scale environment.
You are responsible for the cost of AWS services used while running this Terraform deployment. See Amazon EC2 pricing for more detail.
To reduce costs, we recommend you to keep your deployment up and running only during the performance runs. AWS Bitbucket Data Center development environment infrastructure costs about 20 - 40$ per working week depending on such factors like region, instance type, deployment type of DB, and other.
Bitbucket Data Center development environment is good for app-specific actions development. But not powerful enough for performance testing at scale. See Set up an enterprise-scale environment Bitbucket Data Center on AWS for more details.
Below process describes how to install low-tier Bitbucket DC with "small" dataset included:
Create Access keys for AWS CLI:
Example Option 1 with Admin user:
AdministratorAccess
Access key
and Secret access key
in aws_envs fileExample Option 2 with granular Policies:
Go to AWS Console -> IAM service -> Policies
Create policy1
with json content of the policy1 file
Important: change all occurrences of 123456789012
to your real AWS Account ID.
Create policy2
with json content of the policy2 file
Important: change all occurrences of 123456789012
to your real AWS Account ID.
Go to User -> Create user -> Attach policies directly -> Attach policy1
and policy2
-> Click on Create user button
Open newly created user -> Security credentials tab -> Access keys -> Create access key -> Command Line Interface (CLI) -> Create access key
Use Access key
and Secret access key
in aws_envs file
Clone Data Center App Performance Toolkit locally.
For annual review, always get the latest version of the DCAPT code from the master branch.
DCAPT supported versions: three latest minor version releases.
Navigate to dc-app-performance-toolkit/app/util/k8s
folder.
Set AWS access keys created in step1 in aws_envs
file:
AWS_ACCESS_KEY_ID
AWS_SECRET_ACCESS_KEY
AWS_SESSION_TOKEN
(only for temporary creds)Set required variables in dcapt-small.tfvars
file:
environment_name
- any name for you environment, e.g. dcapt-bitbucket-small
products
- bitbucket
bitbucket_license
- one-liner of valid bitbucket license without spaces and new line symbols
region
- AWS region for deployment. Do not change default region (us-east-2
). If specific region is required, contact support.
New trial license could be generated on my atlassian.
Use BX02-9YO1-IN86-LO5G
Server ID for generation.
Optional variables to override:
bitbucket_version_tag
- Bitbucket version to deploy. Supported versions see in README.md.From local terminal (Git Bash for Windows users) start the installation (~20 min):
1 2docker run --env-file aws_envs \ -v "/$PWD/dcapt-small.tfvars:/data-center-terraform/conf.tfvars" \ -v "/$PWD/dcapt-snapshots.json:/data-center-terraform/dcapt-snapshots.json" \ -v "/$PWD/logs:/data-center-terraform/logs" \ -it atlassianlabs/terraform:2.9.3 ./install.sh -c conf.tfvars
Copy product URL from the console output. Product url should look like http://a1234-54321.us-east-2.elb.amazonaws.com/bitbucket
.
All the datasets use the standard admin
/admin
credentials.
Make sure English language is selected as a default language on the > General configuration > Languages page. Other languages are not supported by the toolkit.
Clone Data Center App Performance Toolkit locally.
For annual review, always get the latest version of the DCAPT code from the master branch.
DCAPT supported versions: three latest minor version releases.
Follow the README.md instructions to set up toolkit locally.
Navigate to dc-app-performance-toolkit/app
folder.
Open the bitbucket.yml
file and fill in the following variables:
application_hostname
: your_dc_bitbucket_instance_hostname without protocol.application_protocol
: http or https.application_port
: for HTTP - 80, for HTTPS - 443, 8080, 1990 or your instance-specific port.secure
: True or False. Default value is True. Set False to allow insecure connections, e.g. when using self-signed SSL certificate.application_postfix
: /bitbucket - default postfix value for TerraForm deployment url like http://a1234-54321.us-east-2.elb.amazonaws.com/bitbucket
admin_login
: admin user username.admin_password
: admin user password.load_executor
: executor for load tests - jmeterconcurrency
: 1
- number of concurrent JMeter users.test_duration
: 5m
- duration of the performance run.ramp-up
: 1s
- amount of time it will take JMeter to add all test users to test execution.total_actions_per_hour
: 3270
- number of total JMeter actions per hour.WEBDRIVER_VISIBLE
: visibility of Chrome browser during selenium execution (False is by default).Run bzt.
1 2bzt bitbucket.yml
Review the resulting table in the console log. All JMeter and Selenium actions should have 0+% success rate.
In case some actions have 0% success rate refer to the following logs in dc-app-performance-toolkit/app/results/bitbucket/YY-MM-DD-hh-mm-ss
folder:
results_summary.log
: detailed run summaryresults.csv
: aggregated .csv file with all actions and timingsbzt.log
: logs of the Taurus tool executionjmeter.*
: logs of the JMeter tool executionpytest.*
: logs of Pytest-Selenium executionOn the local run with development environment default tests may be flaky due to limited resources of the development cluster and local network.
The only purpose of the development cluster is to develop app-specific actions.
Do not proceed with the next step if any action has 0% success rate. Ask support if above logs analysis did not help.
Data Center App Performance Toolkit has its own set of default test actions for Bitbucket Data Center: JMeter and Selenium for load and UI tests respectively.
App-specific action - action (performance test) you have to develop to cover main use cases of your application. Performance test should focus on the common usage of your application and not to cover all possible functionality of your app. For example, application setup screen or other one-time use cases are out of scope of performance testing.
We strongly recommend developing your app-specific actions on the development environment to reduce AWS infrastructure costs.
You develop an app that adds some additional fields to specific types of Bitbucket issues. In this case, you should develop Selenium app-specific action:
dc-app-performance-toolkit/app/extension/bitbucket/extension_ui.py
.app_specific_action
as specific user uncomment app_specific_user_login
function in code example. Note, that in this case test_1_selenium_custom_action
should follow just before test_2_selenium_z_log_out
action.dc-app-performance-toolkit/app/selenium_ui/bitbucket_ui.py
, review and uncomment the following block of code to make newly created app-specific actions executed:1 2# def test_1_selenium_custom_action(webdriver, datasets, screen_shots): # app_specific_action(webdriver, datasets)
bzt bitbucket.yml
command to ensure that all Selenium actions including app_specific_action
are successful.After adding your custom app-specific actions, you should now be ready to run the required tests for the Marketplace Data Center Apps Approval process. To do this, you'll need an enterprise-scale environment.
It is recommended to terminate a development environment before creating an enterprise-scale environment. Follow Terminate development environment instructions. In case of any problems with uninstall use Force terminate command.
The installation of 4-pods DC environment and execution pod requires at least 40 vCPU Cores. Newly created AWS account often has vCPU limit set to low numbers like 5 vCPU per region. Check your account current vCPU limit for On-Demand Standard instances by visiting AWS Service Quotas page. Applied quota value is the current CPU limit in the specific region.
Make that current region limit is large enough to deploy new cluster. The limit can be increased by using Request increase at account-level button: choose a region, set a quota value which equals a required number of CPU Cores for the installation and press Request button. Recommended limit is 50.
*The prices below are approximate and may vary depending on factors such as (region, instance type, deployment type of DB, etc.)
Stack | Estimated hourly cost ($) |
---|---|
One pod Bitbucket DC | 1 - 2 |
Two pods Bitbucket DC | 1.5 - 2.5 |
Four pods Bitbucket DC | 2.5 - 4 |
Data dimensions and values for an enterprise-scale dataset are listed and described in the following table.
Data dimensions | Value for an enterprise-scale dataset |
---|---|
Projects | ~25 000 |
Repositories | ~52 000 |
Users | ~25 000 |
Pull Requests | ~ 1 000 000 |
Total files number | ~750 000 |
Below process describes how to install enterprise-scale Bitbucket DC with "large" dataset included:
Create Access keys for AWS CLI:
Example Option 1 with Admin user:
AdministratorAccess
Access key
and Secret access key
in aws_envs fileExample Option 2 with granular Policies:
Go to AWS Console -> IAM service -> Policies
Create policy1
with json content of the policy1 file
Important: change all occurrences of 123456789012
to your real AWS Account ID.
Create policy2
with json content of the policy2 file
Important: change all occurrences of 123456789012
to your real AWS Account ID.
Go to User -> Create user -> Attach policies directly -> Attach policy1
and policy2
-> Click on Create user button
Open newly created user -> Security credentials tab -> Access keys -> Create access key -> Command Line Interface (CLI) -> Create access key
Use Access key
and Secret access key
in aws_envs file
Clone Data Center App Performance Toolkit locally.
For annual review, always get the latest version of the DCAPT code from the master branch.
DCAPT supported versions: three latest minor version releases.
Navigate to dc-app-performance-toolkit/app/util/k8s
folder.
Set AWS access keys created in step1 in aws_envs
file:
AWS_ACCESS_KEY_ID
AWS_SECRET_ACCESS_KEY
AWS_SESSION_TOKEN
(only for temporary creds)Set required variables in dcapt.tfvars
file:
environment_name
- any name for you environment, e.g. dcapt-bitbucket-large
products
- bitbucket
bitbucket_license
- one-liner of valid bitbucket license without spaces and new line symbols
region
- AWS region for deployment. Do not change default region (us-east-2
). If specific region is required, contact support.
New trial license could be generated on my atlassian.
Use this server id for generation BX02-9YO1-IN86-LO5G
.
Optional variables to override:
bitbucket_version_tag
- Bitbucket version to deploy. Supported versions see in README.md.From local terminal (Git Bash for Windows users) start the installation (~40min):
1 2docker run --env-file aws_envs \ -v "/$PWD/dcapt.tfvars:/data-center-terraform/conf.tfvars" \ -v "/$PWD/dcapt-snapshots.json:/data-center-terraform/dcapt-snapshots.json" \ -v "/$PWD/logs:/data-center-terraform/logs" \ -it atlassianlabs/terraform:2.9.3 ./install.sh -c conf.tfvars
Copy product URL from the console output. Product url should look like http://a1234-54321.us-east-2.elb.amazonaws.com/bitbucket
.
All the datasets use the standard admin
/admin
credentials.
It's recommended to change default password from UI account page for security reasons.
Default TerraForm deployment configuration
already has a dedicated execution environment pod to run tests from. For more details see Execution Environment Settings
section in dcapt.tfvars
file.
Check the bitbucket.yml
configuration file. If load configuration settings were changed for dev runs, make sure parameters
were changed back to the defaults:
1 2application_hostname: test_bitbucket_instance.atlassian.com # Bitbucket DC hostname without protocol and port e.g. test-bitbucket.atlassian.com or localhost application_protocol: http # http or https application_port: 80 # 80, 443, 8080, 7990 etc secure: True # Set False to allow insecure connections, e.g. when using self-signed SSL certificate application_postfix: /bitbucket # e.g. /bitbucket for TerraForm deployment url like `http://a1234-54321.us-east-2.elb.amazonaws.com/bitbucket`. Leave this value blank for url without postfix. admin_login: admin admin_password: admin load_executor: jmeter # only jmeter executor is supported concurrency: 20 # number of concurrent virtual users for jmeter scenario test_duration: 50m ramp-up: 10m # time to spin all concurrent users total_actions_per_hour: 32700 # number of total JMeter actions per hour
You'll need to run the toolkit for each test scenario in the next section.
Using the Data Center App Performance Toolkit for Performance and scale testing your Data Center app involves two test scenarios:
Each scenario will involve multiple test runs. The following subsections explain both in greater detail.
This scenario helps to identify basic performance issues without a need to spin up a multi-node Bitbucket DC. Make sure the app does not have any performance impact when it is not exercised.
To receive performance baseline results without an app installed:
Before run:
bitbucket.yml
and toolkit code base has default configuration from the master
branch.application_hostname
, application_protocol
, application_port
and application_postfix
in .yml file../dc-app-performance-toolkit/app/util/k8s/aws_envs
file:
AWS_ACCESS_KEY_ID
AWS_SECRET_ACCESS_KEY
AWS_SESSION_TOKEN
(only for temporary creds)Navigate to dc-app-performance-toolkit
folder and start tests execution:
1 2export ENVIRONMENT_NAME=your_environment_name
1 2docker run --pull=always --env-file ./app/util/k8s/aws_envs \ -e REGION=us-east-2 \ -e ENVIRONMENT_NAME=$ENVIRONMENT_NAME \ -v "/$PWD:/data-center-terraform/dc-app-performance-toolkit" \ -v "/$PWD/app/util/k8s/bzt_on_pod.sh:/data-center-terraform/bzt_on_pod.sh" \ -it atlassianlabs/terraform:2.9.3 bash bzt_on_pod.sh bitbucket.yml
View the following main results of the run in the dc-app-performance-toolkit/app/results/bitbucket/YY-MM-DD-hh-mm-ss
folder:
results_summary.log
: detailed run summaryresults.csv
: aggregated .csv file with all actions and timingsbzt.log
: logs of the Taurus tool executionjmeter.*
: logs of the JMeter tool executionpytest.*
: logs of Pytest-Selenium executionReview results_summary.log
file under artifacts dir location. Make sure that overall status is OK
before moving to the next steps. For an enterprise-scale environment run, the acceptable success rate for actions is 95% and above.
To receive performance results with an app installed (still use master branch):
Install the app you want to test.
Setup app license.
Navigate to dc-app-performance-toolkit
folder and start tests execution:
1 2export ENVIRONMENT_NAME=your_environment_name
1 2docker run --pull=always --env-file ./app/util/k8s/aws_envs \ -e REGION=us-east-2 \ -e ENVIRONMENT_NAME=$ENVIRONMENT_NAME \ -v "/$PWD:/data-center-terraform/dc-app-performance-toolkit" \ -v "/$PWD/app/util/k8s/bzt_on_pod.sh:/data-center-terraform/bzt_on_pod.sh" \ -it atlassianlabs/terraform:2.9.3 bash bzt_on_pod.sh bitbucket.yml
Review results_summary.log
file under artifacts dir location. Make sure that overall status is OK
before moving to the next steps. For an enterprise-scale environment run, the acceptable success rate for actions is 95% and above.
To generate a performance regression report:
./app/reports_generation/performance_profile.yml
file:
dc-app-performance-toolkit
folder and run the following command from local terminal (Git Bash for Windows users) to generate reports:
1 2docker run --pull=always \ -v "/$PWD:/dc-app-performance-toolkit" \ --workdir="//dc-app-performance-toolkit/app/reports_generation" \ --entrypoint="python" \ -it atlassian/dcapt csv_chart_generator.py performance_profile.yml
./app/results/reports/YY-MM-DD-hh-mm-ss
folder, view the .csv
file (with consolidated scenario results), the .png
chart file and performance scenario summary report.
If you see an impact (>20%) on any action timing, we recommend taking a look into the app implementation to understand the root cause of this delta.To receive scalability benchmark results for one-node Bitbucket DC with app-specific actions:
Before run:
bitbucket.yml
and toolkit code base has code base with your developed app-specific actions.application_hostname
, application_protocol
, application_port
and application_postfix
in .yml file../dc-app-performance-toolkit/app/util/k8s/aws_envs
file:
AWS_ACCESS_KEY_ID
AWS_SECRET_ACCESS_KEY
AWS_SESSION_TOKEN
(only for temporary creds)Navigate to dc-app-performance-toolkit
folder and start tests execution:
1 2export ENVIRONMENT_NAME=your_environment_name
1 2docker run --pull=always --env-file ./app/util/k8s/aws_envs \ -e REGION=us-east-2 \ -e ENVIRONMENT_NAME=$ENVIRONMENT_NAME \ -v "/$PWD:/data-center-terraform/dc-app-performance-toolkit" \ -v "/$PWD/app/util/k8s/bzt_on_pod.sh:/data-center-terraform/bzt_on_pod.sh" \ -it atlassianlabs/terraform:2.9.3 bash bzt_on_pod.sh bitbucket.yml
Review results_summary.log
file under artifacts dir location. Make sure that overall status is OK
before moving to the next steps. For an enterprise-scale environment run, the acceptable success rate for actions is 95% and above.
Before scaling your DC make sure that AWS vCPU limit is not lower than needed number. Minimum recommended value is 50.
Use AWS Service Quotas service to see current limit for us-east-2
region.
EC2 CPU Limit section has instructions on how to increase limit if needed.
To receive scalability benchmark results for two-node Bitbucket DC with app-specific actions:
Navigate to dc-app-performance-toolkit/app/util/k8s
folder.
Open dcapt.tfvars
file and set bitbucket_replica_count
value to 2
.
From local terminal (Git Bash for Windows users) start scaling (~20 min):
1 2docker run --pull=always --env-file aws_envs \ -v "/$PWD/dcapt.tfvars:/data-center-terraform/conf.tfvars" \ -v "/$PWD/dcapt-snapshots.json:/data-center-terraform/dcapt-snapshots.json" \ -v "/$PWD/logs:/data-center-terraform/logs" \ -it atlassianlabs/terraform:2.9.3 ./install.sh -c conf.tfvars
Navigate to dc-app-performance-toolkit
folder and start tests execution:
1 2export ENVIRONMENT_NAME=your_environment_name
1 2docker run --pull=always --env-file ./app/util/k8s/aws_envs \ -e REGION=us-east-2 \ -e ENVIRONMENT_NAME=$ENVIRONMENT_NAME \ -v "/$PWD:/data-center-terraform/dc-app-performance-toolkit" \ -v "/$PWD/app/util/k8s/bzt_on_pod.sh:/data-center-terraform/bzt_on_pod.sh" \ -it atlassianlabs/terraform:2.9.3 bash bzt_on_pod.sh bitbucket.yml
Review results_summary.log
file under artifacts dir location. Make sure that overall status is OK
before moving to the next steps. For an enterprise-scale environment run, the acceptable success rate for actions is 95% and above.
Before scaling your DC make sure that AWS vCPU limit is not lower than needed number. Minimum recommended value is 50.
Use AWS Service Quotas service to see current limit for us-east-2
region.
EC2 CPU Limit section has instructions on how to increase limit if needed.
To receive scalability benchmark results for four-node Bitbucket DC with app-specific actions:
Scale your Bitbucket Data Center deployment to 4 nodes as described in Run 4.
Navigate to dc-app-performance-toolkit
folder and start tests execution:
1 2export ENVIRONMENT_NAME=your_environment_name
1 2docker run --pull=always --env-file ./app/util/k8s/aws_envs \ -e REGION=us-east-2 \ -e ENVIRONMENT_NAME=$ENVIRONMENT_NAME \ -v "/$PWD:/data-center-terraform/dc-app-performance-toolkit" \ -v "/$PWD/app/util/k8s/bzt_on_pod.sh:/data-center-terraform/bzt_on_pod.sh" \ -it atlassianlabs/terraform:2.9.3 bash bzt_on_pod.sh bitbucket.yml
Review results_summary.log
file under artifacts dir location. Make sure that overall status is OK
before moving to the next steps. For an enterprise-scale environment run, the acceptable success rate for actions is 95% and above.
To generate a scalability report:
./app/reports_generation/scale_profile.yml
file:
runName: "1 Node"
, in the relativePath
key, insert the relative path to results directory of Run 3.runName: "2 Nodes"
, in the relativePath
key, insert the relative path to results directory of Run 4.runName: "4 Nodes"
, in the relativePath
key, insert the relative path to results directory of Run 5.dc-app-performance-toolkit
folder and run the following command from local terminal (Git Bash for Windows users) to generate reports:
1 2docker run --pull=always \ -v "/$PWD:/dc-app-performance-toolkit" \ --workdir="//dc-app-performance-toolkit/app/reports_generation" \ --entrypoint="python" \ -it atlassian/dcapt csv_chart_generator.py scale_profile.yml
./app/results/reports/YY-MM-DD-hh-mm-ss
folder, view the .csv
file (with consolidated scenario results), the .png
chart file and performance scenario summary report.
If you see an impact (>20%) on any action timing, we recommend taking a look into the app implementation to understand the root cause of this delta.It is recommended to terminate an enterprise-scale environment after completing all tests. Follow Terminate enterprise-scale environment instructions. In case of any problems with uninstall use Force terminate command.
Do not forget to attach performance testing results to your ECOHELP ticket.
profile.csv
, profile.png
, profile_summary.log
and profile run result archives. Archives
should contain all raw data created during the run: bzt.log
, selenium/jmeter/locust logs, .csv and .yml files, etc.If the installation script fails on installing Helm release or any other reason, collect the logs, zip and share to community Slack #data-center-app-performance-toolkit channel. For instructions on how to collect detailed logs, see Collect detailed k8s logs. For failed cluster uninstall use Force terminate command.
In case of any technical questions or issues with DC Apps Performance Toolkit, contact us for support in the community Slack #data-center-app-performance-toolkit channel.
Rate this page: