JQL Functions


The following JQL functions are available for querying Xray issues in the Issue Search Page. They enable you to query the relationships between Xray issue types. 


JQL FunctionParametersDescriptionExample
testTestSetP1 - Test Issue KeyReturns a list of Test Set issues associated with the input Test issue key.
issuetype = 'Test Set' 
   and key in testTestSet('DEMO-1')
testSetTestsP1 - Test Set Issue Key/Filter of Test SetsReturns a list of Test issues associated with the input Test Set issue key.
(1) 
issuetype = 'Test'  and key in testSetTests('DEMO-5')
(2) 
issuetype = 'Test' 
   and key in testSetTests('Test sets saved filter')
testsWithNoTestSetP1 - Saved filter Name/IDReturns a list of Test issues not associated with a Test Set.
(1) 
issue in testsWithNoTestSet()
(2) 
issue in testsWithNoTestSet("saved_filter")
testPreConditionsP1 - Test Issue KeyReturns the Pre-Condition issues associated with the input Test issue key.
issuetype = 'Pre-Condition' 
   and key in testPreConditions('DEMO-1')
preConditionTestsP1 - Pre-Condition Issue KeyReturns the Test issues associated with the input Pre-Condition issue key.
issuetype = 'Test' 
   and key in preConditionTests('DEMO-1')
testRequirementsP1 - Test Issue Key/Filter name of Tests
Returns a list of Requirement issues associated with the input Test issue key/Filter of tests.
(1)
issuetype = 'Feature' 
   and key in testRequirements('DEMO-1')

(2)

issuetype = 'Feature'
   and key in testRequirements('Tests saved filter')
requirementTestsP1 - Requirement Issue Key/Filter of Requirement IssuesReturns a list of Test issues associated with the input Requirement issue key or saved filter with Requirements.
(1)
issuetype = 'Test' 
   and key in requirementTests('DEMO-10')
(2)
issuetype = 'Test' 
   and key in requirementTests('Requirements saved filter')
testsWithReqVersion

P1 - Project Name/Key/Id

P2 - Fix Version 

P3 - Fix Version (Optional)

...

Pn - Fix Version (Optional)

Returns a list of Test issues associated with the Requirement issues of the input Fix Versions of the specified project.
issuetype = 'Test' 
   and issue in 
   testsWithReqVersion('DEMO', 
                       'v1.0', 'v1.1')
testsWithTestSetVersion

P1 - Project Name/Key/Id

P2 - Fix Version 

P3 - Fix Version (Optional)

...

Pn - Fix Version (Optional)

Returns a List of Test issues associated with the Test Set issues of the input Fix Versions of the specified project.
issuetype = 'Test' 
   and issue in 
   testsWithTestSetVersion( 'DEMO', 
                           'v1.0', 'v1.1')
testExecutionTests

P1 - Test Execution Issue Key/Id or Filter ID

P2 - Test Run Status list separated by "|"(pipe) (Optional)

P3 - User assigned to execute Test Run (Optional).

P4 - Defects Flag with value in true or false (optional).

P5 - User who executed the Test Run (optional).

Returns a List of Test issues associated with the input Test Execution issues from P1 optionally filtered by the current test run status for each Test issue.

Parameter P1 can either be a single Test Execution issue key, an ID or a saved filter containing multiple Test Execution issues.

Possible Test Run Status values are: PASS, FAIL, EXECUTING, ABORTED, TODO and all custom statuses.

P3 corresponds to the user assigned to execute the Test Run, while P5 corresponds to the one who actually executed it. For analyzing the joint values of all Test Run Assignees, "" should be used. For taking into account the Test Runs without any Assignee, then "__NULL__" should be used.

If you pass true as the value for P4, the query returns all Tests from a particular set of Test Executions where no Defects were created.

(1)
issuetype = 'Test' 
   and issue in testExecutionTests('DEMO-9')

(2)

issuetype = 'Test' 
   and issue in testExecutionTests('DEMO-9', 
                                   'PASS')

(3)

issuetype = 'Test' 
   and issue in testExecutionTests('DEMO-9', 
                                   'PASS', 
                                    'user A')

(4)

issuetype = 'Test' 
   and issue in testExecutionTests(
                      'Saved Test Execution Filter', 
                      'PASS')

(5)

issuetype = 'Test' 
   and issue in testExecutionTests(
                      'Saved Test Execution Filter', 
                      '',
                      'user A')

(6)

issue in testExecutionTests(
                      'Saved Test Execution Filter', 
                      '',
                      'user A', 'true')

(7)

issue in testExecutionTests(
                      'Saved Test Execution Filter', 
                      '','', 'false', 'admin')
