title | platform | product | category | subcategory | date |
---|---|---|---|---|---|
Data Center App Performance Toolkit User Guide For Jira Service Management |
platform |
marketplace |
devguide |
build |
2024-10-22 |
This document walks you through the process of testing your app on Jira Service Management using the Data Center App Performance Toolkit. These instructions focus on producing the required performance and scale benchmarks for your Data Center app:
If your application relays or extends the functionality of Insight (What is Insight?):
Please, make sure you have enabled Insight-specific tests in the jsm.yml
file, by setting True
value next to the insight
variable.
In this document, we cover the use of the Data Center App Performance Toolkit on two types of environments:
Development environment: Jira Service Management Data Center environment for a test run of Data Center App Performance Toolkit and development of app-specific actions.
- Set up a development environment Jira Service Management Data Center on AWS.
- Run toolkit on the development environment locally.
- Develop and test app-specific actions locally.
Enterprise-scale environment: Jira Service Management Data Center environment used to generate Data Center App Performance Toolkit test results for the Marketplace approval process.
- Set up an enterprise-scale environment Jira Service Management Data Center on AWS.
- Setting up load configuration for Enterprise-scale runs.
- Running the test scenarios from execution environment against enterprise-scale Jira Service Management Data Center.
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.
{{% note %}} You are responsible for the cost of AWS services used while running this Terraform deployment. See Amazon EC2 pricing for more detail. {{% /note %}}
To reduce costs, we recommend you to keep your deployment up and running only during the performance runs. AWS Jira Service Management 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.
{{% note %}} Jira Service Management 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 Jira Service Management Data Center on AWS for more details. {{% /note %}}
Below process describes how to install low-tier Jira Service Management DC with "small" dataset included:
-
Create Access keys for AWS CLI: {{% warning %}} Do not use
root
user credentials for cluster creation.Option 1 (simple): create admin user with
AdministratorAccess
permissions.Option 2 (complex): create granular permission policies with policy1 and policy2.
The specific configuration relies on how you manage permissions within AWS. {{% /warning %}}
Example Option 1 with Admin user:
- Go to AWS Console -> IAM service -> Users
- Create new user -> attach policies directly ->
AdministratorAccess
- Open newly created user -> Security credentials tab -> Access keys -> Create access key -> Command Line Interface (CLI) -> Create access key
- Use
Access key
andSecret access key
in aws_envs file
Example Option 2 with granular Policies:
- Go to AWS Console -> IAM service -> Policies
- Create
policy1
with json content of the policy1 file {{% warning %}} Important: change all occurrences of123456789012
to your real AWS Account ID. {{% /warning %}} - Create
policy2
with json content of the policy2 file {{% warning %}} Important: change all occurrences of123456789012
to your real AWS Account ID. {{% /warning %}} - Go to User -> Create user -> Attach policies directly -> Attach
policy1
andpolicy2
-> 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
andSecret access key
in aws_envs file
-
Clone Data Center App Performance Toolkit locally. {{% warning %}} For annual review, always get the latest version of the DCAPT code from the master branch.
DCAPT supported versions: three latest minor version releases. {{% /warning %}}
-
Navigate to
dc-apps-peformance-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-jsm-small
.products
-jira
jira_image_repository
-atlassian/jira-servicemanagement
- make sure to select the Jira Service Management application.jira_license
- one-liner of valid Jira Service Management 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.
{{% note %}} New trial license could be generated on my atlassian. Use
BX02-9YO1-IN86-LO5G
Server ID for generation. {{% /note %}} -
Optional variables to override:
jira_version_tag
- Jira Service Management version to deploy. Supported versions see in README.md.
-
From local terminal (Git Bash for Windows users) start the installation (~20 min):
docker run --pull=always --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/jira
.
{{% note %}}
All the datasets use the standard admin
/admin
credentials.
{{% /note %}}
{{% warning %}} Make sure English (United States) language is selected as a default language on the > System > General configuration page. Other languages are not supported by the toolkit. {{% /warning %}}
-
Clone Data Center App Performance Toolkit locally. {{% warning %}} For annual review, always get the latest version of the DCAPT code from the master branch.
DCAPT supported versions: three latest minor version releases. {{% /warning %}}
-
Follow the README.md instructions to set up toolkit locally.
-
Navigate to
dc-app-performance-toolkit/app
folder. -
Open the
jsm.yml
file and fill in the following variables:application_hostname
: your_dc_jsm_instance_hostname without protocol.application_protocol
: http or https.application_port
: for HTTP - 80, for HTTPS - 443, 8080, 2990 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
: /jira # default value for TerraForm deployment; e.g., /jira for url like this http://localhost:2990/jira.admin_login
: admin user username.admin_password
: admin user password.load_executor
: executor for load tests. Valid options are jmeter (default) or locust.concurrency_agents
:1
- number of concurrent JMeter/Locust agents.concurrency_customers
:1
- number of concurrent JMeter/Locust customers.test_duration
:5m
- duration of the performance run.ramp-up
:3s
- amount of time it will take JMeter or Locust to add all test users to test execution.total_actions_per_hour_agents
:500
- number of total JMeter/Locust actions per hour for agents scenario.total_actions_per_hour_customers
:1500
- number of total JMeter/Locust actions per hour customers scenario.WEBDRIVER_VISIBLE
: visibility of Chrome browser during selenium execution (False is by default).insight
: True or False. Default value is False. Set True to enable Insight specific tests.
-
In case your application relays or extends the functionality of Insight. Make sure to set
True
value next toinsight
variable. -
Run bzt.
bzt jsm.yml
-
Review the resulting table in the console log. All JMeter/Locust and Selenium actions should have 0+% success rate.
In case some actions have 0% success rate refer to the following logs indc-app-performance-toolkit/app/results/jsm/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 executionlocust.*
: logs of the Locust tool execution (in case you use Locust as load_executor in jsm.yml)pytest.*
: logs of Pytest-Selenium execution
{{% warning %}} On 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. {{% /warning %}}
Data Center App Performance Toolkit has its own set of default test actions for Jira Service Management Data Center: JMeter/Locust 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.
- Define main use case of your app. Usually it is one or two main app use cases.
- Your app adds new UI elements in Jira Service Management Data Center - Selenium app-specific action has to be developed.
- Your app introduces new endpoint or extensively calls existing Jira Service Management Data Center API - JMeter/Locust app-specific actions has to be developed.
JMeter and Locust actions are interchangeable, so you could select the tool you prefer:
- JMeter - UI-based performance tool.
- Locust - code-based (Python requests library) performance tool.
{{% note %}} We strongly recommend developing your app-specific actions on the development environment to reduce AWS infrastructure costs. {{% /note %}}
You can filter your own app-specific issues for your app-specific actions.
- Create app-specific service desk requests that have specific anchor in summary, e.g. AppRequest anchor and issues summaries like AppRequest1, AppRequest2, AppRequest3.
- Go to the search page of your Jira Service Management Data Center -
JSM_URL/issues/?jql=
and selectAdvanced
. - Write JQL that filter just your request from step 1, e.g.
summary ~ 'AppRequest*'
. - Edit JSM configuration file
dc-app-performance-toolkit/app/jsm.yml
:custom_dataset_query:
JQL from step 3.
Next time when you run toolkit, custom dataset issues will be stored to the dc-app-performance-toolkit/app/datasets/jsm/custom-requests.csv
with columns: request_id
, request_key
, service_desk_id
, project_id
, project_key
.
You develop an app that adds some additional fields to specific types of Jira Service Management requests. In this case, you should develop Selenium app-specific action:
- Create app-specific service desk requests with AppRequest anchor in summary: AppRequest1, AppRequest2, etc.
- Go to the search page of your Jira Service Management Data Center -
JSM_URL/issues/?jql=
and check if JQL is correct:summary ~ 'AppRequest*'
. - Edit
dc-app-performance-toolkit/app/jsm.yml
configuration file and setcustom_dataset_query: summary ~ 'AppRequest*'
. - Extend example of app-specific action for agent in
dc-app-performance-toolkit/app/extension/jsm/extension_ui_agents.py
.
Code example. So, our test has to open app-specific requests in agent view and measure time to load of this app-specific request. - Extend example of app-specific action for customer in
dc-app-performance-toolkit/app/extension/jsm/extension_ui_customers.py
.
Code example. So, our test has to open app-specific requests in portal view and measure time to load of this app-specific request. - If you need to run
app_specific_action
as specific user uncommentapp_specific_user_login
function in code example. Note, that in this casetest_1_selenium_custom_action
should follow just beforetest_2_selenium_agent_z_logout
ortest_2_selenium_customer_z_log_out
action. - In
dc-app-performance-toolkit/app/selenium_ui/jsm_ui_agents.py
, review and uncomment the following block of code to make newly created app-specific actions executed:
# def test_1_selenium_agent_custom_action(jsm_webdriver, jsm_datasets, jsm_screen_shots):
# extension_ui_agents.app_specific_action(jsm_webdriver, jsm_datasets)
- In
dc-app-performance-toolkit/app/selenium_ui/jsm_ui_customers.py
, review and uncomment the following block of code to make newly created app-specific actions executed:
# def test_1_selenium_customer_custom_action(jsm_webdriver, jsm_datasets, jsm_screen_shots):
# extension_ui_customers.app_specific_action(jsm_webdriver, jsm_datasets)
- Run toolkit with
bzt jsm.yml
command to ensure that all Selenium actions includingapp_specific_action
are successful.
You develop an app that introduces new GET and POST endpoints in Jira Service Management Data Center. In this case, you should develop Locust or JMeter app-specific action.
Locust app-specific action development example
- Extend example of app-specific action for agent in
dc-app-performance-toolkit/app/extension/jsm/extension_locust_agents.py
, so that test will call the endpoint with GET request, parse response use these data to call another endpoint with POST request and measure response time.
Code example. - Extend example of app-specific action for customers in
dc-app-performance-toolkit/app/extension/jsm/extension_locust_customers.py
, so that test will call the endpoint with GET request, parse response use these data to call another endpoint with POST request and measure response time.
Code example. - In
dc-app-performance-toolkit/app/jsm.yml
setload_executor: locust
to makelocust
as load executor. - Set desired execution percentage for
agent_standalone_extension
/customer_standalone_extension
. Default value is0
, which means thatagent_standalone_extension
/customer_standalone_extension
action will not be executed. Locust uses actions percentage as relative weights, so ifsome_action: 10
andstandalone_extension: 20
that means thatstandalone_extension
will be called twice more.
Setagent_standalone_extension
/customer_standalone_extension
weight in accordance with the expected frequency of your app use case compared with other base actions. - App-specific tests could be run (if needed) as a specific user. Use
@run_as_specific_user(username='specific_user_username', password='specific_user_password')
decorator for that. - Run toolkit with
bzt jsm.yml
command to ensure that all Locust actions includingapp_specific_action
are successful.
JMeter app-specific action development example
-
Check that
jsm.yml
file has correct settings ofapplication_hostname
,application_protocol
,application_port
,application_postfix
, etc. -
Set desired execution percentage for
agent_standalone_extension
and/orcustomer_standalone_extension
. Default values are0
, which means thatagent_standalone_extension
andcustomer_standalone_extension
actions will not be executed. For example, for app-specific action development you could set percentage ofagent_standalone_extension
and/orcustomer_standalone_extension
to 100 and for all other actions to 0 - this way onlyjmeter_agent_login_and_view_dashboard
andagent_standalone_extension
orjmeter_customer_login_and_view_dashboard
andcustomer_standalone_extension
actions would be executed. -
Navigate to
dc-app-performance-toolkit/app
folder and run from virtualenv(as described indc-app-performance-toolkit/README.md
):python util/jmeter/start_jmeter_ui.py --app jsm --type agents # or python util/jmeter/start_jmeter_ui.py --app jsm --type customers
-
Open
Agents
/Customers
thread group >actions per login
and navigate toagent_standalone_extension
/customer_standalone_extension
-
Add GET
HTTP Request
: right-click toagent_standalone_extension
/customer_standalone_extension`` >
Add>
Sampler -
Add
Regular Expression Extractor
: right-click to to newly createdHTTP Request
>Add
>Post processor
>Regular Expression Extractor
-
Add
Response Assertion
: right-click to newly createdHTTP Request
>Add
>Assertions
>Response Assertion
and add assertion withContains
,Matches
,Equals
, etc types. -
Add POST
HTTP Request
: right-click toagent_standalone_extension
/customer_standalone_extension
>Add
>Sampler
HTTP Request
, chose method POST, set endpoint in Path and add Parameters or Body Data if needed. -
Right-click on
View Results Tree
and enable this controller. -
Click Start button and make sure that
login_and_view_dashboard
andagent_standalone_extension
/customer_standalone_extension
are successful. -
Right-click on
View Results Tree
and disable this controller. It is important to disableView Results Tree
controller before full-scale results generation. -
Click Save button.
-
To make
agent_standalone_extension
/customer_standalone_extension
executable during toolkit run editdc-app-performance-toolkit/app/jsm.yml
and set execution percentage ofagent_standalone_extension
/customer_standalone_extension
accordingly to your use case frequency. -
App-specific tests could be run (if needed) as a specific user. In the
agent_standalone_extension
/customer_standalone_extension
uncommentlogin_as_specific_user
controller. Navigate to theusername:password
config element and update values forapp_specific_username
andapp_specific_password
names with your specific user credentials. Also make sure that you located your app-specific tests betweenlogin_as_specific_user
andlogin_as_default_user_if_specific_user_was_loggedin
controllers. -
Run toolkit to ensure that all JMeter actions including
agent_standalone_extension
and/orcustomer_standalone_extension
are successful.
Use or access the following variables in your agent_standalone_extension
action if needed:
${request_id}
- request id being viewed or modified (e.g. 693484)${request_key}
- request key being viewed or modified (e.g. ABC-123)${request_project_id}
- project id being viewed or modified (e.g. 3423)${request_project_key}
- project key being viewed or modified (e.g. ABC)${request_service_desk_id}
- service_desk_id being viewed or modified (e.g. 86)${s_prj_key}
- "small" project (<10k requests per project) key being viewed or modified (e.g. ABC)${s_prj_id}
- "small" project id being viewed or modified (e.g. 123)${s_service_desk_id}
- "small" project service_desk_id being viewed or modified (e.g. 12)${s_prj_total_req}
- "small" project total requests (e.g. 444)${s_prj_all_open_queue_id}
- "small" project "all open" queue id (e.g. 44)${s_created_vs_resolved_id}
- "small" project "created vs resolved" report id (e.g. 45)${s_time_to_resolution_id}
- "small" project "time to resolution" report id (e.g. 46)${m_prj_key}
- "medium" project (>10k and <100k requests per project) key being viewed or modified (e.g. ABC)${m_prj_id}
- "medium" project id being viewed or modified (e.g. 123)${m_service_desk_id}
- "medium" project service_desk_id being viewed or modified (e.g. 12)${m_prj_total_req}
- "medium" project total requests (e.g. 444)${m_prj_all_open_queue_id}
- "medium" project "all open" queue id (e.g. 44)${m_created_vs_resolved_id}
- "medium" project "created vs resolved" report id (e.g. 45)${m_time_to_resolution_id}
- "medium" project "time to resolution" report id (e.g. 46)${username}
- the logged in username (e.g. admin)
Use or access the following variables in your customer_standalone_extension
action if needed:
${s_service_desk_id}
- "small" project (<10k requests per project) service_desk_id being viewed or modified (e.g. 12)${rt_project_id}
- project id (e.g. 12)${rt_service_desk_id}
- service_desk_id (e.g. 12)${rt_id}
- request type id for project with project id${rt_project_id}
and service_desk_id${rt_service_desk_id}
(e.g. 123)${username}
- the logged in username (e.g. admin)
{{% warning %}} App-specific actions are required. Do not proceed with the next step until you have completed app-specific actions development and got successful results from toolkit run. {{% /warning %}}
{{% warning %}} 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. {{% /warning %}}
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.
{{% warning %}} 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. {{% /warning %}}
AWS Pricing Calculator provides an estimate of usage charges for AWS services based on certain information you provide. Monthly charges will be based on your actual usage of AWS services and may vary from the estimates the Calculator has provided.
*The prices below are approximate and may vary depending on such factors like region, instance type, deployment type of DB, and other.
Stack | Estimated hourly cost ($) |
---|---|
One pod Jira Service Management DC | 1 - 2 |
Two pod Jira Service Management DC | 1.5 - 2 |
Four pod Jira Service Management DC | 2.0 - 3.0 |
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 |
---|---|
Attachments | ~2 000 000 |
Comments | ~2 000 000 |
Components | ~1 500 |
Custom fields | ~400 |
Organizations | ~300 |
Requests | ~1 000 000 |
Projects | 200 |
Screen schemes | ~500 |
Screens | ~3000 |
Users | ~21 000 |
Workflows | ~700 |
Insight Schemas | ~ 6 |
Insight Object types | ~ 50 |
Insight Schema objects | ~ 1 000 000 |
{{% note %}}
All the datasets use the standard admin
/admin
credentials.
{{% /note %}}
Below process describes how to install enterprise-scale Jira Service Management DC with "large" dataset included:
-
Create Access keys for AWS CLI: {{% warning %}} Do not use
root
user credentials for cluster creation.Option 1 (simple): create admin user with
AdministratorAccess
permissions.Option 2 (complex): create granular permission policies with policy1 and policy2.
The specific configuration relies on how you manage permissions within AWS. {{% /warning %}}
Example Option 1 with Admin user:
- Go to AWS Console -> IAM service -> Users
- Create new user -> attach policies directly ->
AdministratorAccess
- Open newly created user -> Security credentials tab -> Access keys -> Create access key -> Command Line Interface (CLI) -> Create access key
- Use
Access key
andSecret access key
in aws_envs file
Example Option 2 with granular Policies:
- Go to AWS Console -> IAM service -> Policies
- Create
policy1
with json content of the policy1 file {{% warning %}} Important: change all occurrences of123456789012
to your real AWS Account ID. {{% /warning %}} - Create
policy2
with json content of the policy2 file {{% warning %}} Important: change all occurrences of123456789012
to your real AWS Account ID. {{% /warning %}} - Go to User -> Create user -> Attach policies directly -> Attach
policy1
andpolicy2
-> 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
andSecret access key
in aws_envs file
-
Clone Data Center App Performance Toolkit locally. {{% warning %}} For annual review, always get the latest version of the DCAPT code from the master branch.
DCAPT supported versions: three latest minor version releases. {{% /warning %}}
-
Navigate to
dc-app-perfrormance-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-jsm-large
.products
-jira
jira_image_repository
-atlassian/jira-servicemanagement
- make sure to select the Jira Service Management application.jira_license
- one-liner of valid Jira Service Management 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.
{{% note %}} New trial license could be generated on my atlassian. Use
BX02-9YO1-IN86-LO5G
Server ID for generation. {{% /note %}} -
Optional variables to override:
jira_version_tag
- Jira Service Management version to deploy. Supported versions see in README.md.
-
From local terminal (Git Bash for Windows users) start the installation (~40min):
docker 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
-
Copy product URL from the console output. Product url should look like
http://a1234-54321.us-east-2.elb.amazonaws.com/jira
.
{{% note %}}
All the datasets use the standard admin
/admin
credentials.
It's recommended to change default password from UI account page for security reasons.
{{% /note %}}
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
jsm.yml
configuration file. If load configuration settings were changed for dev runs, make sure parameters were changed back to the defaults: -
In case your application relays or extends the functionality of Insight. Make sure to set
True
next to theinsight
variable.application_hostname: test_jsm_instance.atlassian.com # Jira Service Management DC hostname without protocol and port e.g. test-jsm.atlassian.com or localhost application_protocol: http # http or https application_port: 80 # 80, 443, 8080, 2990, etc secure: True # Set False to allow insecure connections, e.g. when using self-signed SSL certificate application_postfix: /jira # e.g. /jira for TerraForm deployment url like `http://a1234-54321.us-east-2.elb.amazonaws.com/jira`. Leave this value blank for url without postfix. admin_login: admin admin_password: admin load_executor: jmeter # jmeter and locust are supported. jmeter by default. concurrency_agents: 50 # number of concurrent virtual agents for jmeter or locust scenario concurrency_customers: 150 # number of concurrent virtual customers for jmeter or locust scenario test_duration: 45m ramp-up: 3m # time to spin all concurrent users total_actions_per_hour_agents: 5000 # number of total JMeter/Locust actions per hour total_actions_per_hour_customers: 15000 # number of total JMeter/Locust actions per hour insight: False # Set True to enable Insight specific tests
You'll need to run the toolkit for each test scenario in the next section.
6. Running the test scenarios from execution environment against enterprise-scale Jira Service Management Data Center
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 Jira Service Management 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:
- Make sure
jsm.yml
and toolkit code base has default configuration from themaster
branch. - Check load configuration parameters needed for enterprise-scale run: Setting up load configuration for Enterprise-scale runs.
- Check correctness of
application_hostname
,application_protocol
,application_port
andapplication_postfix
in .yml file. standalone_extension
set to 0. App-specific actions are not needed for Run1 and Run2.- AWS access keys set in
./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)
- Make sure
-
Navigate to
dc-app-performance-toolkit
folder and start tests execution:export ENVIRONMENT_NAME=your_environment_name
docker 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 jsm.yml
-
View the following main results of the run in the
dc-app-performance-toolkit/app/results/jsm/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 execution
{{% note %}}
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.
{{% /note %}}
If you are submitting a Jira Service Management app, you are required to conduct a Lucene Index timing test. This involves conducting a foreground re-index on a single-node Data Center deployment (with your app installed) and a dataset that has 1M issues.
{{% note %}} The re-index time for JSM is about ~35-45 minutes. {{% /note %}}
Benchmark your re-index time with your app installed:
-
Install the app you want to test.
-
Setup app license.
-
Select the Full re-index option.
-
Click Re-Index and wait until re-indexing is completed. {{% warning %}} Jira Service Management will be temporarily unavailable during the re-indexing process. Once the process is complete, the system will be fully accessible and operational once again. {{% /warning %}}
-
Take a screenshot of the acknowledgment screen displaying the re-index time and Lucene index timing. {{% note %}} Re-index information window is displayed on the Indexing page. If the window is not displayed, log in to Jira Service Management one more time and navigate to > System > Indexing. If you use the direct link to the Indexing page, refresh the page after the re-index is finished. {{% /note %}}
-
Attach the screenshot(s) to your ECOHELP ticket.
Performance results generation with the app installed (still use master branch):
-
Navigate to
dc-app-performance-toolkit
folder and start tests execution:export ENVIRONMENT_NAME=your_environment_name
docker 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 jsm.yml
{{% note %}}
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.
{{% /note %}}
To generate a performance regression report:
- Edit the
./app/reports_generation/performance_profile.yml
file: - Navigate locally to
dc-app-performance-toolkit
folder and run the following command from local terminal (Git Bash for Windows users) to generate reports:docker 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
- In the
./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.
The purpose of scalability testing is to reflect the impact on the customer experience when operating across multiple nodes. For this, you have to run scale testing on your app.
For many apps and extensions to Atlassian products, there should not be a significant performance difference between operating on a single node or across many nodes in Jira Service Management DC deployment. To demonstrate performance impacts of operating your app at scale, we recommend testing your Jira Service Management DC app in a cluster.
To receive scalability benchmark results for one-node Jira Service Management DC with app-specific actions:
-
Before run:
- Make sure
jsm.yml
and toolkit code base has code base with your developed app-specific actions. - Check correctness of
application_hostname
,application_protocol
,application_port
andapplication_postfix
in .yml file. - Check load configuration parameters needed for enterprise-scale run: Setting up load configuration for Enterprise-scale runs.
standalone_extension
set to non 0 and .jmx file has standalone actions implementation in case of JMeter app-specific actions.- test_1_selenium_customer_custom_action is uncommented and has implementation in case of Selenium app-specific actions.
- AWS access keys set in
./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)
- Make sure
-
Navigate to
dc-app-performance-toolkit
folder and start tests execution:export ENVIRONMENT_NAME=your_environment_name
docker 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 jsm.yml
{{% note %}}
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.
{{% /note %}}
{{% note %}}
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.
{{% /note %}}
To receive scalability benchmark results for two-node Jira Service Management DC with app-specific actions:
-
Navigate to
dc-app-perfrormance-toolkit/app/util/k8s
folder. -
Open
dcapt.tfvars
file and setjira_replica_count
value to2
. -
From local terminal (Git Bash for Windows users) start scaling (~20 min):
docker 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:export ENVIRONMENT_NAME=your_environment_name
docker 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 jsm.yml
{{% note %}}
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.
{{% /note %}}
{{% note %}}
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.
{{% /note %}}
To receive scalability benchmark results for four-node Jira Service Management DC with app-specific actions:
-
Scale your Jira Data Center deployment to 4 nodes as described in Run 4.
-
Navigate to
dc-app-performance-toolkit
folder and start tests execution:export ENVIRONMENT_NAME=your_environment_name
docker 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 jsm.yml
{{% note %}}
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.
{{% /note %}}
To generate a scalability report:
- Edit the
./app/reports_generation/scale_profile.yml
file:- For
runName: "1 Node"
, in therelativePath
key, insert the relative path to results directory of Run 3. - For
runName: "2 Nodes"
, in therelativePath
key, insert the relative path to results directory of Run 4. - For
runName: "4 Nodes"
, in therelativePath
key, insert the relative path to results directory of Run 5.
- For
- Navigate locally to
dc-app-performance-toolkit
folder and run the following command from local terminal (Git Bash for Windows users) to generate reports:docker 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
- In the
./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.
{{% warning %}} 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. {{% /warning %}}
{{% warning %}} Do not forget to attach performance testing results to your ECOHELP ticket. {{% /warning %}}
- Make sure you have two reports folders: one with performance profile and second with scale profile results.
Each folder should have
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. - Attach two reports folders to your ECOHELP ticket.
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.