AutomationTestItems_LoadByCriteria Operation

Applies to QAComplete 14.4, last modified on June 20, 2024
This functionality is provided by the automated testing bridge that allows obtaining TestComplete test results to the QAComplete Automation screen.
Starting from the release 9.9.0, this functionality is obsolete and is supported only for backward compatibility.

Use the AutomationTestItems_LoadByCriteria operation to:

  • Get automation test items that match a specific condition. For example, have a specific test type or created on a specific day.

  • Get all automation test items in QAComplete projects (if no condition is specified).

The operation can get test items from one or several projects. To specify a project to get test items from, use the ProjId value in the AuthenticationData object in the request body. To get test items from several projects, use the ProjIds value in the AuthenticationData object to specify the list of project IDs.

LoadByCriteria returns results in pages (subsets of data) rather than all at once. Pagination is controlled by the PageSize and PageNumber parameters. For information about working with paginated results, see LoadByCriteria Operations.

You can use the Sorting parameter to sort the automation test items before returning them from QAComplete.

To get just one item, use AutomationTestItems_Load. Also, you can use the AutomationTestItems_LoadByHostName operation to get all automation test items that use the same host.

Requirements

The authenticating user must belong to a user group that has the Read privilege for Automation Test Items.

Parameters

The operation uses the following parameters:

AuthenticationData  :  AuthenticationData, required

An AuthenticationData object with the login information and the ID of the project (or the list of project IDs) that contains the automation test items.

Condition  :  string (max 65536 chars)

An XML-formatted string that describes the automation test item you want to get. For the syntax and examples, see Condition Syntax.

If you create SOAP requests manually, place the condition string inside CDATA.

To get all automation test items, use an empty string or a null value.

Sorting  :  string (max 512 chars)

The order to sort the results before returning them from the web service. For example, by test run ID or number of failed tests. The format is:

Property1 [ASC | DESC ][, Property2 [ASC | DESC ]] [, ...]]]

where property names are those of the AutomationTestItem object. If you omit ASC or DESC after a property name, test runs are sorted in ascending order.

Example values:

AutomationTestItemId
AutomationTestParentId, AutomationTestItemId
DateCreated DESC

To keep the default sort order, use an empty string or a null value.

PageSize  :  integer, required

Limits the number of automation test items to return in one page. Possible values: 1..200.

The last page may have less items than PageSize. This means the end of the result set.

PageNumber  :  integer, required

A number starting from 1 that specifies the data page to return in the response. To get all pages, send several requests with increasing PageNumber values. For example, if PageSize is 100, PageNumber of 1 will return items 1..100, PageNumber of 2 – items 101..200 and so on.

If PageNumber exceeds the range, an empty array is returned. If PageNumber is the last page, this page may have less items than PageSize.

Result

An array of AutomationTestItem objects that contain information about automation test items.

Example

Sample Code

This example loads all runs of the specified test set.

C#

string login = "[email protected]";
string password = "p@ssword";
int projID = 10372;

// Specifying the condition
string condition =
@"<Conditions xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance'
              xmlns:xsd='http://www.w3.org/2001/XMLSchema'
              Operation='opEQU'>
  <Items Type='tField'>
    <Value xsi:type='xsd:string'>AutomationType</Value>
  </Items>
  <Items Type='tString'>
    <Value xsi:type='xsd:string'>TestComplete</Value>
  </Items>
</Conditions>";
string Sorting = "";
int pageSize = 200;

ServiceSoapClient service = new ServiceSoapClient();

// Preparing AuthenticationData
LoginInfo loginInfo = service.GetLoginInfo("", login, password);
AuthenticationData authData = new AuthenticationData();
authData.AppCode = loginInfo.AppCode;
authData.UserId = loginInfo.UserId;
authData.PassCode = password;
authData.DeptId = loginInfo.DeptId;
authData.ProjId = projID;

AutomationTestItem[] automationTestItems = new AutomationTestItem[0];
int pageNumber = 1;
do
{
  automationTestItems = service.AutomationTestItems_LoadByCriteria(authData, condition, Sorting, pageSize, pageNumber);
  foreach (AutomationTestItem automationTestItem in automationTestItems)
  {
    Console.WriteLine("Loaded automation test item: {0}", automationTestItem.TestName);
    }
} while (automationTestItems.Length == pageSize);

Java

String login = "[email protected]";
String password = "p@ssword";
int projID = 10372;