testsWithoutTestExecutionP1 - Saved filter Name/IDReturns a list of Tests that are not associated with a Test Execution to be executed
(1)
issuetype = Test and issue in testsWithoutTestExecution()
(2)
issuetype = Test and issue in testsWithoutTestExecution("saved_filter")
requirements

P1 - Status list separated by "|"(pipe)

P2 - Project (Optional)

P3 - Version to calculate requirement status (Optional)

P4 - Test Environment (Optional)

P5 - Flat (Optional)

P6 - ToDate (Optional)

P7 - Saved Filter (Optional)


Returns a list of Requirement Issues with the provided coverage status.

Please provide Project parameter (P2) to restrict the requirements to the specified project.


If analyzing on a specific version, then the Project and Version parameters must be filled.


Optional filters include:

Test Environment, for taking into account the Test Executions made for that environment. For analyzing the joint values of all environments, "" should be used. For taking into account the Test Executions without any Test Environment assigned, then "__NULL__" should be used.

Flat that indicates whether all Requirements (not only parents) should be searched. If "Flat" is not provided, the default value is 'false'.

ToDate considers only those requirements executions before a specific date/time (the date literal must follow the ISO8601 format).

Saved Filters considers only requirements from that specific filter.

(1)
issue in requirements('OK','Calculator')


Please note

Although optional, it is highly recommended to specify the Project parameter as means to define the project having the requirments and thus reduce the amount of issues that will be processed/returned. Otherwise, requirements from all JIRA projects will be processed, which possibly is something that you don't want or need at all.


(2)
priority = Major and fixVersion <= 'v3.0' and
   issue in requirements('NOK', 'Calculator', 'V4.0')
(3)
issue in 
   requirements('NOK', '', '', '', '','2014-01-01')
(4)
issue in 
   requirements('OK',
             'Calculator',  
             'v1.0',
             'chrome' 
             'false'
             '2014-08-30')
(5)
issue in 
   requirements('NOK',
             'Calculator',  
             'v2.0',
'',
             'true')
(6)
issue in
requirements('NOK',
'Calculator',
'v2.0',
'chrome',
'false',
' ',
'Requirements saved filter')

requirementsWithStatusByTestPlan

P1 - Status list separated by "|"(pipe)

P2 - Test Plan Issue Key

P3 - Test Environment (Optional)

P4 - Flat (Optional)

P5 - ToDate (Optional)

P6 - Project (Optional)

P7 - Saved Filter (Optional)


Returns a list of Requirement Issues with the coverage status calculated for the given Test Plan issue.


Optional filters include:

Test Environment, for taking into account the Test Executions made for that environment. For analyzing the joint values of all environments, "" should be used. For taking into account the Test Executions without any Test Environment assigned, then "__NULL__" should be used.

Flat that indicates whether all Requirements (not only parents) should be searched. If "Flat" is not provided, the default value is 'false'.

ToDate considers only those requirements executions before a specific date/time (the date literal must follow the ISO8601 format).

Project and Saved Filters considers only requirements from that specific project or filter.

(1)
issue in 
    requirementsWithStatusByTestPlan('OK', 'TP-123')
(2)
issue in 
    requirementsWithStatusByTestPlan('NOK', 
                                    'TP-123',
                                    '',
                                    'true')

(3)

issue in 
    requirementsWithStatusByTestPlan('NOK', 
                                    'TP-123', 
                                    'Android',
                                    'false',
                                    '2014-01-01')
(4)
issue in
    requirementsWithStatusByTestPlan('NOK',
'TP-123',
'Android',
'false',
' ',
'Calculator',
'Requirements saved filter')

defectsCreatedDuringTesting

P1 - Test Issue Key/Filter of Test IssuesReturn a list of defects created during the execution of the specified Tests.
(1)
issue in defectsCreatedDuringTesting()
(2) 
issue in defectsCreatedDuringTesting("TEST-123") 
(3) 
issue in defectsCreatedDuringTesting("saved_filter")
defectsCreatedDuringTestExecution

P1 - Test Execution issue Key or Test Execution based Filter

P2 - List of users separated by "|" (pipe). (Optional)

Returns a list of Defects created during the execution of the specified Test Executions; can optionally be filtered by the Defect Issue Assignee username.

(1) issue in 
   defectsCreatedDuringTestExecution(TEST-123)
(2) issue in 
   defectsCreatedDuringTestExecution(saved_filter)
(3) issue in 
   defectsCreatedDuringTestExecution(saved_filter, 'user1|user2')
(4) issue in 
   defectsCreatedDuringTestExecution(TEST-123, 'user1|user2')
 

defectsCreatedForRequirement

