OnAfterTestRun Trigger


The content in this topic only applies to Microsoft Dynamics NAV 2009 SP1. For Microsoft Dynamics NAV 2009 content, see Developer and IT Pro Help for Microsoft Dynamics NAV 2009.

Executes after a test function of a test codeunit has been run.

OnAfterTestRun(CodeunitID : Integer;CodeunitName : Text[30];FunctionName : Text[30];Success : Boolean)



Type: Integer

The ID of the codeunit that has run.


Type: Text

The name of the test codeunit that has run.


Type: Text

The name of the test function that has run.


This parameter is empty when the OnAfterTestRun trigger is called for the entire test codeunit.


Type: Boolean

true indicates that the test function run succeeded. false indicates that the test function run failed.

Test runner codeunits. Test runner codeunits have the SubType Property (Codeunit) set to TestRunner.


This trigger is optional and not available on a test runner codeunit by default. To implement this trigger, you must manually add it as a function.

A test runner codeunit manages the execution of test codeunits that are run from its OnRun function. When a test codeunit runs, it executes each test function one at a time in the codeunit. When implemented, the OnAfterTestRun trigger is called after each test function has run and after the entire test codeunit has run.

The OnAfterTestRun trigger suppresses the automatic display of the results message after the test codeunit runs.


To return the error message for a failed test function run, use the GETLASTERRORTEXT Function.

You can use the OnAfterTestRun trigger to perform postprocessing, such as logging, or to automate tests by integrating the test runner codeunit with a test management framework.

The OnAfterTestRun trigger is run in its own database transaction.

For more information, see Testing the Application and How to: Create a Test Runner Codeunit.

The following OnAfterTestRun trigger code logs test results to a test reporting system. This example requires that you create a record variable named log.

log.UnitId := CodeunitId;
log.Unit := CodeunitName;
log.Func := FunctionName;
log.Before := Before;
If Success THEN
  log.Status := log.Status::Success
  log.Status := log.Status::Failure;
  IF FunctionName <> '' THEN
    log.Message := GETLASTERRORTEXT;

The GETLASTERRORTEXT function returns the text that was contained in the last error message.

Community Additions