// Specifying the desired condition
String condition =
"<Conditions xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' \n" +
"            xmlns:xsd='http://www.w3.org/2001/XMLSchema'\n" +
"            Operation='opEQU'>\n" +
"  <Items Type='tField'>\n" +
"    <Value xsi:type='xsd:string'>AutomationType</Value>\n" +
"  </Items>\n" +
"  <Items Type='tString'>\n" +
"    <Value xsi:type='xsd:string'>TestComplete</Value>\n" +
"  </Items>\n" +
"</Conditions>\n";

int pageSize = 200;
String sorting = "";

ServiceSoap service = new Service().getServiceSoap12();

// Preparing AuthenticationData
LoginInfo loginInfo = service.getLoginInfo("", login, password);
AuthenticationData authData = new AuthenticationData();
authData.setAppCode(loginInfo.getAppCode());
authData.setUserId(loginInfo.getUserId());
authData.setPassCode(password);
authData.setDeptId(loginInfo.getDeptId());
authData.setProjId(projID);

// Preparing an array of AutomationTestItem objects
List<AutomationTestItem> automationTestItems;
int pageNumber = 1;

do
{
  automationTestItems = service.automationTestItemsLoadByCriteria(authData, condition, sorting, pageSize, pageNumber).getAutomationTestItem();
  for (AutomationTestItem automationTestItem : automationTestItems)
  {
    System.out.format("Loaded automation test item: %s%n", automationTestItem.getTestName());
  }
  pageNumber++;
} while (automationTestItems.size() == pageSize);

Sample Request XML

POST /psws/psws.asmx HTTP/1.1
Host: myteam.mysite.com
Content-Type: text/xml; charset=utf-8
Content-Length: 1059 {Insert an appropriate value here}
SOAPAction: "http://www.pragmaticsw.com/AutomationTestItems_LoadByCriteria"
 

<?xml version="1.0" encoding="utf-8"?>
<soap:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
  <soap:Body>
    <AutomationTestItems_LoadByCriteria xmlns="http://www.pragmaticsw.com/">
      <AuthenticationData>
        <AppCode>agSP</AppCode>
        <DeptId>7154</DeptId>
        <ProjId>1032</ProjId>
        <UserId>25315</UserId>
        <PassCode>p@ssword</PassCode>
      </AuthenticationData>
      <Condition>
        <![CDATA[<Conditions xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance'
                             xmlns:xsd='http://www.w3.org/2001/XMLSchema'
                             Operation='opEQU'>
          <Items Type='tField'>
            <Value xsi:type='xsd:string'>AutomationType</Value>
          </Items>
          <Items Type='tString'>
            <Value xsi:type='xsd:string'>TestComplete</Value>
          </Items>
        </Conditions>]]>
      
</Condition>
      <Sorting></Sorting>
      <PageSize>200</PageSize>
      <PageNumber>1</PageNumber>
    </AutomationTestItems_LoadByCriteria>
  </soap:Body>
</soap:Envelope>

SOAP 1.2

POST /psws/psws.asmx HTTP/1.1
Host: myteam.mysite.com
Content-Type: application/soap+xml; charset=utf-8
Content-Length: 1067 {Insert an appropriate value here}
 

<?xml version="1.0" encoding="utf-8"?>
<soap12:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap12="http://www.w3.org/2003/05/soap-envelope">
  <soap12:Body>
    <AutomationTestItems_LoadByCriteria xmlns="http://www.pragmaticsw.com/">
      <AuthenticationData>
        <AppCode>agSP</AppCode>
        <DeptId>7154</DeptId>
        <ProjId>1032</ProjId>
        <UserId>25315</UserId>
        <PassCode>p@ssword</PassCode>
      </AuthenticationData>
      <Condition>
        <![CDATA[<Conditions xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance'
                             xmlns:xsd='http://www.w3.org/2001/XMLSchema'
                             Operation='opEQU'>
          <Items Type='tField'>
            <Value xsi:type='xsd:string'>AutomationType</Value>
          </Items>
          <Items Type='tString'>
            <Value xsi:type='xsd:string'>TestComplete</Value>
          </Items>
        </Conditions>]]>
      
</Condition>
      <Sorting></Sorting>
      <PageSize>200</PageSize>
      <PageNumber>1</PageNumber>
    </AutomationTestItems_LoadByCriteria>
  </soap12:Body>
</soap12:Envelope>

Sample Response XML

HTTP/1.1 200 OK
Content-Type: text/xml; charset=utf-8
Content-Length: 1621 {The server returns an appropriate value here}
 