P1 - Requirement key or saved filterReturns a list of defects created during the execution of Tests covering the specified requirements.
(1) 
issue in defectsCreatedForRequirement("REQ-123")
(2) 
issue in defectsCreatedForRequirement("saved_filter")
manualTestsWithoutStepsP1 - Saved filter Name/IDReturns a list of manual tests that have no test steps.
(1) 
issue in manualTestsWithoutSteps()
(2) 
issue in manualTestsWithoutSteps("saved_filter")
testTestExecutions 

P1 - Test Issue Key/Id or Filter Name/Id

P2 - Test Run Status list separated by "|"(pipe) (Optional)

Returns a list of test executions associated with the input Test Issues from P1 optionally filtered by the current Test status in each Test Execution issue.

Parameter P1 can either be a single Test issue key or Id or a saved filter name or id containing multiple Test issues.

Possible Test Run Status values are: PASS, FAIL, EXECUTING, ABORTED, TODO and all custom statuses.

(1)
issuetype = 'Test Execution' 
   and issue in testTestExecutions('DEMO-9')

(2)

issuetype = 'Test Execution' 
   and issue in testTestExecutions('DEMO-9', 
                                   'PASS')

(3)

issuetype = 'Test Execution' 
   and issue in testTestExecutions(
                      'Saved Test Filter', 
                      'PASS')
testExecWithTestRunsAssignedToUser 

P1 - Username (Optional)

P2 - Status (Optional) Username is required in case we use this parameter

Returns a list of test executions where a user has at least one test run assigned to him. You can optionally specify a user with P1, or if the user is omitted the current user will be used. Note that if you are not logged in to JIRA, a user must be specified.

If you use status parameter then user is required

(1)

issuetype = 'Test Execution' and
  issue in testExecWithTestRunsAssignedToUser()

(2)

issuetype = 'Test Execution' and
  issue in testExecWithTestRunsAssignedToUser('userDPC')

(3)

issuetype = 'Test Execution' and
  issue in testExecWithTestRunsAssignedToUser('userDPC', "FAIL")
testSetPartiallyIn
P1 - Test Execution Issue Key/Test Plan Issue Key/Id or Filter IdReturn a list of Test Sets that have at least one test in P1.

(1)

issuetype = 'Test Set' and
  issue in testSetPartiallyIn('DEMO-15')

(2)

issuetype = 'Test Set' and
  issue in testSetPartiallyIn('testExecList')

(3)

issuetype = 'Test Set' and
  issue in testSetPartiallyIn('testPlanList')
testSetFullyIn
P1 - Test Execution Issue Key/Test Plan Issue Key/Id or Filter IdReturn a list of Test Sets that have all its tests in P1.

(1)

issuetype = 'Test Set' and
  issue in testSetFullyIn('DEMO-15')

(2)

issuetype = 'Test Set' and
  issue in testSetFullyIn('testExecList')

(3)

issuetype = 'Test Set' and
  issue in testSetFullyIn('testPlanList')
testPlanTests

P1 - Test Plan Key/Filter of Test Plans

P2 - Status (Optional)

P3 - Environment (Optional)

Returns a list of tests that are associated with the test plan.

The "status" parameter is optional and allows to filter Test issues in a specific Plan with the specified execution status. If the "status" parameter is present, users might also pass the "environment" parameter. If this parameter is filled, Xray will provide all Tests in a Test Plan that are in the specified "status" and for the specified "environment".

(1)

issue in testPlanTests("DEMO-10")
(2)
issue in testPlanTests("Test Plans saved filter","TODO")

(3)

issue in testPlanTests("DEMO-10","TODO")

(4)

issue in testPlanTests("DEMO-10","TODO","IOS")


When searching for Tests with a certain status inside a Test Plan, we recommend you to use the custom field search instead.


Xray has created a new way of searching with big improvements when filtering by test status, using the Custom Fields:
(3)
issuetype = Test and TestRunStatus = "DEMO-10 - TODO"
(4)
issuetype = Test and TestRunStatus = "DEMO-10 - TODO environment:IOS"



testPlanTestExecutionsP1 - Test Plan Key/Filter of Test Plans

Returns a list of test executions that are associated with a Test Plan or a saved filter of Test Plans.

(1)
issue in testPlanTestExecutions("DEMO-10")

(2)

issue in testPlanTestExecutions("Test Plans saved filter")

testPlanRequirements

P1 - Test Plan Key/Filter of Test PlansReturns the Requirement issues that are indirectly associated, through Test issues, with a Test Plan or a saved filter of Test Plans.

(1)

issue in testPlanRequirements("DEMO-20")
(2)
issue in testPlanRequirements("Test Plans saved filter")

testTestPlanP1 - Test Issue KeyReturns a List of Test Plan issues associated with the input Test issue key.
issuetype = 'Test Plan' 
   and key in testTestPlan('DEMO-1')

