Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Introduction

MettleCI

provides a comprehensive and sophisticated automated Unit Testing capability. 

enables you to rapidly (in most cases, automatically) create re-usable Unit Tests for your DataStage Jobs, feed them with data and run them. The focus of MettleCI Unit Testing is create and publish, to Git, a set of artefacts (test specifications and associated test data) that embody a definition of (used to demonstrate) your job's correct functional behaviour.  These artefacts can be propagated to downstream environments where they can be used to verify your job's consistent behaviour on DataStage platforms which may not have the same configuration, connectivity, or even DataStage version as the project in which the original job was developed.  

The Unit being tested by MettleCI's Unit Test capability is an individual DataStage job.  Unit testing is not intended to replace performance testing, nor does it support connecting to source or target databases to validate SQL queries.  Broader-scoped testing activities (typically involving database interaction) is the role of

MettleCi

MettleCI's End-to-End tests which are created, managed, and executed separately to Unit Tests. 

Sections

Child pages (Children Display)

Test Data

Test data can be derived using a number of methods, each of which may be used in combination with one another:

  1. Entered manually into the Excel-like test data file tables in MettleCI Workbench

  2. Provided as CSV file which are imported into the relevant test data file using MettleCI Workbench

  3. Fabricated using MettleCI Workbench's Data Fabrication capabilities (illustrated in the diagram above)

  4. Captured from your existing unit test data sources using MettleCI's Data Interception capabilities (see below)

Creating an Automated Unit Test

Unit tests can be created for individual jobs using the MettleCI workbench, or en masse (for all jobs in a project) using an automated build pipeline.  When MettleCI creates a unit test, using either method, it executes the following process for each job:

  1. Interrogate your job definition in the DataStage repository and identify each job's source and target stages.
  2. Read the metadata definition of each source stage input link and target stage output link.  Note that each source may supply multiple output links, and each target stage may accept multiple input links.
  3. Create an empty unit test data file for each source and target link, with appropriate columns and metadata. 
  4. Read your job's list of parameters
  5. Create a unit test specification which provides references to all of your job's parameters as well as each newly-created unit test data file.

This animation illustrates the conceptual steps MettleCI goes through to create your Unit Test: 

Multimedia
nameunit-test-create-720.mov
width640
height360

See how this is done from the MettleCI workbench here.

Capturing Unit Test Data

(Interception Description Here)

Multimedia
nameunit-test-interception-720.mov
width640
height360

See how this is done from the MettleCI workbench here.

Fabricating Unit Test Data

See how this is done from within the MettleCI workbench here.

Executing an Automated Unit Test

(Execution description here)

Multimedia
nameunit-test-run-720.mov
width640
height360

See how this is done from the MettleCI workbench here.

To create Unit Tests for your jobs you'll need to Install the MettleCI Workbench.

To intercept test data and run Unit Tests you'll need to Install the Unit Testing Harness.


Related FAQ Pages

Filter by label (Content by label)
showLabelsfalse
showSpacefalse
sorttitle
cqllabel = "unit-testing" and space = currentSpace ( ) and ancestor = "330694797"