Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 8 Next »

Introduction

MettleCI provides a comprehensive and sophisticated automated Unit Testing capability.  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's End-to-End tests which are created, managed, and executed separately to Unit Tests. 


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: 

Error rendering macro 'multimedia' : com.atlassian.renderer.v2.macro.MacroException: Cannot find attachment 'unittest-480.mov'

See how this is done from the MettleCI workbench here.


Capturing Unit Test Data

(Interception Description Here)

(Interception animation here)

See how this is done from the MettleCI workbench here.


Fabricating Unit Test Data

(Fabrication Description Here)

(Fabrication animation here)

See how this is done from the MettleCI workbench here.


Executing an Automated Unit Test

(Execution description here)

Error rendering macro 'multimedia' : com.atlassian.renderer.v2.macro.MacroException: Cannot find attachment 'unittest-480.mov'

See how this is done from the MettleCI workbench here.

  • No labels