JetClient Library

The jc Object

The majority of the functionality within the JetClient JavaScript API is accessed through the jc.* object. This object provides access to request and response data, variables, and more. For detailed type definitions, see JetClient Library Types.

Using Variables in Scripts

Use the jc.variables methods to access and manage variables at different scopes and setting runtime variables.

To check if a variable exists in the current scope:

jc.variables.has("variableName")

To get the value of a variable by its name:

jc.variables.get("variableName")

To set a runtime variable:

jc.variables.set("variableName", "variableValue")

To replace all variables in a string with their actual values:

jc.variables.replaceIn("Hi, my name is {{myName}}")

Global Variables

Use the jc.globals methods to access and manipulate global variables that are available regardless of the selected environment.

To verify if a global variable exists:

jc.globals.has("variableName")

To get the value of a global variable:

jc.globals.get("variableName")

To replace all variables in a string with their actual values:

jc.globals.replaceIn("Welcome, {{userName}}")

To set a global variable:

jc.globals.set("variableName", "variableValue")

To delete a global variable:

jc.globals.unset("variableName")

To clear all global variables:

jc.globals.clear()

Environment Variables

Use the jc.environment methods to access and manage variables within a specific environment. If no environment group is specified, the Default group is used.

To check if a variable exists in the active environment:

jc.environment.has("variableName", "envGroup")

To get the value of an environment variable:

jc.environment.get("variableName", "envGroup")

To replace all environment variables in a string with their actual values:

jc.environment.replaceIn("Server URL is {{baseUrl}}", "envGroup")

To set or update a variable in the active environment:

jc.environment.set("variableName", "variableValue", "envGroup")

To remove a variable from the active environment:

jc.environment.unset("variableName", "envGroup")

To clear all variables in the active environment:

jc.environment.clear("envGroup")

Folder Variables

Utilize the jc.folderVariables methods to access and manipulate folder variables in your scripts.

To verify if a folder contains a specific variable:

jc.folderVariables.has("variableName")

To get the value of a variable:

jc.folderVariables.get("variableName")

To replace all variables in a string with their actual values:

jc.folderVariables.replaceIn("Hi, my name is {{myName}}")

To set a local folder variable:

jc.folderVariables.set("variableName", "variableValue")

To set a variable within the active environment of a specific environment group in the folder (defaults to the ‘Default’ environment group if none specified):

jc.folderVariables.setEnv("variableName", "variableValue", "envGroup");

To delete a specific folder variable:

jc.folderVariables.unset("variableName")

To delete a variable from the active environment of a specific environment group in the folder (defaults to the ‘Default’ environment group if no group is specified):

jc.folderVariables.unsetEnv("variableName", "envGroup");

To clear all local variables in the folder:

jc.folderVariables.clear()

Scripting with request and response data

jc.request and jc.response objects provide access to request and response data.

Scripting with request data

The jc.request object provides access to the data for the request the script is running within. For a Pre-request Script this is the request that’s about to run, and for a Test script this is the request that has already run.

You can use the jc.request object in pre-request scripts to alter various parts of the request configuration before it runs.

The jc.request object provides multiple methods for accessing and manipulating request data. See JetClient Library Types for type definitions.

Scripting with response data

The jc.response object provides access to the data returned in the response for the current request in scripts added to the Tests. The jc.response object provides the following properties and methods:

The response status code:

jc.response.code

The status text string:

jc.response.status

The response headers:

jc.response.headers

The time the response took to receive in milliseconds:

jc.response.responseTime

The size of the response received:

jc.response.responseSize

The response text:

jc.response.text()

The response body as a JSON object:

jc.response.json()

Sending Requests from Scripts

The jc.sendRequest method allows you to send requests asynchronously from Pre-request or Test scripts. This method returns a promise that resolves to the response object.

Using HttpRequest Builder

Create a request object with the HttpRequest builder and pass it to jc.sendRequest:

jc.sendRequest(new HttpRequest()
        .setUrl("https://httpbin.org/anything")
        .setMethod("GET"))
        .then((response) => {
          console.log(response.json());
        });

Using a JavaScript Object

Alternatively, create a request using a JavaScript object:

jc.sendRequest({
  url: "https://httpbin.org/anything",
  method: "GET"
})
.then((response) => {
  console.log(response.json());
});

Using an Existing Request Object

You can also utilize an existing request object retrieved with jc.findRequest:

const response = await jc.sendRequest(
    jc.findRequest("/folderName/requestName")
      .addQueryParam('param', 'paramValue')
      .setBodyJson({key: 'value'}));
console.log(response.json());

Important Notes

jc.sendRequest returns a promise that resolves to the response object. Handle the response synchronously with the await keyword or asynchronously with the then and catch methods.

When using the jc.sendRequest method, associated Pre-request and Test scripts are not executed. To ensure these scripts are run, use the jc.runRequest method.

Running Requests, Folders, and Test Suites from Scripts

jc.runRequest is used to execute requests along with their associated Pre-request and Test scripts, as well as those of their parent folders.

Use jc.runFolder to execute all requests within a specified folder and its subfolders, including their respective scripts:

await jc.runFolder("/parentFolder/childFolder")

Similarly, jc.runTestSuite allows you to execute test suites:

await jc.runTestSuite("/folder/TestSuiteName")

Writing Test Assertions

Use jc.test to write test specifications within Pre-request or Test scripts. Each test should include a name and assertion(s). JetClient will then output the test results as part of the response.

jc.test("response should be okay to process", () => {
  jc.response.to.not.be.error
  jc.response.to.have.jsonBody()
  jc.response.to.not.have.jsonBody('error')
})

The jc.expect method allows you to write more detailed assertions on your response data, utilizing the ChaiJS expect BDD syntax.

jc.expect(jc.response.code).to.be.eq(200)

You can also use jc.response.to.have.* and jc.response.to.be.* to build your assertions.

Using External Libraries

The require function enables the use of external libraries in your scripts. JetClient comes with built-in libraries such as ajv, atob, btoa, chai, cheerio, crypto-js, csv-parse/lib/sync, lodash, moment, tv4, uuid, and xml2js, all of which you can import using require.

Additionally, you can add your own libraries to the scripts. Navigate to Settings > Tools > JetClient and set the Libraries directory. If you are using npm libraries, specify the directory containing your package.json and node_modules. Otherwise, set the directory where your script libraries are located. You can then use require to import your libraries.