<?xml version="1.0" encoding="utf-8"?>
<soap:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
  <soap:Body>
    <AutomationTestItems_LoadByCriteriaResponse xmlns="http://www.pragmaticsw.com/">
      <AutomationTestItems_LoadByCriteriaResult>
        <AutomationTestItem>
          <AutomationTestItemId>5</AutomationTestItemId>
          <AutomationHostId>1</AutomationHostId>
          <AutomationHostName>Test-WinXPx86</AutomationHostName>
          <TestType>Automation Tests</TestType>
          <FullPath>\\Test-WinXPx86\Work\Tests\Release\Project.pjs</FullPath>
          <Description>Test input controls on Windows XP</Description>
          <AutomationType>TestComplete</AutomationType>
          <ProjId>10372</ProjId>
          <CreateUserId>24661</CreateUserId>
          <UpdateUserId>24661</UpdateUserId>
          <DateCreated>2014-07-29T13:24:18:027</DateCreated>
          <DateUpdated>2014-07-29T13:24:18:027</DateUpdated>
        </AutomationTestItem>
        <AutomationTestItem>
          <AutomationTestItemId>6</AutomationTestItemId>
          <AutomationHostId>2</AutomationHostId>
          <AutomationHostName>Test-WinVistax64</AutomationHostName>
          <TestType>Automation Tests</TestType>
          <FullPath>\\Test-WinVistax64\Work\Tests\Release\Project.pjs</FullPath>
          <Description>Test input controls on Windows Vista</Description>
          <AutomationType>TestComplete</AutomationType>
          <ProjId>10372</ProjId>
          <CreateUserId>24661</CreateUserId>
          <UpdateUserId>24661</UpdateUserId>
          <DateCreated>2014-07-29T13:57:24:067</DateCreated>
          <DateUpdated>2014-07-29T13:57:24:067</DateUpdated>
        </AutomationTestItem>
      </AutomationTestItems_LoadByCriteriaResult>
    </AutomationTestItems_LoadByCriteriaResponse>
  </soap:Body>
</soap:Envelope>

SOAP 1.2

HTTP/1.1 200 OK
Content-Type: application/soap+xml; charset=utf-8
Content-Length: 1631 {The server returns an appropriate value here}
 

<?xml version="1.0" encoding="utf-8"?>
<soap12:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap12="http://www.w3.org/2003/05/soap-envelope">
  <soap12:Body>
    <AutomationTestItems_LoadByCriteriaResponse xmlns="http://www.pragmaticsw.com/">
      <AutomationTestItems_LoadByCriteriaResult>
        <AutomationTestItem>
          <AutomationTestItemId>5</AutomationTestItemId>
          <AutomationHostId>1</AutomationHostId>
          <AutomationHostName>Test-WinXPx86</AutomationHostName>
          <TestType>Automation Tests</TestType>
          <FullPath>\\Test-WinXPx86\Work\Tests\Release\Project.pjs</FullPath>
          <Description>Test input controls on Windows XP</Description>
          <AutomationType>TestComplete</AutomationType>
          <ProjId>10372</ProjId>
          <CreateUserId>24661</CreateUserId>
          <UpdateUserId>24661</UpdateUserId>
          <DateCreated>2014-07-29T13:24:18:027</DateCreated>
          <DateUpdated>2014-07-29T13:24:18:027</DateUpdated>
        </AutomationTestItem>
        <AutomationTestItem>
          <AutomationTestItemId>6</AutomationTestItemId>
          <AutomationHostId>2</AutomationHostId>
          <AutomationHostName>Test-WinVistax64</AutomationHostName>
          <TestType>Automation Tests</TestType>
          <FullPath>\\Test-WinVistax64\Work\Tests\Release\Project.pjs</FullPath>
          <Description>Test input controls on Windows Vista</Description>
          <AutomationType>TestComplete</AutomationType>
          <ProjId>10372</ProjId>
          <CreateUserId>24661</CreateUserId>
          <UpdateUserId>24661</UpdateUserId>
          <DateCreated>2014-07-29T13:57:24:067</DateCreated>
          <DateUpdated>2014-07-29T13:57:24:067</DateUpdated>
        </AutomationTestItem>
      </AutomationTestItems_LoadByCriteriaResult>
    </AutomationTestItems_LoadByCriteriaResponse>
  </soap12:Body>
</soap12:Envelope>

See Also

AutomationTestItems_Add
AutomationTestItems_Delete
AutomationTestItems_Load
AutomationTestItems_LoadByHostName
AutomationTestItems_Update
Automated Testing Bridge Operations
SOAP API Reference

Highlight search results