testRepositoryFolderTests

P1 - Project Key

P2 - Folder Path

P3 - Flatten (Optional)

Returns the list of Tests contained in a folder (P2) of the Test Repository of a Project (P1)

May optionally include the Tests in sub-folders by setting Flatten (P3) to "true".

(1)

issue in testRepositoryFolderTests("CALC", 'Parent/Child')

(2)

issue in testRepositoryFolderTests("CALC", 'Parent/Child', "true")

testPlanFolderTests

P1 - Test Plan Key

P2 - Folder Path

P3 - Flatten (Optional)

P4 - Test Run Status (Optional)

P5 - Test Environment (Optional)

Returns the list of Tests contained in a folder (P2) of a Test Plan (P1).

May optionally include the Tests in sub-folders by setting Flatten (P3) to "true".

Can also filter by Tests Run Status (P4) for a given Test Environment (P5).

To analyze the joint values of all Test Environments, "" should be used. To analyze the Test Executions without any Test Environment assigned, then "__NULL__" should be used.


(1)

issue in testPlanFolderTests(CALC-10, 'Parent/Child')

(2)

issue in testPlanFolderTests(CALC-10, 'Parent/Child', "true")

(3)

issue in testPlanFolderTests(CALC-10, 'Parent/Child', "true", "TODO|FAIL", "windows")

projectParentRequirementsP1 - Project KeyReturns the list of Requirement issues, from a given Project, which are not Sub-requirements(1) issue in projectParentRequirements("CALC")


Custom Fields


Xray also provides custom fields to allow more refined queries when searching for issues.


JQL FunctionIssue TypeDescriptionExample
Test TypeTestThe Test type: Manual; Cucumber; Generic
issuetype = 'Test' 
   and "Test Type" = "Manual"
TestRunStatusTest

This is a calculated custom field that provides the latest Test Run status based on the current "Test Run Status Version Strategy" option configured in the Xray administration.


Syntax:  TestRunStatus = "[Group (version or TestPlan)] - [Status] environment:[environment]"

Only the Status is mandatory; if only the status is provided, Xray will assume you are searching for the latest execution

Xray will lookup for all Tests with Status in that particular version and environment.

Read more about Status and environments.

Test Run Status

The latest Test Run Status is calculated based on the latest final Test Run (i.e., latest finish date) or, in case there are no final Test Runs, the latest non-final Test Run (i.e., latest start date). Please see the custom fields preferences page.
issuetype = 'Test' 
   and TestRunStatus in ("FAIL", "ABORTED")

_

issuetype = 'Test' 
and TestRunStatus = "PASS"

_

issuetype = 'Test' 
   and TestRunStatus = "TESTPLAN-123 - PASS"

_

issuetype = 'Test' 
   and TestRunStatus = "FAIL environment:Android"

-
issuetype = 'Test' 
   and TestRunStatus = "v3.0 - PASS environment:Android"

_

issuetype = 'Test' 
   and TestRunStatus = "TESTPLAN-123 - PASS environment:Android"

_

issuetype = 'Test' 
   and TestRunStatus is EMPTY
Requirement StatusRequirement

This is a calculated custom field that provides the requirement coverage status.

Possible status values are:

OK - All tests passed the requirement

NOK - At least one test failed

NOTRUN - At least one test did not run

UNCOVERED - The requirements is not associated with tests

testTestExecutions 


Syntax: "Requirement Status" = "[Group (version or TestPlan)] - [Status] environment:[environment]"

Only the Status is mandatory; if only the status is provided, Xray will assume you are searching for the latest execution

Xray will lookup for all Requirements with Status in that particular version and environment.

Read more about Status and environments.


Requirement Coverage

For more information, please check out our page dedicated to requirements coverage.

If the Requirements Coverage Strategy depends on the version, then you must also include the actual version name and the status when you do the search. The syntax: "[version name] - [status]"



issuetype = 'New Feature' 
   and "Requirement Status" = "OK"
_
issuetype = 'New Feature' 
   and "Requirement Status" in ("NOTRUN", "UNCOVERED")

_

issuetype = 'New Feature' 
and "Requirement Status" = "v1.0 - OK"
-
issuetype = 'New Feature' 
   and "Requirement Status" = "v1.0 - OK environment:Android"
Steps CountTestThe number of Steps in a Manual Test
issuetype = 'Test' 
   and "Steps Count" = 3
Manual Test StepsTestFind Tests by text present in the Manual Test Steps fields
issuetype = 'Test' 
   and "Manual Test Steps" ~ "Login with user administrator"



The Test Set Status and Test Plan Status custom fields, mentioned in Custom Fields, are not queryable.