Sltest Ref
Sltest Ref
Reference
R2020b
How to Contact MathWorks
Phone: 508-647-7000
             Functions
1
               Classes
2
              Methods
3
                Blocks
4
    Language Operators
5
                    iii
            1
Functions
1     Functions
            disp
            Display results of sltest.AssessmentSet or sltest.Assessment
            Syntax
            disp(as)
            Description
            disp(as) displays the results of the assessment object as.
Examples
disp(as)
                  sltest.Assessment
                  Package: sltest
                  Properties:
                         Name:   'Simulink:verify_high'
                    BlockPath:   [1×1 Simulink.SimulationData.BlockPath]
                       Values:   [1×1 timeseries]
                       Result:   Fail
            Input Arguments
            as — Assessment object
            sltest.Assessment | sltest.AssessmentSet
            See Also
            sltest.Assessment | sltest.AssessmentSet | sltest.getAssessments
Introduced in R2016b
1-2
                                                                                            Test Manager
Test Manager
Model and code testing in different execution environments, manage test suites, and analyze and
report results
Description
You can use the Test Manager to create test cases for Simulink models and code in desktop, SIL,
PIL, and HIL (for target computers running Simulink Real-Time™) execution environments. You can
create or import test data, run tests, view results, and create reports.
You can group test cases into test suites, which are saved in a test file. The types of test you can
create are simulation tests, equivalence (back-to-back) tests to compare models or generated code,
and baseline tests to compare model output to a known baseline. You can run tests directly on your
model or use test harnesses, which keep the test environment separate from your model. See “Test
Harness and Model Relationship”.
• Test inputs
• Test outputs, such as logged signals and states
• Baseline criteria for baseline tests
• Iterations to run different combinations of inputs, parameters, baseline criteria, etc.
• Temporal and logical assessments of simulation behavior
• Model parameter and configuration overrides
• Callbacks to run before and after loading the model
• Coverage settings to measure the extent to which model or code execution paths are exercised
• Link requirements to the tests that verify them
Note If your model or test harness contains a To Workspace block, the block variable is not saved in
the base workspace after the test finishes running. Upon test completion, the base workspace is
restored to its original state.
                                                                                                    1-3
1     Functions
            In the Test Manager, the test sections in the Test Browser pane contain the options for the test. For
            descriptions of the options, see “Test Sections”.
            Examples
            •         “Capture Simulation Data in a Test Case”
            •         “Create and Run a Back-to-Back Test”
            •         “Create and Run a Baseline Test”
            •         “Create a Test Harness”
            •         “View Test Case Results”
1-4
                                           Test Manager
See Also
Topics
“Capture Simulation Data in a Test Case”
“Create and Run a Back-to-Back Test”
“Create and Run a Baseline Test”
“Create a Test Harness”
“View Test Case Results”
Introduced in R2015a
                                                   1-5
1     Functions
            find
            Find assessments in sltest.AssessmentSet or sltest.Assessment object
            Syntax
            asout = find(as,'PropertyName','PropertyValue')
            asout = find(as,'PropertyName1','PropertyValue1','–logical','PropertyName2',
            'PropertyValue2'...)
            asout = find(as,'–regexp','PropertyName','PropertyValue')
            Description
            asout = find(as,'PropertyName','PropertyValue') returns the results asout specified by
            the properties matching 'PropertyName', and 'PropertyValue'.
            asout = find(as,'PropertyName1','PropertyValue1','–logical','PropertyName2',
            'PropertyValue2'...) returns the results asout specified by multiple 'PropertyName',
            'PropertyValue' pairs, and the '–logical' operator specifying the connective between the
            pairs. '–logical' can be '–and' or '–or'.
Examples
            This example shows how to simulate a model with verify statements and obtain assessment results
            via the programmatic interface.
open_system('sltestRollRefTestExample.slx')
1-6
                                                              find
asSummary =
       Total:   6
    Untested:   3
      Passed:   2
      Failed:   1
      Result:   Fail
  sltest.Assessment
  Package: sltest
                                                              1-7
1     Functions
                  Properties:
                         Name:   'Simulink:verify_high'
                    BlockPath:   [1x1 Simulink.SimulationData.BlockPath]
                       Values:   [1x1 timeseries]
                       Result:   Fail
            asFailUntested = find(as,'Result',slTestResult.Fail,'-or',...
                'Result',slTestResult.Untested)
asFailUntested =
                  sltest.AssessmentSet
                  Summary:
                       Total: 4
                    Untested: 3
                      Passed: 0
                      Failed: 1
                      Result: Fail
4. Find assessments under the Test Assessment block, using a regular expression.
assessBlock = find(as,'-regexp','BlockPath','.[Aa]ssess')
assessBlock =
                  sltest.AssessmentSet
                  Summary:
                       Total: 6
                    Untested: 3
                      Passed: 2
                      Failed: 1
                      Result: Fail
1-8
                                                                                                  find
Re-enable warnings
warning on Stateflow:Runtime:TestVerificationFailed
Input Arguments
as — Assessment object
sltest.Assessment | sltest.AssessmentSet
Property value to search, specified as a character vector. Can be a regular expression when using the
'–regexp' argument.
When using the 'Result' property name, 'PropertyValue' is an enumeration of the assessment
result:
Example: slTestResult.Fail
Example: '[Aa]sess'
                                                                                                  1-9
1   Functions
          Output Arguments
          asout — Assessment results output
          sltest.assessmentSet object
          Assessment results output from the find operation, specified as an sltest.assessmentSet object.
          Example: sltest.AssessmentSet
          See Also
          sltest.Assessment | sltest.AssessmentSet | sltest.getAssessments
Introduced in R2016b
1-10
                                                                                             get
get
Get assessment of sltest.AssessmentSet
Syntax
indexResult = get(as,index)
Description
indexResult = get(as,index) gets the individual assessment result indexResult from the
sltest.AssessmentSet as, specified by the integer index.
Examples
This example shows how to simulate a model with verify statements and obtain assessment results
via the programmatic interface.
open_system('sltestRollRefTestExample.slx')
                                                                                           1-11
1   Functions
s = sim('sltestRollRefTestExample');
as = sltest.getAssessments('sltestRollRefTestExample');
as3 = get(as,3);
asSummary = getSummary(as)
asSummary =
                     Total:    6
                  Untested:    3
                    Passed:    2
                    Failed:    1
                    Result:    Fail
disp(as3)
                sltest.Assessment
                Package: sltest
                Properties:
                       Name:   'Simulink:verify_high'
                  BlockPath:   [1x1 Simulink.SimulationData.BlockPath]
                     Values:   [1x1 timeseries]
                     Result:   Fail
          asFailUntested = find(as,'Result',slTestResult.Fail,'-or',...
              'Result',slTestResult.Untested)
asFailUntested =
                sltest.AssessmentSet
                Summary:
                     Total: 4
                  Untested: 3
                    Passed: 0
                    Failed: 1
                    Result: Fail
1-12
                                                                                                   get
4. Find assessments under the Test Assessment block, using a regular expression.
assessBlock = find(as,'-regexp','BlockPath','.[Aa]ssess')
assessBlock =
  sltest.AssessmentSet
  Summary:
       Total: 6
    Untested: 3
      Passed: 2
      Failed: 1
      Result: Fail
Re-enable warnings
warning on Stateflow:Runtime:TestVerificationFailed
Input Arguments
as — Assessment set from which to get a single assessment
sltest.AssessmentSet
                                                                                              1-13
1   Functions
          See Also
          sltest.Assessment | sltest.AssessmentSet | sltest.getAssessments
Introduced in R2016b
1-14
                                                                                     getSummary
getSummary
Get summary of sltest.AssessmentSet
Syntax
testOut = getSummary(as)
Description
testOut = getSummary(as) gets the summary testOut of the sltest.AssessmentSet as.
Examples
This example shows how to simulate a model with verify statements and obtain assessment results
via the programmatic interface.
                                                                                           1-15
1   Functions
s = sim('sltestRollRefTestExample');
as = sltest.getAssessments('sltestRollRefTestExample');
as3 = get(as,3);
asSummary = getSummary(as)
asSummary =
                    Total:   6
                 Untested:   3
                   Passed:   2
                   Failed:   1
                   Result:   Fail
disp(as3)
                sltest.Assessment
                Package: sltest
                Properties:
                       Name:   'Simulink:verify_high'
                  BlockPath:   [1x1 Simulink.SimulationData.BlockPath]
                     Values:   [1x1 timeseries]
                     Result:   Fail
          asFailUntested = find(as,'Result',slTestResult.Fail,'-or',...
              'Result',slTestResult.Untested)
asFailUntested =
                sltest.AssessmentSet
                Summary:
                     Total: 4
                  Untested: 3
                    Passed: 0
                    Failed: 1
                    Result: Fail
1-16
                                                                                   getSummary
4. Find assessments under the Test Assessment block, using a regular expression.
assessBlock = find(as,'-regexp','BlockPath','.[Aa]ssess')
assessBlock =
  sltest.AssessmentSet
  Summary:
       Total: 6
    Untested: 3
      Passed: 2
      Failed: 1
      Result: Fail
Re-enable warnings
warning on Stateflow:Runtime:TestVerificationFailed
Input Arguments
as — Assessment set from which to get a summary
sltest.AssessmentSet
Output Arguments
testOut — Assessment summary
struct
                                                                                        1-17
1   Functions
          See Also
          sltest.Assessment | sltest.AssessmentSet | sltest.getAssessments
Introduced in R2016b
1-18
                                                                             sltest.getAssessments
sltest.getAssessments
Returns test assessment set object
Syntax
as = sltest.getAssessments(model)
Description
as = sltest.getAssessments(model) returns as, an sltest.AssessmentSet from
assessments in model. Simulate the model before getting the assessment results.
• verify statements
• Blocks in the Model Verification library
Examples
This example shows how to simulate a model with verify statements and obtain assessment results
via the programmatic interface.
open_system('sltestRollRefTestExample.slx')
                                                                                            1-19
1   Functions
asSummary =
                     Total:   6
                  Untested:   3
                    Passed:   2
                    Failed:   1
                    Result:   Fail
                sltest.Assessment
                Package: sltest
1-20
                                                                                   sltest.getAssessments
  Properties:
         Name:    'Simulink:verify_high'
    BlockPath:    [1x1 Simulink.SimulationData.BlockPath]
       Values:    [1x1 timeseries]
       Result:    Fail
asFailUntested = find(as,'Result',slTestResult.Fail,'-or',...
    'Result',slTestResult.Untested)
asFailUntested =
  sltest.AssessmentSet
  Summary:
       Total: 4
    Untested: 3
      Passed: 0
      Failed: 1
      Result: Fail
4. Find assessments under the Test Assessment block, using a regular expression.
assessBlock = find(as,'-regexp','BlockPath','.[Aa]ssess')
assessBlock =
  sltest.AssessmentSet
  Summary:
       Total: 6
    Untested: 3
      Passed: 2
      Failed: 1
      Result: Fail
                                                                                                  1-21
1   Functions
Re-enable warnings
warning on Stateflow:Runtime:TestVerificationFailed
          See Also
          sltest.Assessment | sltest.AssessmentSet
          Topics
          “Examine Model Verification Results by Using Simulation Data Inspector”
Introduced in R2016b
1-22
                                                                              sltest.harness.check
sltest.harness.check
Compare component under test between harness model and main model
Syntax
[CheckResult,CheckDetails] = sltest.harness.check(harnessOwner,harnessName)
Description
[CheckResult,CheckDetails] = sltest.harness.check(harnessOwner,harnessName)
computes the checksum of the component under test in the harness model harnessName and
compares it to the checksum of the component harnessOwner in the main model, returning the
overall CheckResult and additional CheckDetails of the comparison. You cannot use
sltest.harness.check on Subsystem models test harnesses.
Examples
Compare Component Under Test Between Model and Harness
This example shows how to compare a component under test between the main model and the test
harness. Comparing the component under test can help you determine if the CUT contains
unsynchronized changes.
Check the Controller subsystem in the f14 model against the Controller subsystem in a test
harness.
CheckResult = logical
   1
                                                                                            1-23
1   Functions
                contents: 1
                  reason: 'The checksum of the harnessed component and the component in the main model are sa
          clear('CheckResult','CheckDetails');
          close_system('f14',0);
          Input Arguments
          harnessOwner — Model or component
          character vector | double
          Output Arguments
          CheckResult — Result of comparison
          true | false
          The result of the component comparison between the harness model and the system model, returned
          as true or false.
          Details of the check operation, returned as a structure. Structure fields contain the comparison
          results for the overall component, the component contents, the component interface, and a reason for
          the comparison result. If sltest.harness.check returns false, rebuild the test harness and retry
          sltest.harness.check.
          See Also
          sltest.harness.close | sltest.harness.create | sltest.harness.delete |
          sltest.harness.export | sltest.harness.find | sltest.harness.load |
          sltest.harness.open | sltest.harness.push | sltest.harness.rebuild |
          sltest.harness.set
1-24
                       sltest.harness.check
Introduced in R2015a
                                     1-25
1   Functions
          sltest.harness.clone
          Copy test harness
          Syntax
          sltest.harness.clone(HarnessOwner,HarnessName)
          sltest.harness.clone(HarnessOwner,HarnessName,NewHarness)
          sltest.harness.clone(HarnessOwner,HarnessName,Name,Value)
          Description
          sltest.harness.clone(HarnessOwner,HarnessName) clones the test harness HarnessName
          associated with the model or component HarnessOwner. The cloned harness contains the source
          harness model contents, configuration settings, and callbacks.
Examples
          Create a test harness ControllerHarness1 for the Controller subsystem of the model f14.
          Clone the harness and save it as ControllerHarness2.
          f14
          sltest.harness.create('f14/Controller','Name',...
              'ControllerHarness1','SynchronizationMode',...
              'SyncOnOpenAndClose')
          sltest.harness.clone('f14/Controller',...
              'ControllerHarness1','ControllerHarness2')
          Clone the test harness ControllerHarness1 created in the previous step to the Aircraft
          Dynamics Model subsystem and save it as ControllerHarnessClone.
          sltest.harness.clone('f14/Controller',...
             'ControllerHarness1','DestinationOwner',...
             'f14/Aircraft Dynamics Model','Name',...
             'ControllerHarnessClone')
          Input Arguments
          HarnessOwner — Model or component
          character vector | double
1-26
                                                                                       sltest.harness.clone
Example: 1.9500e+03
Example: 'f14'
Example: 'f14/Controller'
The name of the cloned harness, specified as a character vector. If no value is specified, a default
value is automatically generated.
Example: 'ControllerHarness2'
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Example: 'DestinationOwner','model3/Controller3','Name','newClonedHarness'
Owner block to which the test harness is cloned, specified as the comma-separated pair consisting of
'DestinationOwner' and a character vector.
Example: 'DestinationOwner','model3/Controller3'
The name of the cloned test harness, specified as the comma-separated pair consisting of 'Name' and
a character vector. If no value is specified for Name, a default value is automatically generated.
Example: 'Name','newClonedHarness'
See Also
sltest.harness.check | sltest.harness.close | sltest.harness.create |
sltest.harness.delete | sltest.harness.export | sltest.harness.find |
sltest.harness.load | sltest.harness.open | sltest.harness.push |
sltest.harness.rebuild | sltest.harness.set
Introduced in R2015b
                                                                                                       1-27
1   Functions
          sltest.harness.close
          Close test harness
          Syntax
          sltest.harness.close(modelName)
          sltest.harness.close(harnessOwner)
          sltest.harness.close(harnessOwner,harnessName)
          Description
          sltest.harness.close(modelName) closes the open test harness associated with the model
          modelName.
          sltest.harness.close(harnessOwner) closes the open test harness associated with the model
          or component harnessOwner.
Examples
          Close the test harness named controller_harness, associated with the subsystem Controller in
          the model f14.
          f14;
          sltest.harness.create('f14/Controller',...
             'Name','sample_controller_harness');
          sltest.harness.open('f14/Controller',...
             'sample_controller_harness');
          sltest.harness.close('f14/Controller',...
             'sample_controller_harness');
          Close the test harness named sample_harness, which is associated with the model f14.
          f14;
          sltest.harness.create('f14','Name','sample_harness');
          sltest.harness.open('f14','sample_harness');
          sltest.harness.close('f14','sample_harness');
          Input Arguments
          modelName — Model name
          character vector | double
1-28
                                                                                sltest.harness.close
See Also
sltest.harness.check | sltest.harness.create | sltest.harness.delete |
sltest.harness.export | sltest.harness.find | sltest.harness.load |
sltest.harness.open | sltest.harness.push | sltest.harness.rebuild |
sltest.harness.set
Introduced in R2015a
                                                                                              1-29
1   Functions
          sltest.harness.convert
          Convert test harnesses between internal and external storage
          Syntax
          sltest.harness.convert(modelName)
          sltest.harness.convert(modelName,conversion)
          Description
          sltest.harness.convert(modelName) converts the test harnesses storage type for modelName.
Examples
sltest.harness.convert('f14','ExternalToInternal')
          Input Arguments
          modelName — Model name
          character vector
          See Also
          sltest.harness.check | sltest.harness.close | sltest.harness.create |
          sltest.harness.delete | sltest.harness.export | sltest.harness.open
Introduced in R2016a
1-30
                                                                                 sltest.harness.create
sltest.harness.create
Create test harness
Syntax
sltest.harness.create(harnessOwner)
sltest.harness.create(harnessOwner,Name,Value)
Description
sltest.harness.create(harnessOwner) creates a test harness for the model component
harnessOwner, using default properties.
Examples
Create harness for the f14 model. The harness is called sample_harness and has a Signal Builder
block source and a scope sink.
f14;
sltest.harness.create('f14','Name','sample_harness','Source',...
'Signal Builder','Sink','Scope')
f14;
sltest.harness.create('f14/Controller');
Create a harness that uses a Stateflow® Chart as the test harness scheduler for the Controller
subsystem of the f14 model.
f14;
sltest.harness.create('f14/Controller','SchedulerBlock','Chart');
Input Arguments
harnessOwner — Model or component
character vector | double
                                                                                                 1-31
1   Functions
          Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
          Value is the corresponding value. Name must appear inside quotes. You can specify several name and
          value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
          Example: 'Name','controller_harness','Source','Signal Builder','Sink','To File'
          specifies a harness named controller_harness, with a signal builder block source and To File
          block sinks for the component under test.
          The name for the harness you create, specified as the comma-separated pair consisting of 'Name'
          and a valid MATLAB file name.
          Example: 'Name','harness_name'
          The harness description, specified as the comma-separated pair consisting of 'Description' and a
          character vector.
          Example: 'Description','A test harness'
          The input to the component, specified as the comma-separated pair consisting of 'Source' and one
          of the possible source values.
          Example: 'Source','Signal Builder'
          For a custom source, the path to the library block to use as the source, specified as the comma-
          separated pair consisting of 'CustomSourcePath' and the path.
          Example: 'CustomSourcePath','simulink/Sources/Sine Wave'
          The output of the component, specified as the comma-separated pair consisting of 'Sink' and one of
          the possible sink values.
1-32
                                                                                    sltest.harness.create
If your test harness contains a To Workspace block, the block variable is not saved in the base
workspace after the test finishes running. Upon test completion, the base workspace is restored to its
original state.
Example: 'Sink','Scope'
For a custom sink, the path to the library block to use as the sink, specified as the comma-separated
pair consisting of 'CustomSinkPath' and the path.
Example: 'CustomSinkPath','simulink/Sinks/Display'
Option to add a separate Test Assessment block to the test harness, specified as a comma-separated
pair consisting of 'SeparateAssessment' and false or true.
Example: 'SeparateAssessment',true
Option to specify when the component under test synchronizes the main model and the test harness.
Subsystem model test harnesses are always synchronized with their underlying model.
• 'SyncOnOpenAndClose' rebuilds the component under test from the main model when the test
  harness opens, and pushes changes from the component under test to the main model when the
  test harness closes.
• 'SyncOnOpen' rebuilds the component under test from the main model when the test harness
  opens. It does not push changes from the component under test to the main model when the test
  harness closes.
• 'SyncOnPushRebuildOnly' rebuilds and pushes changes only when you manually initiate
  rebuild or push for the entire test harness. For more information, see “Synchronize Changes
  Between Test Harness and Model”.
Example: 'SynchronizationMode','SyncOnOpen'
Option to specify harness creation without compiling the main model, specified as a comma-separated
pair consisting of 'CreateWithoutCompile' and false or true. This option is set to true for
Subsystem model test harnesses.
false compiles the model and runs other operations to support the harness build. true creates the
harness without model compilation.
Example: 'CreateWithoutCompile',false
                                                                                                   1-33
1   Functions
          An option to specify what type of block to use in the test harness, specified as a comma-separated
          pair consisting of 'VerificationMode' and the type of block to use. SIL and PIL blocks require
          Simulink Coder. This option is set to normal for Subsystem models.
          Example: 'VerificationMode','SIL'
          Path to main build folder of existing generated code verified using SIL/PIL, specified as a string or
          character vector. If you specify a build folder, the existing code in that folder is used, which enables
          faster harness creation time. If you do not specify a build folder, the code is regenerated.
          Example: 'ExistingBuildFolder','C:\TestMdl\SILHarness\Amplifier_ert_rtw'
          RebuildOnOpen — Sets the harness rebuild command to execute when the harness opens
          false (default) | true
          Option to have the harness rebuild when it opens, specified as the comma-separated pair consisting
          of 'UseDefaultName' and false or true. This option is set to true for Subsystem model test
          harnesses.
          Example: 'RebuildOnOpen',true
          Option to have the configuration set and model workspace entries updated during test harness
          rebuild, specified as the comma-separated pair consisting of 'RebuildModelData' and true or
          false. This option is set to true for Subsystem model test harnesses.
          Example: 'RebuildModelData',true
          Option to have each test harness saved as a separate SLX file, specified as the comma-separated pair
          consisting of 'SaveExternally' and true or false. A model cannot use both external and internal
          test harness storage. If a model already has test harnesses, a new test harness follows the storage
          type of the existing harnesses, which this option does not override. See “Manage Test Harnesses”.
          Example: 'SaveExternally',true
          If 'SaveExternally' is specified, you can specify a location for the external harness SLX file using
          a comma-separated pair consisting of 'HarnessPath' and a character vector..
          Example: 'HarnessPath','C:\MATLAB\SafetyTests'
          Use a post create callback function to customize a test harness. The post create callback function
          executes after the harness is created. For more information, see “Customize Test Harnesses”.
1-34
                                                                                    sltest.harness.create
Example: 'PostCreateCallback','HarnessCustomization'
Use a post rebuild callback function to customize a test harness. The post rebuild callback function
executes after the harness rebuild. For more information, see “Customize Test Harnesses”.
Example: 'PostRebuildCallback','HarnessCustomization'
Option to drive model initialize, reset, and terminate ports with the chosen test harness source,
specified as the comma-separated pair consisting of 'ScheduleInitTermReset' and false or
true. This option only applies to harnesses created for a block diagram. This option is set to false
for Subsystem models.
Example: 'ScheduleInitTermReset',true
SchedulerBlock — Include scheduler block for periodic signals and function calls
'Test Sequence' | 'MATLAB Function' | 'Chart' | 'None'
Option to include a scheduler block in the test harness, specified as the comma-separated pair
consisting of 'SchedulerBlock' and the type of block to use. The block is included if the test
harness is created for a model block diagram or a Model block and contains function calls or periodic
event ports. To include no scheduler block and connect all ports to harness source blocks, use
'None' .
Example: 'SchedulerBlock','Test Sequence'
Example: 'SchedulerBlock','None'
AutoShapeInputs — Match scalar and double value source to input signal dimension
false (default) | true
Option to shape scalar and double values to match the dimension of the input signals to the
component under test, specified as the comma-separated pair consisting of 'AutoShapeInputs'
and false or true. This option only applies to harnesses with Inport, Constant, Signal Builder, From
Workspace, or From File blocks. This option is set to false for Subsystem models.
Example: 'AutoShapeInputs',true
Name of reusable library subsystem function interface, specified as a string or character vector. The
test harness is created for the function interface of the reusable library subsystem.
Example: 'FunctionInterfaceName','double_RLS'
Compatibility Considerations
DriveFcnCallWithTestSequence in sltest.harness.create is not recommended
Not recommended starting in R2018b
                                                                                                   1-35
1   Functions
          Starting with the R2018b release, you can use the 'SchedulerBlock' option to include a scheduler
          block when creating a test harness. The name-value pair 'SchedulerBlock','Test Sequence'
          uses a Test Sequence scheduler block and replaces 'DriveFcnCallWithTestSequence',true.
          'SchedulerBlock' provides more scheduler options, and creates a simplified block interface
          compared to 'DriveFcnCallWithTestSequence'. To update your code, for instances of
          sltest.harness.create, replace 'DriveFcnCallWithTestSequence',true with
          'SchedulerBlock','Test Sequence'.
          See Also
          sltest.harness.check | sltest.harness.clone | sltest.harness.close |
          sltest.harness.convert | sltest.harness.delete | sltest.harness.export |
          sltest.harness.find | sltest.harness.load | sltest.harness.open |
          sltest.harness.set
Introduced in R2015a
1-36
                                                                                sltest.harness.delete
sltest.harness.delete
Delete test harness
Syntax
sltest.harness.delete(harnessOwner,harnessName)
Description
sltest.harness.delete(harnessOwner,harnessName) deletes the harness harnessName
associated with harnessOwner.
Examples
Delete the test harness controller_harness, which is associated with the Controller subsystem
in the f14 model.
f14;
sltest.harness.create('f14/Controller','Name','controller_harness');
sltest.harness.delete('f14/Controller','controller_harness');
Delete the test harness bd_harness, which is associated with the model f14.
f14;
sltest.harness.create('f14','Name','bd_harness');
sltest.harness.delete('f14','bd_harness');
Input Arguments
harnessOwner — Model or component
character vector | double
                                                                                               1-37
1   Functions
Example: 'harness_name'
          See Also
          sltest.harness.check | sltest.harness.clone | sltest.harness.close |
          sltest.harness.create | sltest.harness.export | sltest.harness.find |
          sltest.harness.load | sltest.harness.open | sltest.harness.push |
          sltest.harness.rebuild | sltest.harness.set
Introduced in R2015a
1-38
                                                                                 sltest.harness.export
sltest.harness.export
Export test harness to Simulink model
Syntax
sltest.harness.export(harnessOwner,harnessName,'Name',modelName)
Description
sltest.harness.export(harnessOwner,harnessName,'Name',modelName) exports the
harness harnessName, associated with the model or component harnessOwner, to a new Simulink
model specified by the pair 'Name',modelName.
Examples
Export the harness controller_harness, which is associated with the Controller subsystem of
the f14 model. The new model name is model_from_harness.
f14;
sltest.harness.create('f14/Controller','Name','controller_harness');
sltest.harness.export('f14/Controller','controller_harness','Name',...
'model_from_harness');
Input Arguments
harnessOwner — Model or component
character vector | double
A valid MATLAB filename for the model generated from the harness, specified as a character vector.
                                                                                                1-39
1   Functions
Example: 'harness_name'
          See Also
          sltest.harness.check | sltest.harness.clone | sltest.harness.close |
          sltest.harness.create | sltest.harness.delete | sltest.harness.find |
          sltest.harness.import | sltest.harness.load | sltest.harness.open |
          sltest.harness.push | sltest.harness.rebuild | sltest.harness.set
Introduced in R2015a
1-40
                                                                                   sltest.harness.find
sltest.harness.find
Find test harnesses in model
Syntax
harnessList = sltest.harness.find(harnessOwner)
harnessList = sltest.harness.find(harnessOwner,Name,Value)
Description
harnessList = sltest.harness.find(harnessOwner) returns a structure listing harnesses
and harness properties that exist for the component or model harnessOwner.
Examples
Find harnesses for the f14 model and its first-level subsystems. The function matches harness names
according to a regular expression.
f14;
sltest.harness.create('f14','Name','model_harness');
sltest.harness.create('f14/Controller','Name',...
   'Controller_Harness1');
harnessList = sltest.harness.find('f14',...
   'SearchDepth',1,'Name','_[Hh]arnes+',...
   'RegExp','on')
harnessList =
    model
    name
    description
    type
    ownerHandle
    ownerFullPath
    ownerType
    isOpen
    canBeOpened
    verificationMode
    saveExternally
    rebuildOnOpen
    rebuildModelData
    graphical
                                                                                                1-41
1   Functions
                origSrc
                origSink
          Input Arguments
          harnessOwner — Model or component
          character vector | double
          Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
          Value is the corresponding value. Name must appear inside quotes. You can specify several name and
          value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
          Example: 'SearchDepth',2,'Name','controller_harness' searches the model or component,
          and two lower hierarchy levels, for harnesses named controller_harness.
          Harness name to search for in the model, specified as the comma-separated pair consisting of
          'Name' and a character vector or a regular expression. You can specify a regular expression only if
          you also use the Name,Value pair 'RegExp','on'.
          Example: 'Name','sample_harness''Name','_[Hh]arnes+'
          Ability to search using a regular expression, specified as the comma-separated pair consisting of
          'RegExp' and 'off' or 'on'. When 'RegExp' is set to 'on', you can use a regular expression
          with 'Name'.
          Example: 'RegExp','on'
          Subsystem levels into harnessOwner to search for harnesses, specified as the comma-separated pair
          consisting of 'SearchDepth' and an integer. For example:
0 searches harnessOwner.
          When you do not specify SearchDepth, the function searches all levels of harnessOwner.
          Example: 'SearchDepth',1
1-42
                                                                                       sltest.harness.find
Search option to return only active harnesses, specified as the comma-separated pair consisting of
'OpenOnly' and 'off' or 'on'.
Example: 'OpenOnly','on'
Name of the function interface for the reusable library subsystem to search for, specified as a string
or character vector. Using this Name-Value pair returns a list of all harnesses for the specified
function interface.
Example: 'FunctionInterfaceName','double_RLS'
Output Arguments
harnessList — List of harnesses and properties
structure
List of harnesses and properties for the component or model harnessOwner, returned as a structure.
The structure fields are shown in the “Use RegExp to Find Harnesses for a Model Component” on
page 1-41 example.
See Also
sltest.harness.check | sltest.harness.clone | sltest.harness.close |
sltest.harness.create | sltest.harness.delete | sltest.harness.export |
sltest.harness.load | sltest.harness.open | sltest.harness.push |
sltest.harness.rebuild | sltest.harness.set
Introduced in R2015a
                                                                                                    1-43
1   Functions
          sltest.harness.import
          Import Simulink model to test harness
          Syntax
          sltest.harness.import(harnessOwner,'ImportFileName',
          importModel,'ComponentName',TestedComponent)
          sltest.harness.import(harnessOwner,'ImportFileName',
          importModel,'ComponentName',TestedComponent,Name,Value)
          Description
          sltest.harness.import(harnessOwner,'ImportFileName',
          importModel,'ComponentName',TestedComponent) creates a test harness from the Simulink
          model importModel, with a default harness name, associated with harnessOwner, with
          TestedComponent the harness component under test.
          sltest.harness.import(harnessOwner,'ImportFileName',
          importModel,'ComponentName',TestedComponent,Name,Value) uses additional Name,Value
          arguments to specify test harness properties.
Examples
          This example shows how to use sltest.harness.import to create a test harness by importing a
          standalone verification model. You create a test harness for a basic cruise control subsystem.
          The standalone model contains a Signal Builder block driving a copy of the Controller subsystem,
          with a subsystem verifying that the throttle output goes to 0 if the brake is applied for three
          consecutive time steps.
          mainModel = 'sltestBasicCruiseControl';
          harnessModel = 'sltestBasicCruiseControlHarnessModel';
load_system(mainModel)
          2. Create a test harness from the standalone model. Create the harness for subsystem Controller
          in the main model, with Controller the harness component under test.
          sltest.harness.import([mainModel '/Controller'],'ImportFileName',harnessModel,...
              'ComponentName',[harnessModel '/Controller'],'Name',...
              'VerificationSubsystemHarness')
1-44
                                                                                sltest.harness.import
close_system(mainModel,0)
Input Arguments
harnessOwner — Model or component
character vector | double
The name or path and name of the tested component in the standalone model. After import, this
component is linked to the harnessOwner component in the main model.
Example: 'Controller'
                                                                                                1-45
1   Functions
          Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
          Value is the corresponding value. Name must appear inside quotes. You can specify several name and
          value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
          Example: 'Name','harness_name','RebuildOnOpen',true
          The name for the harness you create, specified as the comma-separated pair consisting of 'Name'
          and a valid MATLAB filename.
          Example: 'Name','harness_name'
          Option to specify when the component under test synchronizes the main model and the test harness.
          Subsystem model test harnesses are always synchronized with their underlying model.
          • 'SyncOnOpenAndClose' rebuilds the component under test from the main model when the test
            harness opens, and pushes changes from the component under test to the main model when the
            test harness closes.
          • 'SyncOnOpen' rebuilds the component under test from the main model when the test harness
            opens. It does not push changes from the component under test to the main model when the test
            harness closes.
          • 'SyncOnPushRebuildOnly' rebuilds and pushes changes only when you manually initiate
            rebuild or push for the entire test harness. For more information, see “Synchronize Changes
            Between Test Harness and Model”.
Example: 'SynchronizationMode','SyncOnOpen'
          RebuildOnOpen — Sets the harness rebuild command to execute when the harness opens
          false (default) | true
          Option to have the harness rebuild when it opens, specified as the comma-separated pair consisting
          of 'UseDefaultName' and false or true. This option is set to true for Subsystem model test
          harnesses.
          Example: 'RebuildOnOpen',true
          Option to have the configuration set and model workspace entries updated during test harness
          rebuild, specified as the comma-separated pair consisting of 'RebuildModelData' and true or
          false. This option is set to true for Subsystem model test harnesses.
          Example: 'RebuildModelData',true
1-46
                                                                                  sltest.harness.import
Option to have each test harness saved as a separate SLX file, specified as the comma-separated pair
consisting of 'SaveExternally' and true or false. A model cannot use both external and internal
test harness storage. If a model already has test harnesses, a new test harness follows the storage
type of the existing harnesses, which this option does not override. See “Manage Test Harnesses”.
Example: 'SaveExternally',true
If 'SaveExternally' is specified, you can specify a location for the external harness SLX file using
a comma-separated pair consisting of 'HarnessPath' and a character vector..
Example: 'HarnessPath','C:\MATLAB\SafetyTests'
See Also
sltest.harness.clone | sltest.harness.create | sltest.harness.export |
sltest.harness.push | sltest.harness.rebuild | sltest.harness.set
Topics
“Create Test Harnesses from Standalone Models”
Introduced in R2017a
                                                                                                 1-47
1   Functions
          sltest.harness.load
          Load test harness
          Syntax
          sltest.harness.load(harnessOwner,harnessName)
          Description
          sltest.harness.load(harnessOwner,harnessName) loads the harness harnessName into
          memory. harnessName is associated with the model or component harnessOwner.
Examples
          Load the test harness controller_harness, which is associated with the Controller subsystem
          in the f14 model.
          f14;
          sltest.harness.create('f14/Controller','Name','controller_harness');
          save_system('f14');
          sltest.harness.load('f14/Controller','controller_harness');
          Input Arguments
          harnessOwner — Model or component
          character vector | double
          See Also
          sltest.harness.check | sltest.harness.close | sltest.harness.create |
          sltest.harness.delete | sltest.harness.export | sltest.harness.find |
          sltest.harness.open | sltest.harness.push | sltest.harness.rebuild |
          sltest.harness.set
1-48
                       sltest.harness.load
Introduced in R2015a
                                    1-49
1   Functions
          sltest.harness.move
          Move test harness from linked instance to library block or to a different harness owner
          Syntax
          sltest.harness.move(HarnessOwner,HarnessName)
          sltest.harness.move(HarnessOwner,HarnessName,NewPath)
          sltest.harness.move(HarnessOwner,HarnessName,Name,Value)
          Description
          sltest.harness.move(HarnessOwner,HarnessName) moves the test harness HarnessName
          associated with the block HarnessOwner from the linked instance to its reference library block.
          Moving the test harness removes it from the linked instance. This command results in an error if
          HarnessName is not a linked instance.
Examples
          Move the test harness Baseline_controller_tests from the linked instance of the Controller
          subsystem to the library subsystem.
          % Open the model
          open_system sltestHeatpumpLibraryLinkExample
          % Move the test harness
          sltest.harness.move('sltestHeatpumpLibraryLinkExample/Controller',...
          'Baseline_controller_tests')
          Move the test harness Requirements_Tests from the linked instance of the Controller
          subsystem to the Plant subsystem and save it as Requirements_Tests_Moved.
          sltest.harness.move...
             ('sltestHeatpumpLibraryLinkExample/Controller',...
             'Requirements_Tests','DestinationOwner',...
             'sltestHeatpumpLibraryLinkExample/Plant',...
             'Name','Requirements_Tests_Moved')
          Input Arguments
          HarnessOwner — Model or component name
          character vector | double
1-50
                                                                                       sltest.harness.move
The destination path of the moved test harness, specified as a character vector.
Example: 'model_name/Subsystem2'
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Example: 'DestinationOwner','model3/Controller3','Name','newMovedHarness'
Owner block to which the test harness is moved, specified as the comma-separated pair consisting of
'DestinationOwner' and a character vector.
Example: 'DestinationOwner','model3/Controller3'
The name of the moved test harness, specified as the comma-separated pair consisting of 'Name' and
a character vector. If a value is not specified for Name, the name of the test harness is used by default.
Example: 'Name','newMovedHarness'
See Also
sltest.harness.close | sltest.harness.create | sltest.harness.delete |
sltest.harness.find | sltest.harness.open
Introduced in R2016a
                                                                                                    1-51
1   Functions
          sltest.harness.open
          Open test harness
          Syntax
          sltest.harness.open(harnessOwner,harnessName)
          Description
          sltest.harness.open(harnessOwner,harnessName) opens the harness harnessName, which
          is associated with the model or component harnessOwner.
Examples
          Open the test harness controller_harness, which is associated with the Controller subsystem
          in the f14 model.
          f14;
          sltest.harness.create('f14/Controller','Name','controller_harness');
          sltest.harness.open('f14/Controller','controller_harness');
Open the test harness sample_harness, which is associated with the f14 model.
          f14;
          sltest.harness.create('f14','Name','sample_harness');
          sltest.harness.open('f14','sample_harness');
          Input Arguments
          harnessOwner — Model or component
          character vector | double
1-52
                                                                    sltest.harness.open
Example: 'harness_name'
See Also
sltest.harness.check | sltest.harness.close | sltest.harness.create |
sltest.harness.delete | sltest.harness.export | sltest.harness.find |
sltest.harness.load | sltest.harness.push | sltest.harness.rebuild |
sltest.harness.set
Introduced in R2015a
                                                                                 1-53
1   Functions
          sltest.harness.push
          Push test harness workspace entries and configuration set to model
          Syntax
          sltest.harness.push(harnessOwner,harnessName)
          Description
          sltest.harness.push(harnessOwner,harnessName) pushes the configuration parameter set
          and workspace entries associated with the component under test from the test harness harnessName
          to the main model containing the model or component harnessOwner. Subsystem model test
          harnesses always push.
Examples
          Push the parameters of the harness controller_harness, which is associated with the
          Controller subsystem in the f14 model, to the f14 model.
          f14;
          sltest.harness.create('f14/Controller','Name','controller_harness');
          sltest.harness.push('f14/Controller','controller_harness')
          Input Arguments
          harnessOwner — Model or component
          character vector | double
          See Also
          sltest.harness.check | sltest.harness.close | sltest.harness.create |
          sltest.harness.delete | sltest.harness.export | sltest.harness.find |
          sltest.harness.load | sltest.harness.open | sltest.harness.rebuild |
          sltest.harness.set
1-54
                       sltest.harness.push
Introduced in R2015a
                                    1-55
1   Functions
          sltest.harness.rebuild
          Rebuild test harness and update workspace entries and configuration parameter set based on main
          model
          Syntax
          sltest.harness.rebuild(harnessOwner,harnessName)
          Description
          sltest.harness.rebuild(harnessOwner,harnessName) rebuilds the test harness
          harnessName based on the main model containing harnessOwner. The function transfers the
          configuration set and workspace entries associated with harnessOwner to the test harness
          harnessName. The function also rebuilds conversion subsystems in the test harness. If you specified
          to use existing generated code for a SIL/PIL subsystem using sltest.harness.create or
          sltest.harness.set, the harness rebuild uses that code instead of regenerating it. Subsystem
          model test harnesses always rebuild.
Examples
          Rebuild the harness controller_harness, which is associated with the Controller subsystem in
          the f14 model.
          f14;
          sltest.harness.create('f14/Controller','Name','controller_harness');
          sltest.harness.rebuild('f14/Controller','controller_harness');
          Input Arguments
          harnessOwner — Model or component
          character vector | double
1-56
                                                                   sltest.harness.rebuild
See Also
sltest.harness.check | sltest.harness.close | sltest.harness.create |
sltest.harness.delete | sltest.harness.export | sltest.harness.find |
sltest.harness.load | sltest.harness.open | sltest.harness.push |
sltest.harness.set
Introduced in R2015a
                                                                                   1-57
1   Functions
          sltest.harness.set
          Change test harness property
          Syntax
          sltest.harness.set(harnessOwner,harnessName,Name,Value)
          Description
          sltest.harness.set(harnessOwner,harnessName,Name,Value) changes a property, specified
          by one Name,Value pair argument, for the test harness harnessName owned by the model or
          component harnessOwner.
Examples
This example shows how to change the name of a test harness using sltest.harness.set.
Load the f14 model and create a test harness for the Controller subsystem.
          load_system('f14')
          sltest.harness.create('f14/Controller','Name','Harness1')
sltest.harness.set('f14/Controller','Harness1','Name','ControllerHarness')
close_system('f14',0)
          Input Arguments
          harnessOwner — Model or component
          character vector | double
1-58
                                                                                     sltest.harness.set
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Example: 'Name','updated_harness' specifies a new harness name 'updated_harness'.
The new name for the harness, specified as the comma-separated pair consisting of 'Name' and a
valid MATLAB filename.
Example: 'Name','new_harness_name'
The new description for the harness, specified by the comma-separated pair consisting of
'Description' and a character vector.
Example: 'Description','An updated test harness'
Option to specify when the component under test synchronizes the main model and the test harness.
Subsystem model test harnesses are always synchronized with their underlying model.
• 'SyncOnOpenAndClose' rebuilds the component under test from the main model when the test
  harness opens, and pushes changes from the component under test to the main model when the
  test harness closes.
• 'SyncOnOpen' rebuilds the component under test from the main model when the test harness
  opens. It does not push changes from the component under test to the main model when the test
  harness closes.
• 'SyncOnPushRebuildOnly' rebuilds and pushes changes only when you manually initiate
  rebuild or push for the entire test harness. For more information, see “Synchronize Changes
  Between Test Harness and Model”.
Example: 'SynchronizationMode','SyncOnOpen'
RebuildOnOpen — Sets the harness rebuild command to execute when the harness opens
false (default) | true
Option to have the harness rebuild when it opens, specified as the comma-separated pair consisting
of 'UseDefaultName' and false or true. This option is set to true for Subsystem model test
harnesses.
Example: 'RebuildOnOpen',true
                                                                                                 1-59
1   Functions
          Path to main build folder of existing generated code verified using SIL/PIL, specified as a string or
          character vector. If you specify a build folder, the existing code in that folder is used, which enables
          faster harness creation time. If you do not specify a build folder, the code is regenerated.
          Example: 'ExistingBuildFolder','C:\TestMdl\SILHarness\Amplifier_ert_rtw'
          Option to have the configuration set and model workspace entries updated during test harness
          rebuild, specified as the comma-separated pair consisting of 'RebuildModelData' and true or
          false. This option is set to true for Subsystem model test harnesses.
          Example: 'RebuildModelData',true
          RebuildWithoutCompile — Sets the harness to rebuild without compiling the main model
          false (default) | true
          Option to rebuild the harness without compiling the main model, in which cached information from
          the most recent compile is used to update the test harness workspace, and conversion subsystems
          are not updated, specified as the comma-separated pair consisting of 'RebuildWithoutCompile'
          and true or false.
          Example: 'RebuildWithoutCompile',true
          Use a post rebuild callback function to customize a test harness. The post rebuild callback function
          executes after the harness rebuild. For more information, see “Customize Test Harnesses”.
          Example: 'PostRebuildCallback','HarnessCustomization'
          Name of the function interface to associate with the harness, specified as a string or character vector.
          This option applies only to reusable library components with function interfaces.
          Example: 'FunctionInterfaceName','double_RLS'
          See Also
          sltest.harness.check | sltest.harness.close | sltest.harness.create |
          sltest.harness.delete | sltest.harness.export | sltest.harness.find |
          sltest.harness.load | sltest.harness.open | sltest.harness.push |
          sltest.harness.rebuild
Introduced in R2015a
1-60
                                                                                 sltest.import.sldvData
sltest.import.sldvData
Create test cases from Simulink Design Verifier results
Syntax
[owner,testHarness,testFile] = sltest.import.sldvData(dataFile)
[owner,testHarness,testFile] = sltest.import.sldvData(dataFile,'TestCase',
testcase)
[owner,testHarness,testFile] = sltest.import.sldvData(dataFile,Name,Value)
Description
[owner,testHarness,testFile] = sltest.import.sldvData(dataFile) creates a test
harness and test file using Simulink Design Verifier™ analysis results contained in dataFile. The
function returns the model component owner associated with the test case, the testHarness, and
the testFile.
[owner,testHarness,testFile] = sltest.import.sldvData(dataFile,'TestCase',
testcase) uses the specified test case for the import operation.
[owner,testHarness,testFile] = sltest.import.sldvData(dataFile,Name,Value)
uses additional options specified by one or more Name,Value pair arguments.
Examples
Create a test file and test harness for the ShiftLogic subsystem in the sldvdemo_autotrans model.
The inputs reflect the analysis objectives.
Analyze the ShiftLogic subsystem with Simulink Design Verifier to generate test inputs for subsystem
coverage. The results data file is ShiftLogic_sldvdata.mat.
[component,harness,testfile] = ...
   sltest.import.sldvData...
   ('./sldv_output/ShiftLogic/ShiftLogic_sldvdata.mat',...
   'TestHarnessName','CoverageHarness',...
   'TestFileName','CoverageTests')
sltest.harness.open(component,harness)
open(testfile)
                                                                                                 1-61
1   Functions
Create Test Cases for ShiftLogic Subsystem Using an Existing Test Harness
          Create a test file and test harness for the ShiftLogic subsystem in the sldvdemo_autotrans model,
          using an existing test harness.
          Analyze the ShiftLogic subsystem with Simulink Design Verifier to generate test inputs for subsystem
          coverage. The results data file is ShiftLogic_sldvdata.mat. The existing test harness is named
          DatafileHarness.
          [component,harness,testfile] = sltest.import.sldvData...
          ('./sldv_output/ShiftLogic/ShiftLogic_sldvdata.mat',...
          'TestHarnessName','DatafileHarness','TestFileName','CoverageTests',...
          'CreateHarness',false)
sltest.harness.open(component,harness)
open(testfile)
          Input Arguments
          dataFile — Data file full path name
          character vector | string scalar
          Path and file name of the data file generated by Simulink Design Verifier analysis, specified as a
          character vector or string scalar.
          Example: 'ShiftLogic0/ShiftLogic0_sldvdata.mat'
          Example: 'Controller_sldvdata.mat'
Full path name of test case to use, specified as a character vector or string scalar.
          Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
          Value is the corresponding value. Name must appear inside quotes. You can specify several name and
          value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
          Example: 'TestHarnessName','DatafileHarness','CreateHarness',false
          Option to add a test harness to the model or model component, which corresponds to the test cases in
          the test file, specified as a comma-separated pair consisting of 'CreateHarness' and true or
          false.
If you specify true, use a new test harness name with the 'TestHarnessName' name-value pair.
1-62
                                                                                   sltest.import.sldvData
If you specify false, use an existing test harness name with the 'TestHarnessName' name-value
pair.
Note If the model under analysis is a test harness, the CreateHarness default value is false.
Example: 'CreateHarness',false
The test harness used for running the test cases, specified as the comma-separated pair consisting of
'TestHarnessName' and the name of a test harness.
Use a new test harness name if 'CreateHarness' is true and an existing test harness name if
'CreateHarness' is false.
Example: 'TestHarnessName','ModelCoverageTestHarness'
The source of the new test harness, specified as the comma-separated pair consisting of
'TestHarnessSource' and 'Inport' or 'Signal Builder'.
Use a new test harness name if 'CreateHarness' is true and an existing test harness name if
'CreateHarness' is false.
Example: 'TestHarnessName','ModelCoverageTestHarness'
The name for the test file created for the test cases, specified as the comma-separated pair consisting
of 'TestFileName' and the name of a test file.
Example: 'TestFileName','ModelCoverageTests'
The path to the model extracted from Simulink Design Verifier analysis, specified as the comma-
separated pair consisting of 'ExtractedModelPath' and a path.
Simulink Test uses the extracted model to generate the test harness. By default,
sltest.import.sldvData looks for the extracted model in the output folder specified in the
Design Verifier configuration parameters. Use ExtractedModelPath if the extracted model is in a
different location.
Simulink Design Verifier does not use an extracted model when you analyze a top-level model. When
you generate test cases for a top-level model, Simulink Test does not use 'ExtractedModelPath'.
Example: 'Tests/ExtractedModels/'
                                                                                                   1-63
1   Functions
          See Also
          Topics
          “Increase Coverage by Generating Test Inputs”
Introduced in R2015b
1-64
                                                                           sltest.testmanager.clear
sltest.testmanager.clear
Clear test files from the Test Manager
Syntax
sltest.testmanager.clear
Description
sltest.testmanager.clear clears all test files from the Simulink Test Test Manager. Changes to
unsaved test files are not saved.
Examples
See Also
sltest.testmanager.close | sltest.testmanager.view
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015a
                                                                                             1-65
1   Functions
          sltest.testmanager.clearResults
          Clear results from Test Manager
          Syntax
          sltest.testmanager.clearResults
          Description
          sltest.testmanager.clearResults clears all results data from the Test Manager Results and
          Artifacts pane.
Examples
          See Also
          sltest.testmanager.clear
          Topics
          “Create and Run Test Cases with Scripts”
Introduced in R2016a
1-66
                                                                           sltest.testmanager.close
sltest.testmanager.close
Close the Simulink Test Manager
Syntax
sltest.testmanager.close
Description
sltest.testmanager.close closes the Simulink Test Manager interface. Test files and results are
retained in the Test Manager until the MATLAB session is closed.
Examples
See Also
sltest.testmanager.view
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015a
                                                                                             1-67
1   Functions
          sltest.testmanager.copyTests
          Copy test cases or test suites to another location
          Syntax
          objArray = sltest.testmanager.copyTests(srcObjArray,targetObj)
          Description
          objArray = sltest.testmanager.copyTests(srcObjArray,targetObj) copies test cases or
          test suites to another test file or test suite.
Examples
objArray =
                    Name
                    Description
                    Enabled
                    ReasonForDisabling
                    TestFile
                    TestPath
                    TestType
                    Parent
          Input Arguments
          srcObjArray — Test case or test suites to copy
          object array
1-68
                                                                             sltest.testmanager.copyTests
The destination test file or test suite to copy to, specified as an sltest.testmanager.TestFile or
sltest.testmanager.TestSuite object.
Output Arguments
objArray — Test cases or test suites at new location
object array
Test cases or test suites at the target destination location, returned as an array of
sltest.testmanager.TestCase or sltest.testmanager.TestSuite objects.
See Also
sltest.testmanager.moveTests
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                                                                   1-69
1   Functions
          sltest.testmanager.createTestForComponent
          Package: sltest
Create test case and test harness for model or model component
          Syntax
          tc = createTestForComponent("TestFile",tf,"Component",componentName)
          tc = createTestForComponent( ___ ,Name,Value)
          Description
          tc = createTestForComponent("TestFile",tf,"Component",componentName) creates a
          test case in the specified test file or test suite for the specified model component. The test file must
          already exist unless CreateTestFile is set to true.
Examples
          Create a baseline test case for the sltestCar model and save the inputs in an Excel® file. A test
          harness is created automatically.
          load_system('sltestCar');
tf = sltest.testmanager.TestFile('MyBaselineTestFile');
          sltest.testmanager.createTestForComponent("TestFile",tf,...
             "Component","sltestCar",...
             "TestType","baseline",...
             "ExcelFileLocation",...
             "C:\MATLABdata\mybaseline_inputdata.xlsx");
          Create an equivalence (back-to-back) test case for the Controller component of the
          rtwdemo_sil_block model.
          load_system('rtwdemo_sil_block');
tf = sltest.testmanager.TestFile('MyB2BTestFile');
          sltest.testmanager.createTestForComponent("TestFile",tf,...
             "Component","rtwdemo_sil_block/Controller",...
             "TestType","equivalence",...
             "SLDVTestGeneration",true,...
1-70
                                                               sltest.testmanager.createTestForComponent
    "Simulation1Mode","Normal",...
    "Simulation2Mode","Software-in-the-Loop (SIL)");
Input Arguments
tf — Test file or suite to which to add the test case
sltest.testmanager.TestFile object | sltest.testmanager.TestSuite object | string |
character vector
Test file or test suite to which to add the test case, specified as an sltest.testmanager.TestFile
or sltest.testmanager.TestSuite object, string or character vector. If CreateTestFile is
false, the test file object must exist. If CreateTestFile is true, TestFile is the path of a new test
file, specified as a string or character vector.
C
Example: "TestFile","myTestFile"
Model or component to test, specified as a string or character vector of the full path or as a
Simulink.BlockPath object. You can specify any model or block that is supported for test harness
generation. See “Test Harness and Model Relationship” for a list of components for which you can
build test harnesses.
Example: "Component","sf_car/shift_logic"
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Example: CreateTestFile,true
Whether to create a new test file, specified as specified as the comma-separated pair consisting of
"CreateTestFile" and true or false.
Example: "CreateTestFile",true
Model name at the top of the hierarchy if the component to test is in a referenced model, specified as
the comma-separated pair consisting of "TopModel" and as a string or character vector. If the
componentName is a top model, do not use the TopModel property.
Example: "TopModel","Plant"
                                                                                                  1-71
1   Functions
          Test case type, specified as the comma-separated pair consisting of "TestType" and "baseline",
          "equivalence", or "simulation".
          Example: "TestType","equivalence"
          Whether to create a test harness for a model, specified as the comma-separated pair consisting of
          "CreateHarness" and true or false. When the Component is not a top-level model or when test
          cases are generated using Simulink Design Verifier, this option is set to true automatically and a test
          harness is always created. If the model being tested is an export-function model, a Test Sequence
          scheduler block is created automatically in the test harness.
          Example: "CreateHarness",false
          Option to simulate the model to obtain component inputs for the created test harness, specified as
          true or false. If this property is true, the test harness uses the inputs from the model simulation.
          If this property is false, the test harness does not use the component inputs from the simulation.
          Example: "UseComponentInputs",false
          Simulation mode for simulation 1 of an equivalence test, specified as the comma-separated pair
          consisting of "Simulation1Mode" and either "Normal" or "Accelerator". If you do not specify a
          simulation mode, the mode of the system under test is used. The required test harness is created
          automatically for the simulation mode.
          Example: "Simulation1Mode","Normal"
          Simulation mode for simulation 2 of an equivalence test, specified as the comma-separated pair
          consisting of "Simulation2Mode" and a valid string or character vector. If you do not specify a
          simulation mode, the mode of the system under test is used. If TestType is equivalence and
          Simulation2Mode is Software-in-the-Loop (SIL), an extra test harness is created in addition
          to the test case and test harness.
          Example: "Simulation2Mode","Software-in-the-Loop (SIL)"
1-72
                                                               sltest.testmanager.createTestForComponent
File path for storing logged inputs in a MAT-file, specified as the comma-separated pair consisting of
"InputsLocation" and a character vector or string array. Include the file extension .mat. If you do
not specify an InputsLocation, a default location is used.
Example: "InputsLocation","C:\MATLAB\inputs_data.mat"
File path for storing baseline logged output data in a MAT-file, specified as the comma-separated pair
consisting of "BaselineLocation" and a character vector or string. Include the file
extension .mat. If you do not specify a BaselineLocation, a default location is used.
Example: "BaselineLocation","C:\MATLAB\baseline_data.mat"
Whether to use Excel format for inputs and, for baseline tests only, outputs, specified as the comma-
separated pair consisting of "CreateExcelFile" and either true or false. If you use the
"ExcelFileLocation" argument to specify the file name and location, you do not need to also use
"CreateExcelFile".
Example: "CreateExcelFile",true
File path for the Excel file, specified as the comma-separated pair consisting of
"ExcelFileLocation" and a character vector or string array. Include the extension .xlsx. If you
specify a location, you do not need to also use the "CreateExcelFile" option. If you do not specify
an ExcelFileLocation, the current working folder is used.
Example: "ExcelFileLocation","C:\MATLAB\baseline_data.xlsx"
Name of Excel sheet in which to save data, specified as the comma-separated pair consisting of
"Sheet" and a character vector or string. If you do not specify a Sheet, the current working folder
is used.
Example: "Sheet","MySubsysTest"
Whether to generate tests using Simulink Design Verifier, specified as the comma-separated pair
consisting of "SLDVTestGeneration" and true or false.
                                                                                                  1-73
1   Functions
          Note To generate tests from Simulink Design Verifier, the system under test must be an atomic
          subsystem.
Example: "SLDVTestGeneration",true
          Input source block for the test harness, specified as the comma-separated pair consisting of
          "HarnessSource" and either "Inport" or "Signal Editor".
          Example: "HarnessSource","Signal Editor"
          Test harness creation options, specified as a cell array of comma-separated name-value pairs. See
          sltest.harness.create for valid options. Do not include the harnessOwner handle as the first
          argument in the cell array. The first argument is set automatically to the Component value.
          Example:
          {"HarnessOptions","SynchronizationMode","SyncOnOpen","SeparateAssessment",tru
          e}
          Output Arguments
          tc — Test case
          sltest.testmanager.TestCase object
          See Also
          sltest.harness.create | sltest.testmanager.TestCase |
          sltest.testmanager.TestFile
          Topics
          “Create and Run Test Cases with Scripts”
          “Generate Tests and Test Harness for a Component or Model”
          “Create and Run a Back-to-Back Test”
          “Library-Based Code Generation for Reusable Library Subsystems” (Embedded Coder)
Introduced in R2020b
1-74
                                                                   sltest.testmanager.createTestsFromModel
sltest.testmanager.createTestsFromModel
Generate test cases from a model
Syntax
testFile = sltest.testmanager.createTestsFromModel(filePath,modelName,
testType)
Description
testFile = sltest.testmanager.createTestsFromModel(filePath,modelName,
testType) generates test cases based on the model structure. The function creates test cases from
test harnesses, Signal Editor scenarios, and Signal Builder groups in the model and assigns them to a
test file. If there are multiple Signal Builder groups, the test file includes iterations for each group
instead of separate test cases.
Examples
Create a new test file with new test cases in the Test Manager. Each test case uses a Signal Builder
group scenario.
testFile = sltest.testmanager.createTestsFromModel...
('C:\MATLAB\TestFile.mldatx','sldemo_autotrans','baseline')
testFile =
        Name: 'TestFile'
    FilePath: 'C:\MATLAB\TestFile.mldatx'
       Dirty: 0
Input Arguments
filePath — Test file name and path
character vector
The path and name of the test file to save the generated test cases to, specified as a character vector.
Example: 'C:\MATLAB\TestFile.mldatx'
The name of the model to generate test cases from, specified as a character vector.
Example: 'sldemo_autotrans'
                                                                                                    1-75
1   Functions
          The type of test cases to generate, specified as a character vector. The function creates test cases
          using this test case type.
          Output Arguments
          testFile — Test file
          sltest.testmanager.TestFile object
          Test file that contains the generated test cases, returned as an sltest.testmanager.TestFile
          object.
          See Also
          Topics
          “Create and Run Test Cases with Scripts”
Introduced in R2015b
1-76
                                                                          sltest.testmanager.exportResults
sltest.testmanager.exportResults
Export results set from Test Manager
Syntax
sltest.testmanager.exportResults(resultObjs,filePath)
Description
sltest.testmanager.exportResults(resultObjs,filePath) exports the specified results set
objects to a .mldatx file.
Examples
Input Arguments
resultObjs — Results set array
object
The file path and name of the result file you want to output, specified as a character vector. The
results file is a .mldatx file.
Example: 'C:\MATLAB\results.mldatx'
See Also
sltest.testmanager.ResultSet | sltest.testmanager.getResultSets
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                                                     1-77
1   Functions
          sltest.testmanager.getpref
          Get Test Manager preferences
          Syntax
          settings = sltest.testmanager.getpref(group)
          settings = sltest.testmanager.getpref(group,preferences)
          Description
          settings = sltest.testmanager.getpref(group) returns Test Manager preference settings
          in group.
Examples
Get the preferences for the sections that appear in test suites.
Get preferences for test suite display. A value of 1 means the section appears.
settings = sltest.testmanager.getpref('TestSuiteDisplay')
settings =
                      TestTag:   1
                  Description:   1
                  Requirement:   1
                     Callback:   1
                     Coverage:   1
settings =
                 Description: 1
                 Requirement: 1
1-78
                                                                             sltest.testmanager.getpref
ans =
    Name
    MATLABRoot
    IsDefault
    Selected
ans =
'14a'
ans =
'R2017b'
Input Arguments
group — Preference group
'TestFileDisplay' | 'TestSuiteDisplay' | 'TestCaseDisplay' | 'MATLABReleases'
Preference name, specified as a character vector or a cell array of character vectors. Use settings
= sltest.testmanager.getpref(group) to get valid preferences for each group.
Example: 'Description'
Example: {'TestTag','Description'}
Output Arguments
settings — Test Manager preferences
struct
                                                                                                 1-79
1   Functions
          See Also
          sltest.testmanager.setpref
          Topics
          “Test Sections”
Introduced in R2017a
1-80
                                                                       sltest.testmanager.getResultSets
sltest.testmanager.getResultSets
Returns result set objects in Test Manager
Syntax
rsList = sltest.testmanager.getResultSets
Description
rsList = sltest.testmanager.getResultSets returns an array of result set objects,
sltest.testmanager.ResultSet, from the results currently in the Test Manager Results and
Artifacts pane.
Examples
rsList = sltest.testmanager.getResultSets;
tsrList = getTestSuiteResults(rsList(1));
Output Arguments
rsList — Result set array
array of objects
The results currently in the Test Manager Results and Artifacts pane, returned as an array of
sltest.testmanager.ResultSet objects.
See Also
sltest.testmanager.ResultSet | sltest.testmanager.view
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                                                 1-81
1   Functions
          sltest.testmanager.getTestFiles
          Get test files open in the Test Manager
          Syntax
          testFiles = sltest.testmanager.getTestFiles
          Description
          testFiles = sltest.testmanager.getTestFiles returns an array of test files that are
          currently open in the Test Manager. The array contains an sltest.testmanager.TestFile object
          for each test file.
Examples
Load test files in the Test Manager that you want to get the objects for.
          Output Arguments
          testFiles — Test files
          sltest.testmanager.TestFile object array
          Test files that are open in the test manager, returned as an array of
          sltest.testmanager.TestFile objects.
          See Also
          sltest.testmanager.TestFile | sltest.testmanager.view
          Topics
          “Create and Run Test Cases with Scripts”
Introduced in R2016b
1-82
                                                                      sltest.testmanager.importResults
sltest.testmanager.importResults
Import Test Manager results file
Syntax
resultObjs = sltest.testmanager.importResults(filePath)
Description
resultObjs = sltest.testmanager.importResults(filePath) imports a results set file
(.mldatx) into the Test Manager.
Examples
Input Arguments
filePath — File name and path of results set
character vector
Output Arguments
resultObjs — Results set
object
See Also
sltest.testmanager.ResultSet | sltest.testmanager.report
                                                                                                1-83
1   Functions
          Topics
          “Create and Run Test Cases with Scripts”
Introduced in R2016a
1-84
                                                                                    sltest.testmanager.load
sltest.testmanager.load
Load a test file in the Simulink Test manager
Syntax
tfObj = sltest.testmanager.load(filename)
Description
tfObj = sltest.testmanager.load(filename) loads a test file in the Simulink Test manager.
Examples
In this example, the test file is from the “Override Model Parameters in a Test Case” example.
% Path to the example test file
exampleFile = fullfile(matlabroot,...
          'toolbox','simulinktest','simulinktestdemos',...
          'sltestParameterOverridesTestSuite.mldatx');
Input Arguments
filename — File name of test file
character vector
File name of a test file, specified as a character vector. The character vector must fully specify the
location of the test file. The file can be a test file (.mldatx), or a MATLAB test file (.m), if that
MATLAB test file is a derived class from sltest.TestCase.
Example: 'C:\MATLAB\test_file.mldatx'
Output Arguments
tfObj — Test file object
object
See Also
sltest.TestCase | sltest.testmanager.TestFile | sltest.testmanager.run |
sltest.testmanager.view
                                                                                                     1-85
1   Functions
          Topics
          “Create and Run Test Cases with Scripts”
          “Using MATLAB-Based Simulink Tests in the Test Manager”
          “Collect Coverage Using MATLAB-Based Simulink Tests”
Introduced in R2015a
1-86
                                                                        sltest.testmanager.moveTests
sltest.testmanager.moveTests
Move test cases or test suites to a new location
Syntax
objArray = sltest.testmanager.moveTests(srcObjArray,targetObj)
Description
objArray = sltest.testmanager.moveTests(srcObjArray,targetObj) moves test cases or
test suites to another test file or test suite.
Examples
objArray =
Input Arguments
srcObjArray — Test case or test suites to move
object array
The destination test file or test suite to move to, specified as an sltest.testmanager.TestFile or
sltest.testmanager.TestSuite object.
                                                                                              1-87
1   Functions
          Output Arguments
          objArray — Test cases or test suites at new location
          object array
          Test cases or test suites at the target destination location, returned as an array of
          sltest.testmanager.TestCase or sltest.testmanager.TestSuite objects.
          See Also
          sltest.testmanager.copyTests
          Topics
          “Create and Run Test Cases with Scripts”
Introduced in R2015b
1-88
                                                                                sltest.testmanager.report
sltest.testmanager.report
Generate report of test results
Syntax
sltest.testmanager.report(resultObj,filePath,Name,Value)
Description
sltest.testmanager.report(resultObj,filePath,Name,Value) generates a report of the
specified results in resultObj and saves the report to the filePath location.
Examples
Generate a report that includes the test author, test title, and the MATLAB version used to run the
test case. The report includes only failed results.
filePath = 'test.pdf';
sltest.testmanager.report(resultObj,filePath,...
    'Author','TestAuthor',...
    'Title','Test',...
    'IncludeMLVersion',true,...
    'IncludeTestResults',2);
If you create a custom class to customize how the report is generated using the
sltest.testmanager.TestResultReport class, then generate the report using:
                                                                                                   1-89
1   Functions
                'CustomReportClass','CustomReport',...
                'LaunchReport',true);
          Input Arguments
          resultObj — Results set object
          object
          File name and path of the generated report, specified as a character vector. File path must have file
          extension of pdf, docx, or zip, which are the only supported file types.
          Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
          Value is the corresponding value. Name must appear inside quotes. You can specify several name and
          value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
          Example: 'IncludeTestRequirement',true
          Choose to include the version of MATLAB used to run the test cases, specified as a Boolean value,
          true or false.
          Choose to include the test requirement link defined under Requirements in the test case, specified
          as a Boolean value, true or false.
          Choose to include the simulation output plots of each signal, specified as a Boolean value, true or
          false.
1-90
                                                                                   sltest.testmanager.report
Number of rows of plots to include on report pages, specified as an integer from 1 to 4. This property
is used only if the IncludeSimulationSignalPlots property is true.
Number of columns of plots to include on report pages, specified as an integer from 1 to 4. This
property is used only if the IncludeSimulationSignalPlots property is true.
Choose to include the signal comparison plots defined under baseline criteria, equivalence criteria, or
assessments using the verify operator in the test case, specified as a Boolean value, true or
false.
Option to include the figures opened from a callback script, custom criteria, or by the model in the
report, specified as true or false.
Choose to include error messages from the test case simulations, specified as a Boolean value, true
or false.
Option to include all or a subset of test results in the report. You can select passed and failed results,
specified as the integer value 0, select only passed results, specified as the value 1, or select only
failed results, specified as the value 2.
Open the report when it is finished generating, specified as a Boolean value, true or to not open the
report, false.
Name and path for a Microsoft® Word template file to use for report generation, specified as a
character vector. This is an optional argument that is only available if you have a MATLAB Report
Generator™ license.
Name of the class used for report customization, specified as a character vector. This is an optional
argument that is only available if you have a MATLAB Report Generator license.
                                                                                                      1-91
1   Functions
          Choose to include coverage metrics that are collected at test execution, specified as a Boolean value,
          true or false. For more information about collecting coverage, see “Collect Coverage in Tests”.
          Choose to include simulation metadata for each test case or iteration, specified as a Boolean value,
          true or false. The metadata includes: Simulink version, model version, model author, date, model
          user ID, model path, machine name, solver name, solver type, fixed step size, simulation start time,
          simulation stop time, and platform.
          See Also
          sltest.testmanager.ResultSet | sltest.testmanager.TestResultReport
          Topics
          “Customize Test Results Reports”
          “Create and Run Test Cases with Scripts”
Introduced in R2015a
1-92
                                                                                        sltest.testmanager.run
sltest.testmanager.run
Run tests with Test Manager
Syntax
resultObj = sltest.testmanager.run
resultObj = sltest.testmanager.run(Name,Value)
Description
resultObj = sltest.testmanager.run runs all of the Simulink Test test files in the Test
Manager, returning a sltest.testmanager.ResultSet object resultObj.
Examples
You can run tests at a test-file, test-suite, or test-case level if they are loaded in the test manager.
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('API Test File');
ts = createTestSuite(tf,'API Test Suite');
tc = createTestCase(ts,'simulation','Simulation Test Case');
Input Arguments
Name-Value Pair Options
Example: 'Parallel',true,'Tags',{'safety'}
Specifies whether to run tests with Parallel Computing Toolbox™ or MATLAB Parallel Server™.
Requires Parallel Computing Toolbox or MATLAB Parallel Server license, respectively.
Example: 'Parallel',true
Specifies test tags for execution. For more information, see “Tags”.
                                                                                                           1-93
1   Functions
          Example: 'Tags',{'safety'}
          Example: 'Tags',{'safety','regression'}
          Output Arguments
          resultObj — Results set object
          object
          Extended Capabilities
          Automatic Parallel Support
          Accelerate code by automatically running computation in parallel using Parallel Computing Toolbox™.
          See Also
          simulate | sltest.testmanager.load
          Topics
          “Create and Run Test Cases with Scripts”
          “Test Models Using MATLAB-Based Simulink Tests”
          “Using MATLAB-Based Simulink Tests in the Test Manager”
          “Collect Coverage Using MATLAB-Based Simulink Tests”
Introduced in R2015a
1-94
                                                                                 sltest.testmanager.setpref
sltest.testmanager.setpref
Set Test Manager preferences
Syntax
settings = sltest.testmanager.setpref(group,preference,value)
settings = sltest.testmanager.setpref('MATLABReleases','ReleaseList',
releasePrefs)
settings = sltest.testmanager.setpref('MATLABReleases',release,releasePref)
Description
settings = sltest.testmanager.setpref(group,preference,value) sets Test Manager
preferences in group, specified by preference, and value.
settings = sltest.testmanager.setpref('MATLABReleases','ReleaseList',
releasePrefs) updates the specified releases in your preferences with the ones specified by
releasePrefs. This preference lets you use releases other than the current release for testing.
This syntax replaces the existing list of added releases. Including a release path that is already in the
release preferences returns an error. To include that release in the releasePrefs, first delete the
existing release list.
settings = sltest.testmanager.setpref('MATLABReleases',release,releasePref)
adds the specified release to the list of releases in Test Manager preferences. Set releasePref to
{[]} to delete that release.
Examples
Change the display setting of two Test Manager preferences in test suite sections.
settings =
        TestTag:    1
    Description:    1
    Requirement:    1
       Callback:    1
       Coverage:    1
                                                                                                     1-95
1   Functions
settings =
                        TestTag:      1
                    Description:      0
                    Requirement:      0
                       Callback:      1
                       Coverage:      1
                 TestFileOption:      1
          You can add several releases at a time, delete the added releases, or add and delete a single release
          in your Test Manager MATLAB Release preferences.
Set your preferences to include several releases. Create a struct for each release.
          r1 = struct('Name','12b',...
                      'MATLABRoot','\\mycompany\R2012b\matlab',...
                      'Selected',true);
          r2 = struct('Name','14a',...
                      'MATLABRoot','\\mycompany\R2014a\matlab',...
                      'Selected',true);
          r3 = struct('Name','15a',...
                      'MATLABRoot','\\mycompany\R2015a\matlab',...
                      'Selected',true);
          r4 = struct('Name','13a',...
                      'MATLABRoot','\\mycompany\R2013a\matlab',...
                      'Selected',true);
          sltest.testmanager.setpref('MATLABReleases','13a',{r4});
sltest.testmanager.setpref('MATLABReleases','14a',{[]});
          Input Arguments
          group — Preference group
          'TestFileDisplay' | 'TestSuiteDisplay' | 'TestCaseDisplay'
1-96
                                                                                   sltest.testmanager.setpref
Preference value, specified as true to display the preference or false to hide it.
Example: true
Example: {true,false}
Release information, specified as a struct or cell array of structs. In the struct, include, in this order:
• 'Name',releaseName
• 'MATLABRoot',Path
• 'Selected',Boolean
Example: struct('Name','14a','MATLABRoot','\\mypath','Selected',true)
Release information, specified as a struct or as {[]}. Use {[]} to delete the release information
from the preferences. In the struct, include:
• 'Name',releaseName
• 'MATLABRoot',Path
• 'Selected',Boolean
Example: struct('Name','14a','MATLABRoot','\\mypath','Selected',true)
Output Arguments
settings — Test Manager preferences
struct
                                                                                                       1-97
1   Functions
          See Also
          sltest.testmanager.getpref
          Topics
          “Test Sections”
          “Run Tests in Multiple Releases of MATLAB”
Introduced in R2017a
1-98
                                                                         sltest.testmanager.TestSpecReport
sltest.testmanager.TestSpecReport
Generate report of test specifications
Syntax
sltest.testmanager.TestSpecReport(testObj,filePath,Name,Value)
Description
sltest.testmanager.TestSpecReport(testObj,filePath,Name,Value) generates a report
of the test specifications for the specified testObj and saves the report to the specified filePath
location.
Examples
Generate a PDF report that uses the default template. This example reports on test cases from the
test manager file of the AutopilotTestFile model. The report specifies the test author and report
title. It excludes custom criteria from the report and launches the report after it is generated. Other
properties default to true and thus, their information is included in the report.
tfiles = sltest.testmanager.getTestFiles;
tcases = tfiles.getTestSuites.getTestCases;
sltest.testmanager.TestSpecReport(tcases,'testReport.pdf',...
    'Author','Test File Author',...
    'Title','Test Specification Details',...
    'IncludeCustomCriteria',false,...
       'LaunchReport',true);
Create a custom test case template. After you edit the template as desired, use that template when
generating the report. Examples of edits to the custom template include reordering the report
sections and changing the report fonts. This example shows how to generate a customized
TestCaseReporter. Generating a customized TestSuiteReporter template is similar and is used to
generate both Test Suite and Test File report sections. Customizing templates requires a Simulink
Report Generator license. See “Templates” (MATLAB Report Generator) for more information.
sltest.testmanager.TestCaseReporter.createTemplate(...
   'MyCustomTemplate','pdf');
unzipTemplate('MyCustomTemplate.pdftx');
                                                                                                    1-99
1   Functions
zipTemplate('MyCustomTemplate.pdftx')
          tfiles = sltest.testmanager.getTestFiles;
          tcases = tfiles.getTestSuites.getTestCases;
          sltest.testmanager.TestSpecReport(tcases,'testReport.pdf',...
             'Author','Test Author','Title','Test',...
             'LaunchReport',true,...
             'TestCaseReporterTemplate','MyCustomTemplate.pdftx');
          Input Arguments
          testObj — Test objects
          array of sltest.testmanager.TestFile objects | array of sltest.testmanager.TestSuite
          objects | array of sltest.testmanager.TestCase objects
          Test objects from which to generate the test specification report, specified as an array of
          sltest.testmanager.TestFile, sltest.testmanager.TestSuite, or
          sltest.testmanager.TestCase objects. You cannot include a different object types in the same
          array.
          File name and path of the generated report, specified as a string or character array. The file path
          must have one of these file extensions:
Example: "reports/test_specs/new_report.pdf"
          Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
          Value is the corresponding value. Name must appear inside quotes. You can specify several name and
          value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
          Example: 'IncludeCallbackScripts',false
1-100
                                                                            sltest.testmanager.TestSpecReport
Option to include test details in the report, specified as a logical. If true, the test details included in
the report are test tags, releases, description, and requirements.
Option to include test file options in the report, specified as a logical. If true, the test file options
included in the report are:
   • Report title
   • Author
   • Whether to include the MATLAB version
   • Types of test results to include (all, failed only, or passed only)
   • Other items to include in the report - test requirements, simulation metadata, error and log
     messages, plots of simulation output and baseline, plots of criteria and assessments, MATLAB
     figures, and coverage results
   • Output file format
   • Output file name
   • Custom report class
Option to include coverage settings in the report, specified as a logical. If true, the coverage settings
included in the report are coverage to collect, coverage filter file name, and coverage metrics.
Examples of coverage metrics included in the report include decisions, signal range, relational
boundaries, saturation on integer overflow, and lookup tables. For more information about collecting
coverage, see “Collect Coverage in Tests”.
Option to include the system under test in the report, specified as a logical. If true, the system under
test information included in the report is:
                                                                                                       1-101
1   Functions
          • Test sequence and assessment data (if they exist in the test harness)
          • Simulation settings — simulation mode, start time (if overridden), stop time (if overridden), and
            initial state (if overridden)
          • Target settings — target information for real-time test cases
          Option to include configuration settings overrides, specified as a logical. If true, the report includes
          the settings that differ from the model configuration settings.
          Option to include parameter overrides in the report, specified as a logical. If true, the report
          includes the name of the parameter set or workspace variable, the override value, the source of the
          variable, and the model element.
          Option to include external inputs in the report, specified as a logical. If true, the report includes the
          name, file path, and mapping status of the external inputs.
          Option to include logged signals, specified as a logical. If true, the report includes the name, source,
          port index, and plot index for each logged signal.
          Option to include baseline criteria information in the report, specified as a logical. If true, the report
          includes the signal name, absolute tolerance, relative tolerance, leading tolerance, and lagging
          tolerance for the baseline test.
          Option to include equivalence criteria information in the report, specified as a logical. If true, the
          report includes the signal name, absolute tolerance, relative tolerance, leading tolerance, and lagging
          tolerance for the equivalence test.
          Option to include iterations information in the report, specified as a logical. If true, the report
          includes the iteration name and the values of the external inputs, parameter set, and logged signal
1-102
                                                                           sltest.testmanager.TestSpecReport
set for each iteration. It also includes the content of the Iterations Script section from the Test
Manager.
Option to include the custom pass/fail criteria script in the report, specified as a logical.
Path to test case reporter template, specified as a character vector. The template path file name must
use a pdftx, html, or dotx extension, for a PDF, HTML, or Word template, respectively. The
specified template is used instead of the default TestCaseReporter template. Using non-default
templates is available only if you have a Simulink Report Generator license.
Path to test suite reporter template, specified as a character vector. The file name in the template
path must use a pdftx, html, or dotx extension, for a PDF, HTML, or Word template, respectively.
The TestSuiteReporter template is used for both test suites and test files. The specified template
is used instead of the default TestSuiteReporter template. Using non-default templates is
available only if you have a Simulink Report Generator license.
See Also
sltest.testmanager.TestCase | sltest.testmanager.TestFile |
sltest.testmanager.TestSuite | sltest.testmanager.getTestFiles
Topics
“Generate a Test Specification Report” on page 1-99
“Generate a Customized Test Specification Report” on page 1-99
Introduced in R2019b
                                                                                                     1-103
1   Functions
          sltest.testmanager.view
          Launch the Simulink Test Manager
          Syntax
          sltest.testmanager.view
          Description
          sltest.testmanager.view launches the Simulink Test Manager interface. You can also use the
          function sltestmgr to launch the Test Manager.
Examples
          % Create the test file, test suite, and test case structure
          tf = sltest.testmanager.TestFile('API Test File');
          ts = createTestSuite(tf,'API Test Suite');
          tc = createTestCase(ts,'baseline','Baseline API Test Case');
          See Also
          sltest.testmanager.load | sltest.testmanager.run
          Topics
          “Create and Run Test Cases with Scripts”
Introduced in R2015a
1-104
                                                                   sltest.testsequence.activateScenario
sltest.testsequence.activateScenario
Package: sltest.testsequence
Syntax
sltest.testsequence.activateScenario(blockPath,scenarioName)
Description
sltest.testsequence.activateScenario(blockPath,scenarioName) makes the
scenarioName scenario in the specified Test Sequence block active so it runs during simulation.
Only one scenario is active at a time. You can use activateScenario only if
sltest.testsequence.setScenarioControlSource is
sltest.testsequence.ScenarioControlSource.Block, which sets the active scenario control to a Test
Sequence block instead of a variable in the workspace. Use
sltest.testsequence.getScenarioControlSource to view the current scenario control source
setting and sltest.testsequence.setScenarioControlSource to change it.
Examples
Set the Test Sequence block in the sltestRollRefTestExample model to use scenarios. Then, add
another scenario named Scenario_2 and activate Scenario_2 so it runs when the model simulates.
The control source is the default, sltest.testsequence.ScenarioControlSource.Block. Close the model
without saving it.
Model = 'sltestRollRefTestExample';
load_system(Model);
sltest.testsequence.useScenario...
   ('sltestRollRefTestExample/Test Sequence',...
   'Scenario_1');
sltest.testsequence.addScenario...
   ('sltestRollRefTestExample/Test Sequence',...
   'Scenario_2');
sltest.testsequence.activateScenario...
   ('sltestRollRefTestExample/Test Sequence',...
   'Scenario_2');
close_system(Model,0)
Input Arguments
blockPath — Test Sequence block path
string | character vector
                                                                                                1-105
1   Functions
          Path to a Test Sequence block, including the block name, specified as a string or character vector.
          Example: 'FanSpeedTestHarness/Test Sequence'
          See Also
          getAllScenarios | setScenarioControlSource |
          sltest.testsequence.getActiveScenario | sltest.testsequence.useScenario
          Topics
          “Programmatically Create Multiple Scenarios in a Test Sequence Block”
Introduced in R2020b
1-106
                                                                          sltest.testsequence.addScenario
sltest.testsequence.addScenario
Package: sltest.testsequence
Syntax
sltest.testsequence.addScenario(blockPath,scenarioName)
Description
sltest.testsequence.addScenario(blockPath,scenarioName) adds a new scenario with the
name specified by scenarioName to the Test Sequence block specified by blockPath. The specified
Test Sequence block must be in scenario mode and the name of the new scenario cannot already exist
in the block. The new scenario is added after the last scenario in the block.
Examples
Set the Test Sequence block in the sltestRollRefTestExample model to use scenarios. Then, add
a new scenario named new_Scenario. Close the model without saving it.
Model = 'sltestRollRefTestExample';
load_system(Model);
sltest.testsequence.useScenario...
   ('sltestRollRefTestExample/Test Sequence',...
   'Scenario_1');
sltest.testsequence.addScenario...
   ('sltestRollRefTestExample/Test Sequence',...
   'new_Scenario');
close_system(Model,0)
Input Arguments
blockPath — Test Sequence block path
string | character vector
Path to a Test Sequence block, including the block name, specified as a string or character vector.
Example: 'FanSpeedTestHarness/Test Sequence'
                                                                                                  1-107
1   Functions
Example: 'Name','Scenario_1'
          See Also
          deleteScenario | sltest.testsequence.useScenario
          Topics
          “Programmatically Create Multiple Scenarios in a Test Sequence Block”
Introduced in R2020b
1-108
                                                                             sltest.testsequence.addStep
sltest.testsequence.addStep
Add test sequence step
Syntax
sltest.testsequence.addStep(blockPath,stepPath,Name,Value)
Description
sltest.testsequence.addStep(blockPath,stepPath,Name,Value) adds a step named
stepPath to a Test Sequence block specified by blockPath. Step properties are specified by
Name,Value pairs.
Examples
This example creates a test step in the Projector Fan Speed example test sequence under the parent
step SystemHeatingTest.
Create a step substep1 under the step SystemHeatingTest and assign the value 5 to h.
sltest.testsequence.addStep('FanSpeedTestHarness/Test Sequence',...
'SystemHeatingTest.substep1','Action','h = 5')
Input Arguments
blockPath — Test Sequence block path
string | character vector
Path to a Test Sequence block, including the block name, specified as a string or character vector.
Example: 'FanSpeedTestHarness/Test Sequence'
                                                                                                 1-109
1   Functions
          Path of the step in the Test Sequence block, specified as a character vector. The path includes the
          step location in the Test Sequence hierarchy, using . to separate hierarchy levels. If the Test
          Sequence block is using scenarios, add the scenario name that contains the step to the beginning of
          the step path, for example, Scenario_2.SystemHeatingTest.InitializeHeating.
          Example: 'SystemHeatingTest.InitializeHeating'
          Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
          Value is the corresponding value. Name must appear inside quotes. You can specify several name and
          value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
          Example: 'Action','out = square(et)','IsWhenStep',false,'Description','Square
          wave.' specifies a test step to produce a square wave.
          Test step action programming. To add a line, create the step actions using the sprintf function and
          the new line operator, \n.
          Example: 'Action','out = square(et)'
          Specifies whether the step is a standard transition type or a When decomposition transition.
          Example: 'IsWhenStep',true
          Specifies the condition that activates a When decomposition child step. To activate the When step,
          enter a valid logical expression.
          Example: 'WhenCondition','a >= 1'
          See Also
          sltest.testsequence.addStepAfter | sltest.testsequence.addStepBefore |
          sltest.testsequence.addSymbol | sltest.testsequence.addTransition |
          sltest.testsequence.editStep | sltest.testsequence.findStep
          Topics
          “Programmatically Create a Test Sequence”
Introduced in R2016a
1-110
                                                                       sltest.testsequence.addStepAfter
sltest.testsequence.addStepAfter
Add test sequence step after existing step
Syntax
sltest.testsequence.addStepAfter(blockPath,newStep,stepPath,Name,Value)
Description
sltest.testsequence.addStepAfter(blockPath,newStep,stepPath,Name,Value) adds a
step to a Test Sequence block specified by blockPath. The new step is named newStep and is
inserted after stepPath. Step properties are specified by Name,Value.
Examples
This example creates a test step, step1, in a Test Sequence block after the step SetLowPhi, which is
in the second level of hierarchy under the top-level step APEngagement_AttitudeLevels.
filePath = fullfile(matlabroot,'toolbox',...
   'simulinktest','simulinktestdemos');
rollModel = 'RollAutopilotMdlRef';
testHarness = 'RollReference_Requirement1_3';
open_system(fullfile(filePath,rollModel));
sltest.testsequence.addSymbol...
   ('RollReference_Requirement1_3/Test Sequence',...
   'h','Data','Local');
sltest.testsequence.addStepAfter...
   ('RollReference_Requirement1_3/Test Sequence',...
   'AttitudeLevels.APEngage_LowRoll.step2',...
   'AttitudeLevels.APEngage_LowRoll.SetLowPhi',...
   'Action','h = 5;')
Input Arguments
blockPath — Test Sequence block path
string | character vector
                                                                                                1-111
1   Functions
          Path to a Test Sequence block, including the block name, specified as a string or character vector.
          Example: 'FanSpeedTestHarness/Test Sequence'
          Name of a new test step in the Test Sequence block, specified as a character vector. It is added after
          stepPath and must have the same parent step as stepPath.
          Example: 'newStep'
          Example: 'topStep.midStep.newStep'
          Path of the step in the Test Sequence block, specified as a character vector. The path includes the
          step location in the Test Sequence hierarchy, using . to separate hierarchy levels. If the Test
          Sequence block is using scenarios, add the scenario name that contains the step to the beginning of
          the step path, for example, Scenario_2.SystemHeatingTest.InitializeHeating.
          Example: 'SystemHeatingTest.InitializeHeating'
          Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
          Value is the corresponding value. Name must appear inside quotes. You can specify several name and
          value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
          Example: 'Action','out = square(et)','IsWhenStep',false,'Description','This
          step produces a square wave.' specifies a test step to produce a square wave.
          The test step action programming. To add a line, create the step actions using the sprintf function
          and the new line operator \n.
          Example: 'Action','out = square(et)'
          Specifies whether the step is a standard transition type or a When decomposition transition.
          Example: 'IsWhenStep',true
          Specifies the condition that activates a When decomposition child step. To activate the When step,
          enter a valid logical expression.
          Example: 'WhenCondition','a >= 1'
1-112
                                                          sltest.testsequence.addStepAfter
See Also
sltest.testsequence.addStep | sltest.testsequence.addStepBefore |
sltest.testsequence.addSymbol | sltest.testsequence.addTransition |
sltest.testsequence.editStep | sltest.testsequence.findStep
Topics
“Programmatically Create a Test Sequence”
Introduced in R2016a
                                                                                   1-113
1   Functions
          sltest.testsequence.addStepBefore
          Add test sequence step before existing step
          Syntax
          sltest.testsequence.addStepBefore(blockPath,newStep,stepPath,Name,Value)
          Description
          sltest.testsequence.addStepBefore(blockPath,newStep,stepPath,Name,Value) adds a
          step to a Test Sequence block specified by blockPath. The new step is named newStep and inserted
          immediately before the step named stepPath. Step properties are specified by Name,Value.
Examples
          This example creates a test step, step1, in a Test Sequence block before the step SetLowPhi, which
          is in the second level of hierarchy under the top-level step APEngagement_AttitudeLevels.
          filePath = fullfile(matlabroot,'toolbox',...
             'simulinktest','simulinktestdemos');
          rollModel = 'RollAutopilotMdlRef';
          testHarness = 'RollReference_Requirement1_3';
          open_system(fullfile(filePath,rollModel));
          sltest.testsequence.addSymbol...
             ('RollReference_Requirement1_3/Test Sequence',...
             'h','Data','Local');
          sltest.testsequence.addStepBefore...
             ('RollReference_Requirement1_3/Test Sequence',...
             'AttitudeLevels.APEngage_LowRoll.step1',...
             'AttitudeLevels.APEngage_LowRoll.SetLowPhi',...
             'Action','h = 5;')
          Input Arguments
          blockPath — Test Sequence block path
          string | character vector
1-114
                                                                        sltest.testsequence.addStepBefore
Path to a Test Sequence block, including the block name, specified as a string or character vector.
Example: 'FanSpeedTestHarness/Test Sequence'
Name of a new test step in the Test Sequence block, specified as a character vector. It is added before
stepPath and must have the same parent step as stepPath.
Example: 'newStep'
Example: 'topStep.midStep.newStep'
Path of the step in the Test Sequence block, specified as a character vector. The path includes the
step location in the Test Sequence hierarchy, using . to separate hierarchy levels. If the Test
Sequence block is using scenarios, add the scenario name that contains the step to the beginning of
the step path, for example, Scenario_2.SystemHeatingTest.InitializeHeating.
Example: 'SystemHeatingTest.InitializeHeating'
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Example: 'Action','out = square(et)','IsWhenStep',false,'Description','This
step produces a square wave.' specifies a test step to produce a square wave.
The test step action programming. To add a line, create the step actions using the sprintf function
and the new line operator \n.
Example: 'Action','out = square(et)'
Specifies whether the step is a standard transition type or a When decomposition transition
Example: 'IsWhenStep',true
Specifies the condition that activates a When decomposition child step. To activate the When step,
enter a valid logical expression.
Example: 'WhenCondition','a >= 1'
                                                                                                  1-115
1   Functions
          See Also
          sltest.testsequence.addStep | sltest.testsequence.addStepAfter |
          sltest.testsequence.addSymbol | sltest.testsequence.addTransition |
          sltest.testsequence.editStep | sltest.testsequence.findStep
          Topics
          “Programmatically Create a Test Sequence”
Introduced in R2016a
1-116
                                                                           sltest.testsequence.addSymbol
sltest.testsequence.addSymbol
Add symbol to test sequence
Syntax
sltest.testsequence.addSymbol(blockPath,name,kind,scope)
Description
sltest.testsequence.addSymbol(blockPath,name,kind,scope) adds a symbol name with
properties specified by scope and kind to a Test Sequence block specified by blockPath. The new
symbol appears in the Symbols sidebar of the Test Sequence Editor. Symbols include data, messages,
function calls, and triggers.
Examples
filePath = fullfile(matlabroot,'toolbox',...
   'simulinktest','simulinktestdemos');
rollModel = 'RollAutopilotMdlRef';
testHarness = 'RollReference_Requirement1_3';
open_system(fullfile(filePath,rollModel));
Add a parameter.
sltest.testsequence.addSymbol...
   ('RollReference_Requirement1_3/Test Sequence',...
   'theta','Data','Parameter')
Input Arguments
blockPath — Test Sequence block path
string | character vector
Path to a Test Sequence block, including the block name, specified as a string or character vector.
Example: 'FanSpeedTestHarness/Test Sequence'
                                                                                                 1-117
1   Functions
          Name of the new symbol, specified as a character vector. The symbol must not already exist in the
          Test Sequence block.
          Example: 'theta'
          See Also
          sltest.testsequence.deleteSymbol | sltest.testsequence.editSymbol |
          sltest.testsequence.find | sltest.testsequence.findSymbol |
          sltest.testsequence.readSymbol
          Topics
          “Programmatically Create a Test Sequence”
Introduced in R2016a
1-118
                                                                             sltest.testsequence.addTransition
sltest.testsequence.addTransition
Add new transition to test sequence step
Syntax
sltest.testsequence.addTransition(blockPath,fromStep,condition,toStep)
Description
sltest.testsequence.addTransition(blockPath,fromStep,condition,toStep) creates a
test step transition in the Test Sequence block blockPath. The transition executes on condition,
from the origin fromStep, to the destination toStep. fromStep and toStep must be at the same
hierarchy level.
Examples
Add and Edit a Test Step Transition
This example adds a transition to a test step, then changes the transition's index, condition, and next
step of the first transition in the step.
Model = 'sltestRollRefTestExample';
load_system(Model);
sltest.testsequence.addTransition('sltestRollRefTestExample/Test Sequence',...
'AttitudeLevels.APEngage_LowRoll','TurnKnob ~= 0',...
'AttitudeLevels.APEngagement_End')
3. Edit the transition index, condition, and next step of the first transition.
sltest.testsequence.editTransition('sltestRollRefTestExample/Test Sequence',...
'AttitudeLevels.APEngage_LowRoll',1,'Index',2,...
'NextStep','AttitudeLevels.APEngage_HighRoll',...
'Condition','duration(DD_PhiRef == 0,sec) >= 5')
close_system(Model,0)
Input Arguments
blockPath — Test Sequence block path
string | character vector
Path to a Test Sequence block, including the block name, specified as a string or character vector.
                                                                                                       1-119
1   Functions
          Path of an existing step in the Test Sequence block, specified as a character vector, at which the
          transition originates. The path must include the step name and step hierarchy, using . to separate
          hierarchy levels. This step must be at same level as toStep.
          Example: 'topStep.midStep.step1'
          The condition on which the transition executes, specified as a character vector. Though specified as a
          character vector, it must be a valid logical expression for the transition to execute.
          Example: 'theta == 0 && a == 1'
          Path of an existing step in the Test Sequence block, specified as a character vector, which becomes
          active step after the transition executes. The path must include the step name and step hierarchy,
          using . to separate hierarchy levels. This step must be at same level as fromStep.
          Example: 'topStep.midStep.step2'
          See Also
          sltest.testsequence.addStep | sltest.testsequence.addSymbol |
          sltest.testsequence.deleteTransition | sltest.testsequence.editTransition |
          sltest.testsequence.find | sltest.testsequence.readTransition
          Topics
          “Programmatically Create a Test Sequence”
Introduced in R2016a
1-120
                                                                       sltest.testsequence.deleteScenario
sltest.testsequence.deleteScenario
Package: sltest.testsequence
Syntax
sltest.testsequence.deleteScenario(blockPath,scenarioName)
Description
sltest.testsequence.deleteScenario(blockPath,scenarioName) removes the scenario
specified by scenarioName from the Test Sequence block specified by blockPath. All steps in the
deleted scenario are also deleted. Each scenario in a Test Sequence block is identified by a scenario
name and an index. When you delete a scenario, the indices of the following scenarios update. For
example, if you delete the second scenario, the index of the third scenario changes from 3 to 2.
Examples
Set the Test Sequence block in the sltestRollRefTestExample model to use scenarios. Add a new
scenario named Scenario_2, and then delete the scenario.
Model = 'sltestRollRefTestExample';
load_system(Model);
sltest.testsequence.useScenario...
   ('sltestRollRefTestExample/Test Sequence',...
   'Scenario_1');
sltest.testsequence.addScenario...
   ('sltestRollRefTestExample/Test Sequence',...
   'Scenario_2');
sltest.testsequence.deleteScenario...
   ('sltestRollRefTestExample/Test Sequence',...
   'Scenario_2');
close_system(Model,0)
Input Arguments
blockPath — Test Sequence block path
string | character vector
Path to a Test Sequence block, including the block name, specified as a string or character vector.
Example: 'FanSpeedTestHarness/Test Sequence'
                                                                                                  1-121
1   Functions
          See Also
          addScenario | getAllScenarios | sltest.testsequence.useScenario
          Topics
          “Programmatically Create Multiple Scenarios in a Test Sequence Block”
Introduced in R2020b
1-122
                                                                           sltest.testsequence.deleteStep
sltest.testsequence.deleteStep
Delete test sequence step
Syntax
sltest.testsequence.deleteStep(blockPath,stepPath)
Description
sltest.testsequence.deleteStep(blockPath,stepPath) deletes a test step specified by
stepPath from a Test Sequence block specified by blockPath. Sub-steps of stepPath are also
deleted.
Examples
This example shows how to delete a test step programmatically from a Test Sequence block.
Input Arguments
blockPath — Test Sequence block path
string | character vector
Path to a Test Sequence block, including the block name, specified as a string or character vector.
Example: 'FanSpeedTestHarness/Test Sequence'
Path of the step in the Test Sequence block, specified as a character vector. The path includes the
step location in the Test Sequence hierarchy, using . to separate hierarchy levels. If the Test
Sequence block is using scenarios, add the scenario name that contains the step to the beginning of
the step path, for example, Scenario_2.SystemHeatingTest.InitializeHeating.
Example: 'SystemHeatingTest.InitializeHeating'
                                                                                                  1-123
1   Functions
          See Also
          sltest.testsequence.addStep | sltest.testsequence.deleteSymbol |
          sltest.testsequence.deleteTransition
          Topics
          “Programmatically Create a Test Sequence”
Introduced in R2017a
1-124
                                                                         sltest.testsequence.deleteSymbol
sltest.testsequence.deleteSymbol
Delete test sequence block symbol
Syntax
sltest.testsequence.deleteSymbol(blockPath,symbolName)
Description
sltest.testsequence.deleteSymbol(blockPath,symbolName) deletes symbolName from a
Test Sequence block specified by blockPath.
Examples
This example shows how to delete a data symbol programmatically from a Test Sequence block. The
data symbol DurationLimit is a constant.
Model = 'sltestRollRefTestExample';
load_system(Model);
sltest.testsequence.deleteSymbol('sltestRollRefTestExample/Test Sequence',...
    'DurationLimit');
close_system(Model,0);
Input Arguments
blockPath — Test Sequence block path
string | character vector
Path to a Test Sequence block, including the block name, specified as a string or character vector.
Example: 'FanSpeedTestHarness/Test Sequence'
Name of the symbol to delete in the Test Sequence block, specified as a character vector.
Example: 'testOutput'
                                                                                                  1-125
1   Functions
          See Also
          sltest.testsequence.addSymbol | sltest.testsequence.deleteStep |
          sltest.testsequence.deleteTransition
          Topics
          “Programmatically Create a Test Sequence”
Introduced in R2017a
1-126
                                                                       sltest.testsequence.deleteTransition
sltest.testsequence.deleteTransition
Delete test sequence transition
Syntax
sltest.testsequence.deleteTransition(blockPath,stepPath,index)
Description
sltest.testsequence.deleteTransition(blockPath,stepPath,index) deletes the
transition at the given numerical index from the test step specified by blockPath and stepPath.
Examples
cd(matlabroot);
Model = 'sltestRollRefTestExample';
load_system(fullfile(matlabroot,'examples','simulinktest',Model));
Delete the transition from the test step SetKnobAndPhi under the parent step
TurnKnobAndAttitude.
sltest.testsequence.deleteTransition...
('sltestRollRefTestExample/Test Sequence',...
'TurnKnobAndAttitude.SetKnobAndPhi',1)
close_system(Model,0);
Input Arguments
blockPath — Test Sequence block path
string | character vector
Path to a Test Sequence block, including the block name, specified as a string or character vector.
Example: 'FanSpeedTestHarness/Test Sequence'
Path of the step in the Test Sequence block, specified as a character vector. The path includes the
step location in the Test Sequence hierarchy, using . to separate hierarchy levels. If the Test
                                                                                                   1-127
1   Functions
          Sequence block is using scenarios, add the scenario name that contains the step to the beginning of
          the step path, for example, Scenario_2.SystemHeatingTest.InitializeHeating.
          Example: 'SystemHeatingTest.InitializeHeating'
          Integer specifying the transition in the test step to be edited. Corresponds to the integer displayed in
          the Transition cell of the Test Sequence Editor.
          Example: 3
          See Also
          sltest.testsequence.addTransition | sltest.testsequence.deleteStep |
          sltest.testsequence.deleteSymbol
          Topics
          “Programmatically Create a Test Sequence”
Introduced in R2017a
1-128
                                                                          sltest.testsequence.editScenario
sltest.testsequence.editScenario
Package: sltest.testsequence
Syntax
sltest.testsequence.editScenario(blockPath,scenarioName,'Name',newName)
Description
sltest.testsequence.editScenario(blockPath,scenarioName,'Name',newName) changes
the name of the scenario specified by scenarioName in the Test Sequence block specified by
blockPath to the specified newName. To edit the properties of steps within a scenario, see
sltest.testsequence.editStep.
Examples
Set the Test Sequence block in the sltestRollRefTestExample model to use scenarios. Then,
change the name of the scenario named Scenario_1 to FirstScenario.
Model = 'sltestRollRefTestExample';
load_system(Model);
% Rename scenario
sltest.testsequence.editScenario...
   ('sltestRollRefTestExample/Test Sequence',...
   'Scenario_1','Name','FirstScenario');
close_system(Model,0)
Input Arguments
blockPath — Test Sequence block path
string | character vector
Path to a Test Sequence block, including the block name, specified as a string or character vector.
Example: 'FanSpeedTestHarness/Test Sequence'
                                                                                                   1-129
1   Functions
          See Also
          addScenario | deleteScenario | sltest.testsequence.editStep
          Topics
          “Programmatically Create Multiple Scenarios in a Test Sequence Block”
Introduced in R2020b
1-130
                                                                             sltest.testsequence.editStep
sltest.testsequence.editStep
Edit test sequence step
Syntax
sltest.testsequence.editStep(blockPath,stepPath,Name,Value)
Description
sltest.testsequence.editStep(blockPath,stepPath,Name,Value) edits the properties of
an existing step specified by stepPath in a Test Sequence block specified by blockPath. Changes to
the properties are specified by Name,Value.
Examples
This example adds a test step then edits the step actions of the new step.
open_system('sltestTestSequenceWhenExample')
sltest.harness.open('sltestTestSequenceWhenExample/SimpleTracker',...
'SimpleTrackerHarness')
sltest.testsequence.addStep('SimpleTrackerHarness/Test Sequence',...
'Square.SquareAndVeryQuick')
action =
mode = uint8(3);
out = square(et);
% New step action
sltest.testsequence.editStep('SimpleTrackerHarness/Test Sequence',...
'Square.SquareAndVeryQuick','Action',action,'Description',...
'This step outputs a high-frequency square wave.')
sltest.testsequence.addStep('SimpleTrackerHarness/Test Sequence',...
'Square.SquareAndVeryQuick.Step1')
sltest.testsequence.addStep('SimpleTrackerHarness/Test Sequence',...
'Square.SquareAndVeryQuick.Step2')
                                                                                                  1-131
1   Functions
          sltest.testsequence.editStep('SimpleTrackerHarness/Test Sequence',...
          'Square.SquareAndVeryQuick','IsWhenStep',true)
          sltest.testsequence.editStep('SimpleTrackerHarness/Test Sequence',...
          'Square.SquareAndVeryQuick.Step1','WhenCondition','a >= 1')
          Input Arguments
          blockPath — Test Sequence block path
          string | character vector
          Path to a Test Sequence block, including the block name, specified as a string or character vector.
          Example: 'FanSpeedTestHarness/Test Sequence'
          Path of the step in the Test Sequence block, specified as a character vector. The path includes the
          step location in the Test Sequence hierarchy, using . to separate hierarchy levels. If the Test
          Sequence block is using scenarios, add the scenario name that contains the step to the beginning of
          the step path, for example, Scenario_2.SystemHeatingTest.InitializeHeating.
          Example: 'SystemHeatingTest.InitializeHeating'
          Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
          Value is the corresponding value. Name must appear inside quotes. You can specify several name and
          value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
          Example: 'Action','out = square(et)','IsWhenStep',false,'Description','This
          step produces a square wave.' specifies a test step to produce a square wave.
          The new name for the test step, specified as a character vector.
          Example: 'Name','HoldOutput'
          The test step action programming. To add a line, create the step actions using the sprintf function
          and the new line operator \n.
          Example: 'Action','out = square(et)'
Specifies whether the step is a standard transition type or a When decomposition transition
1-132
                                                                            sltest.testsequence.editStep
Example: 'IsWhenStep',true
Character vector specifying the condition that activates a When decomposition child step. This must
be a valid logical expression for the When step to activate.
Example: 'WhenCondition','a >= 1'
See Also
sltest.testsequence.addStep | sltest.testsequence.deleteStep |
sltest.testsequence.editSymbol | sltest.testsequence.editTransition |
sltest.testsequence.findStep
Topics
“Programmatically Create a Test Sequence”
Introduced in R2016a
                                                                                                 1-133
1   Functions
          sltest.testsequence.editSymbol
          Edit symbol in Test Sequence block
          Syntax
          sltest.testsequence.editSymbol(blockPath,name,Name,Value)
          Description
          sltest.testsequence.editSymbol(blockPath,name,Name,Value) edits a symbol name with
          properties specified by Name,Value in a Test Sequence block specified by blockPath. Symbols
          include data, function calls, messages, and triggers.
Examples
          This example edits constant DurationLimit in the Test Sequence block, changing it to a local
          variable of single data type.
          Model = 'sltestRollRefTestExample';
          load_system(Model)
          data_names = sltest.testsequence.findSymbol...
              ('sltestRollRefTestExample/Test Sequence','Name','[Dd]uration',...
              'RegExp','on','Kind','Data')
          dlProperties = sltest.testsequence.readSymbol...
              ('sltestRollRefTestExample/Test Sequence',data_names{1})
1-134
                                                                           sltest.testsequence.editSymbol
sltest.testsequence.editSymbol('sltestRollRefTestExample/Test Sequence',...
    data_names{1},'Scope','Local','DataType','single')
close_system(Model,0)
Input Arguments
blockPath — Test Sequence block path
string | character vector
Path to a Test Sequence block, including the block name, specified as a string or character vector.
Example: 'FanSpeedTestHarness/Test Sequence'
Name of the symbol, specified as a character vector. For the symbol that controls the active scenario,
you can change only its name using the 'Name' name-value pair.
Example: 'theta'
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
See Also
sltest.testsequence.addStep | sltest.testsequence.addStepAfter |
sltest.testsequence.addStepBefore | sltest.testsequence.addTransition |
sltest.testsequence.editStep | sltest.testsequence.find
Topics
“Programmatically Create a Test Sequence”
Introduced in R2017a
                                                                                                  1-135
1   Functions
          sltest.testsequence.editTransition
          Edit test sequence step transition
          Syntax
          sltest.testsequence.editTransition(blockPath,stepPath,index,Name,Value)
          Description
          sltest.testsequence.editTransition(blockPath,stepPath,index,Name,Value) edits
          transition index in stepPath of the Test Sequence block blockPath. Transition properties are
          specified by Name,Value.
          Examples
          Add and Edit a Test Step Transition
          This example adds a transition to a test step, then changes the transition's index, condition, and next
          step of the first transition in the step.
          3. Edit the transition index, condition, and next step of the first transition.
          sltest.testsequence.editTransition('sltestRollRefTestExample/Test Sequence',...
          'AttitudeLevels.APEngage_LowRoll',1,'Index',2,...
          'NextStep','AttitudeLevels.APEngage_HighRoll',...
          'Condition','duration(DD_PhiRef == 0,sec) >= 5')
          Input Arguments
          blockPath — Test Sequence block path
          string | character vector
          Path to a Test Sequence block, including the block name, specified as a string or character vector.
          Example: 'FanSpeedTestHarness/Test Sequence'
1-136
                                                                          sltest.testsequence.editTransition
Path of the step in the Test Sequence block, specified as a character vector. The path includes the
step location in the Test Sequence hierarchy, using . to separate hierarchy levels. If the Test
Sequence block is using scenarios, add the scenario name that contains the step to the beginning of
the step path, for example, Scenario_2.SystemHeatingTest.InitializeHeating.
Example: 'SystemHeatingTest.InitializeHeating'
Integer specifying the transition in the test step to be edited. Corresponds to the integer displayed in
the Transition cell of the Test Sequence Editor.
Example: 3
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Example: 'Condition','error == 1','NextStep','Stop','Index', 3
The condition on which the transition executes, specified as a character vector. To execute the
transition, enter a valid logical expression.
Example: 'theta == 0 && a == 1'
The name of the destination step of the transition, which is next in the sequence if the transition
condition is satisfied.
Example: 'RampAngle'
See Also
sltest.testsequence.addStep | sltest.testsequence.addTransition |
sltest.testsequence.deleteTransition | sltest.testsequence.readTransition
Topics
“Programmatically Create a Test Sequence”
                                                                                                    1-137
1   Functions
Introduced in R2017a
1-138
                                                                                 sltest.testsequence.find
sltest.testsequence.find
Find Test Sequence blocks
Syntax
blocks = sltest.testsequence.find
Description
blocks = sltest.testsequence.find returns a cell array blocks listing Test Sequence blocks
in open models.
Examples
This example opens a test harness and finds the paths to the two Test Sequence blocks contained in
the test harness.
open_system('sltestTestSequenceWhenExample')
sltest.harness.open('sltestTestSequenceWhenExample/SimpleTracker',...
'SimpleTrackerHarness')
Find the Test Sequence blocks. One of the blocks is used specifically for Test Assessment.
blocks = sltest.testsequence.find
blocks =
Column 1
'SimpleTrackerHarn…'
Column 2
'SimpleTrackerHarn…'
See Also
sltest.testsequence.findStep | sltest.testsequence.findSymbol |
sltest.testsequence.getProperty | sltest.testsequence.readStep |
sltest.testsequence.readSymbol | sltest.testsequence.readTransition
Introduced in R2016a
                                                                                                 1-139
1   Functions
          sltest.testsequence.findStep
          Find test sequence steps
          Syntax
          steps = sltest.testsequence.findStep(Name,Value)
          Description
          steps = sltest.testsequence.findStep(Name,Value) returns a cell array steps listing Test
          Sequence steps that match properties specified by Name,Value pairs.
Examples
          Model = 'sltestRollRefTestExample';
          load_system(Model)
2. Find test sequence steps that contain the case-insensitive string apeng.
Columns 4 through 6
Columns 7 through 9
Column 10
{'AttitudeLevels...'}
steps(3)
1-140
                                                                          sltest.testsequence.findStep
close_system(Model,0)
Input Arguments
Name-Value Pair Arguments
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Example: 'Name','[Aa][Pp][Ee]ng','RegExp','on'
Specifies case
Example: 'CaseSensitive','on'
Specify whether to search the step names using Name as a regular expression
Example: 'RegExp','on'
Output Arguments
steps — Test sequence steps
cell array
See Also
sltest.testsequence.editStep | sltest.testsequence.find |
sltest.testsequence.findSymbol | sltest.testsequence.readStep |
sltest.testsequence.readSymbol | sltest.testsequence.readTransition
Introduced in R2017a
                                                                                               1-141
1   Functions
          sltest.testsequence.findSymbol
          Find Test Sequence block symbols
          Syntax
          symbols = sltest.testsequence.findSymbol(blockPath,Name,Value)
          Description
          symbols = sltest.testsequence.findSymbol(blockPath,Name,Value) returns symbols in
          the Test Sequence block blockPath matching properties specified by Name,Value pairs. Symbols
          include data, messages, function calls, and triggers.
Examples
          This example edits constant DurationLimit in the Test Sequence block, changing it to a local
          variable of single data type.
          Model = 'sltestRollRefTestExample';
          load_system(Model)
          data_names = sltest.testsequence.findSymbol...
              ('sltestRollRefTestExample/Test Sequence','Name','[Dd]uration',...
              'RegExp','on','Kind','Data')
          dlProperties = sltest.testsequence.readSymbol...
              ('sltestRollRefTestExample/Test Sequence',data_names{1})
1-142
                                                                           sltest.testsequence.findSymbol
sltest.testsequence.editSymbol('sltestRollRefTestExample/Test Sequence',...
    data_names{1},'Scope','Local','DataType','single')
close_system(Model,0)
Input Arguments
blockPath — Test Sequence block path
string | character vector
Path to a Test Sequence block, including the block name, specified as a string or character vector.
Example: 'FanSpeedTestHarness/Test Sequence'
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Example: 'Kind','Message','Scope','Output'
Example: 'Kind','Data','Name','[Aa]ngle','RegExp','on'
The scope defines how the data symbol operates in the block. It is specified as a character vector.
Example: 'Data'
Specifies case
Example: 'CaseSensitive','on'
                                                                                                  1-143
1   Functions
          Specify whether to search the step names using Name as a regular expression
          Example: 'RegExp','on'
          Output Arguments
          symbols — Block symbols
          cell array
          See Also
          sltest.testsequence.deleteSymbol | sltest.testsequence.editSymbol |
          sltest.testsequence.find | sltest.testsequence.findStep |
          sltest.testsequence.readSymbol
          Topics
          “Programmatically Create a Test Sequence”
Introduced in R2017a
1-144
                                                                  sltest.testsequence.getActiveScenario
sltest.testsequence.getActiveScenario
Package: sltest.testsequence
Syntax
active_scenario = sltest.testsequence.getActiveScenario(blockPath)
Description
active_scenario = sltest.testsequence.getActiveScenario(blockPath) returns the
name of the active scenario for the Test Sequence block specified by blockPath. The active scenario
is the scenario that runs during model simulation.
Examples
Set the Test Sequence block in the sltestRollRefTestExample model to use scenarios. Add
another scenario named new_Scenario and activate it. Then, get the name of the currently active
scenario. You can use getActiveScenario only if you have set
sltest.testsequence.setScenarioControlSource to
sltest.testsequence.ScenarioControlSource.Block, which sets the active scenario control
to a Test Sequence block instead of a variable in the workspace.
Model = 'sltestRollRefTestExample';
load_system(Model);
sltest.testsequence.useScenario...
   ('sltestRollRefTestExample/Test Sequence',...
   'Scenario_1');
sltest.testsequence.addScenario...
   ('sltestRollRefTestExample/Test Sequence',...
   'new_Scenario');
sltest.testsequence.activateScenario...
   ('sltestRollRefTestExample/Test Sequence',...
   'new_Scenario');
active_scenario = sltest.testsequence.getActiveScenario...
   ('sltestRollRefTestExample/Test Sequence')
active_scenario =
'new_Scenario'
                                                                                                1-145
1   Functions
close_system(Model,0)
          Input Arguments
          blockPath — Test Sequence block path
          string | character vector
          Path to a Test Sequence block, including the block name, specified as a string or character vector.
          Example: 'FanSpeedTestHarness/Test Sequence'
          Output Arguments
          active_scenario — Active Test Sequence block scenario name
          character vector
          See Also
          activateScenario | getAllScenarios | setScenarioControlSource |
          sltest.testsequence.useScenario
          Topics
          “Programmatically Create Multiple Scenarios in a Test Sequence Block”
Introduced in R2020b
1-146
                                                                  sltest.testsequence.getAllScenarios
sltest.testsequence.getAllScenarios
Package: sltest.testsequence
Syntax
all_scenarios = sltest.testsequence.getAllScenarios(blockPath)
Description
all_scenarios = sltest.testsequence.getAllScenarios(blockPath) returns the names
of all scenarios in a Test Sequence block specified by blockPath.
Examples
Set the Test Sequence block in the sltestRollRefTestExample model to use scenarios. Add
another scenario named new_Scenario. Then, get the names of all scenarios in the Test Sequence
block.
Model = 'sltestRollRefTestExample';
load_system(Model);
sltest.testsequence.useScenario...
   ('sltestRollRefTestExample/Test Sequence',...
   'Scenario_1');
sltest.testsequence.addScenario...
   ('sltestRollRefTestExample/Test Sequence',...
   'new_Scenario');
all_scenarios = sltest.testsequence.getAllScenarios...
   ('sltestRollRefTestExample/Test Sequence')
all_scenarios =
{'Scenario_1'} {'new_Scenario'}
close_system(Model,0)
Input Arguments
blockPath — Test Sequence block path
string | character vector
                                                                                              1-147
1   Functions
          Path to a Test Sequence block, including the block name, specified as a string or character vector.
          Example: 'FanSpeedTestHarness/Test Sequence'
          Output Arguments
          all_scenarios — Names of all scenarios in Test Sequence block
          cell array
          See Also
          addScenario | sltest.testsequence.useScenario
          Topics
          “Programmatically Create Multiple Scenarios in a Test Sequence Block”
Introduced in R2020b
1-148
                                                                        sltest.testsequence.getProperty
sltest.testsequence.getProperty
Get Test Sequence block properties
Syntax
blockInfo = sltest.testsequence.getProperty(blockPath)
blockInfo = sltest.testsequence.getProperty(blockPath,propertyName)
Description
blockInfo = sltest.testsequence.getProperty(blockPath) returns a struct blockInfo
containing properties of the Test Sequence block specified by blockPath.
Examples
This example gets and sets properties for a Test Sequence block using the programmatic interface.
Model = 'sltestRollRefTestExample';
load_system(Model)
blockUpdateMethod = sltest.testsequence.getProperty(...
    [Model '/Test Sequence'],'UpdateMethod')
                                                                                                1-149
1   Functions
          blockUpdateMethod =
          'INHERITED'
4. Change the Test Sequence block update method and sample time.
close_system(Model,0)
          Input Arguments
          blockPath — Test Sequence block path
          string | character vector
          Path to a Test Sequence block, including the block name, specified as a string or character vector.
          Example: 'FanSpeedTestHarness/Test Sequence'
          Name of a particular Test Sequence block property for which to get a value.
          Example: 'Description'
          Output Arguments
          blockInfo — Block properties or property value
          struct | character vector | logical
1-150
                                                                          sltest.testsequence.getProperty
See Also
sltest.testsequence.find | sltest.testsequence.readStep |
sltest.testsequence.readSymbol | sltest.testsequence.readTransition |
sltest.testsequence.setProperty
Topics
“Programmatically Create a Test Sequence”
Introduced in R2017a
                                                                                                  1-151
1   Functions
          sltest.testsequence.getScenarioControlSource
          Package: sltest.testsequence
          Syntax
          scenarioCtrlSource = sltest.testsequence.getScenarioControlSource(blockPath)
          Description
          scenarioCtrlSource = sltest.testsequence.getScenarioControlSource(blockPath)
          returns the source that controls the active scenario for the Test Sequence block specified by
          blockPath.
Examples
          Set the Test Sequence block in the sltestRollRefTestExample model to use scenarios. Set the
          control source to the workspace. Then, get the name of the source that controls the active scenario.
          Model = 'sltestRollRefTestExample';
          load_system(Model);
          sltest.testsequence.useScenario...
             ('sltestRollRefTestExample/Test Sequence',...
             'Scenario_1');
          sltest.testsequence.setScenarioControlSource...
             ('sltestRollRefTestExample/Test Sequence',...
              sltest.testsequence.ScenarioControlSource.Workspace);
          scenarioControlSource = ...
             sltest.testsequence.getScenarioControlSource...
             ('sltestRollRefTestExample/Test Sequence')
scenarioCtrlSource =
ScenarioControlSource enumeration
Workspace
close_system(Model,0)
          Input Arguments
          blockPath — Test Sequence block path
          string | character vector
1-152
                                                              sltest.testsequence.getScenarioControlSource
Path to a Test Sequence block, including the block name, specified as a string or character vector.
Example: 'FanSpeedTestHarness/Test Sequence'
Output Arguments
scenarioCtrlSource — Active scenario control source
sltest.testsequence.ScenarioControlSource.Block |
sltest.testsequence.ScenarioControlSource.Workspace
See Also
setScenarioControlSource | sltest.testsequence.useScenario
Topics
“Programmatically Create Multiple Scenarios in a Test Sequence Block”
Introduced in R2020b
                                                                                                   1-153
1   Functions
          sltest.testsequence.isUsingScenarios
          Package: sltest.testsequence
          Syntax
          TF = sltest.testsequence.isUsingScenarios(blockPath)
          Description
          TF = sltest.testsequence.isUsingScenarios(blockPath) returns whether the Test
          Sequence block specified by blockPath uses scenarios.
Examples
          Check whether the Test Sequence block in the sltestRollRefTestExample model uses scenarios.
          In this case, the block has not been set to use scenarios, so isUsingScenarios returns false.
          Model = 'sltestRollRefTestExample';
          load_system(Model);
          use_scen = sltest.testsequence.isUsingScenarios...
             ('sltestRollRefTestExample/Test Sequence')
use_scen =
logical
close_system(Model,0)
          Input Arguments
          blockPath — Test Sequence block path
          string | character vector
          Path to a Test Sequence block, including the block name, specified as a string or character vector.
          Example: 'FanSpeedTestHarness/Test Sequence'
          See Also
          sltest.testsequence.useScenario
1-154
                                                                  sltest.testsequence.isUsingScenarios
Topics
“Programmatically Create Multiple Scenarios in a Test Sequence Block”
Introduced in R2020b
                                                                                               1-155
1   Functions
          sltest.testsequence.newBlock
          Create Test Sequence block
          Syntax
          blockID = sltest.testsequence.newBlock(blockPath)
          Description
          blockID = sltest.testsequence.newBlock(blockPath) adds a Test Sequence block specified
          by blockPath, returning the handle blockID.
Examples
          This example shows how to create a Test Sequence block programmatically, and get properties for the
          block, which can be used in Name, Value pairs for sltest.testsequence.setProperty.
          new_system('tsb_model');
          sltest.testsequence.newBlock('tsb_model/Test Sequence');
close_system('tsb_model',0)
1-156
                                                                            sltest.testsequence.newBlock
Input Arguments
blockPath — Test Sequence block path
string | character vector
Path to a Test Sequence block, including the block name, specified as a string or character vector.
Example: 'FanSpeedTestHarness/Test Sequence'
Output Arguments
blockID — Handle to the block
double
See Also
sltest.testsequence.find | sltest.testsequence.getProperty |
sltest.testsequence.setProperty
Topics
“Programmatically Create a Test Sequence”
Introduced in R2017a
                                                                                                 1-157
1   Functions
          sltest.testsequence.readStep
          Read Test Sequence block steps
          Syntax
          stepInfo = sltest.testsequence.readStep(blockPath,stepPath)
          stepInfo = sltest.testsequence.readStep(blockPath,stepPath,Property)
          Description
          stepInfo = sltest.testsequence.readStep(blockPath,stepPath) returns a struct
          stepInfo of properties for the test step stepPath in the Test Sequence block blockPath.
Examples
This example reads properties of a test step and a transition in a Test Sequence block.
          stepAction =
              'Phi = 11.5;
               APEng = false;'
1-158
                                                                             sltest.testsequence.readStep
close_system(Model,0)
Input Arguments
blockPath — Test Sequence block path
string | character vector
Path to a Test Sequence block, including the block name, specified as a string or character vector.
Example: 'FanSpeedTestHarness/Test Sequence'
Path of the step in the Test Sequence block, specified as a character vector. The path includes the
step location in the Test Sequence hierarchy, using . to separate hierarchy levels. If the Test
Sequence block is using scenarios, add the scenario name that contains the step to the beginning of
the step path, for example, Scenario_2.SystemHeatingTest.InitializeHeating.
Example: 'SystemHeatingTest.InitializeHeating'
Output Arguments
stepInfo — Test step properties
struct | character vector | logical | numeric
                                                                                                  1-159
1   Functions
          See Also
          sltest.testsequence.deleteStep | sltest.testsequence.editStep |
          sltest.testsequence.find | sltest.testsequence.findStep |
          sltest.testsequence.readSymbol | sltest.testsequence.readTransition
          Topics
          “Programmatically Create a Test Sequence”
Introduced in R2017a
1-160
                                                                       sltest.testsequence.readSymbol
sltest.testsequence.readSymbol
Read Test Sequence block symbol properties
Syntax
symbolInfo = sltest.testsequence.readSymbol(blockPath,symbol)
symbolInfo = sltest.testsequence.readSymbol(blockPath,symbol,Property)
Description
symbolInfo = sltest.testsequence.readSymbol(blockPath,symbol) returns a struct
symbolInfo of properties for symbol in the Test Sequence block specified by blockPath.
Examples
This example edits constant DurationLimit in the Test Sequence block, changing it to a local
variable of single data type.
Model = 'sltestRollRefTestExample';
load_system(Model)
data_names = sltest.testsequence.findSymbol...
    ('sltestRollRefTestExample/Test Sequence','Name','[Dd]uration',...
    'RegExp','on','Kind','Data')
dlProperties = sltest.testsequence.readSymbol...
    ('sltestRollRefTestExample/Test Sequence',data_names{1})
                                                                                               1-161
1   Functions
                        Size: ''
                         Tag: []
          sltest.testsequence.editSymbol('sltestRollRefTestExample/Test Sequence',...
              data_names{1},'Scope','Local','DataType','single')
close_system(Model,0)
          Input Arguments
          blockPath — Test Sequence block path
          string | character vector
          Path to a Test Sequence block, including the block name, specified as a string or character vector.
          Example: 'FanSpeedTestHarness/Test Sequence'
          Test Sequence block symbol name, specified as a character vector. Symbols include data, messages,
          function calls, and triggers used as inputs, outputs, local variables, constants, parameters, or data
          store memory in the Test Sequence block.
          Example: 'DurationLimit'
          Test Sequence block symbol property, specified as a character vector. To find valid properties for a
          particular symbol, read properties of the symbol using
          sltest.testsequence.readSymbol(blockPath,symbol).
          Example: 'Kind'
          Example: 'Scope'
          Example: 'DataType''Description'
          Output Arguments
          symbolInfo — Test Sequence block symbol properties
          struct | character vector | logical | numeric
1-162
                                                          sltest.testsequence.readSymbol
See Also
sltest.testsequence.addSymbol | sltest.testsequence.deleteSymbol |
sltest.testsequence.findSymbol | sltest.testsequence.readStep |
sltest.testsequence.readTransition
Topics
“Programmatically Create a Test Sequence”
Introduced in R2017a
                                                                                 1-163
1   Functions
          sltest.testsequence.readTransition
          Read properties of test sequence transition
          Syntax
          transitionInfo = sltest.testsequence.readTransition(blockPath,stepPath,index)
          transitionInfo = sltest.testsequence.readTransition(blockPath,stepPath,index,
          Property)
          Description
          transitionInfo = sltest.testsequence.readTransition(blockPath,stepPath,index)
          returns a struct transitionInfo of properties for the transition index, in the test step stepPath
          of the Test Sequence block blockPath.
          transitionInfo = sltest.testsequence.readTransition(blockPath,stepPath,index,
          Property) returns the value transitionInfo of the Property for the transition.
Examples
This example reads properties of a test step and a transition in a Test Sequence block.
          stepAction =
              'Phi = 11.5;
1-164
                                                                          sltest.testsequence.readTransition
APEng = false;'
Input Arguments
blockPath — Test Sequence block path
string | character vector
Path to a Test Sequence block, including the block name, specified as a string or character vector.
Example: 'FanSpeedTestHarness/Test Sequence'
Path of the step in the Test Sequence block, specified as a character vector. The path includes the
step location in the Test Sequence hierarchy, using . to separate hierarchy levels. If the Test
Sequence block is using scenarios, add the scenario name that contains the step to the beginning of
the step path, for example, Scenario_2.SystemHeatingTest.InitializeHeating.
Example: 'SystemHeatingTest.InitializeHeating'
Integer specifying the transition in the test step to be edited. Corresponds to the integer displayed in
the Transition cell of the Test Sequence Editor.
Example: 3
Transition property, specified as a character vector. To find valid properties for a particular symbol,
read properties of the symbol using
sltest.testsequence.readTransition(blockPath,stepPath,index).
Example: 'Step'
Example: 'Index'
Example: 'Condition'
                                                                                                    1-165
1   Functions
Example: 'NextStep'
          Output Arguments
          transitionInfo — Transition properties
          struct | character vector | numeric
          See Also
          sltest.testsequence.addTransition | sltest.testsequence.deleteTransition |
          sltest.testsequence.editTransition | sltest.testsequence.findStep |
          sltest.testsequence.readStep | sltest.testsequence.readSymbol
          Topics
          “Programmatically Create a Test Sequence”
Introduced in R2017a
1-166
                                                                       sltest.testsequence.setProperty
sltest.testsequence.setProperty
Set Test Sequence block properties
Syntax
sltest.testsequence.setProperty(blockPath,Name,Value)
Description
sltest.testsequence.setProperty(blockPath,Name,Value) sets properties of the Test
Sequence block specified by blockPath according to one or more Name, Value pairs. Obtain valid
properties using sltest.testsequence.getProperty.
Note All properties, except ActiveStepDataSymbol, are writable. You cannot change the value of
ActiveStepDataSymbol using sltest.testsequence.setProperty. You can, however, rename
the symbol using sltest.testsequence.editSymbol.
Examples
This example shows how to create a Test Sequence block programmatically, and get properties for the
block, which can be used in Name, Value pairs for sltest.testsequence.setProperty.
                                                                                               1-167
1   Functions
close_system('tsb_model',0)
This example gets and sets properties for a Test Sequence block using the programmatic interface.
          Model = 'sltestRollRefTestExample';
          load_system(Model)
          blockUpdateMethod = sltest.testsequence.getProperty(...
              [Model '/Test Sequence'],'UpdateMethod')
          blockUpdateMethod =
          'INHERITED'
4. Change the Test Sequence block update method and sample time.
1-168
                                                                           sltest.testsequence.setProperty
    SaturateOnIntegerOverflow:       1
                  InputFimath:       'fimath(......'
             EmlDefaultFimath:       'Same as MATLAB Default'
         EnableActiveStepData:       0
         ActiveStepDataSymbol:       ''
            ScenarioParameter:       ''
close_system(Model,0)
Input Arguments
blockPath — Test Sequence block path
string | character vector
Path to a Test Sequence block, including the block name, specified as a string or character vector.
Example: 'FanSpeedTestHarness/Test Sequence'
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Example: 'Description','Temperature cycle','EnableActiveStepData',true
Valid name-value pairs are block-specific. Obtain properties for the block using
sltest.testsequence.getProperty.
See Also
sltest.testsequence.editSymbol | sltest.testsequence.find |
sltest.testsequence.getProperty | sltest.testsequence.newBlock
Topics
“Programmatically Create a Test Sequence”
Introduced in R2017a
                                                                                                   1-169
1   Functions
          sltest.testsequence.setScenarioControlSource
          Package: sltest.testsequence
          Syntax
          sltest.testsequence.setScenarioControlSource(blockPath,scenarioControlSource)
          Description
          sltest.testsequence.setScenarioControlSource(blockPath,scenarioControlSource)
          sets the source, specified by scenarioControlSource, that controls the active scenario for the Test
          Sequence block specified by blockPath.
Examples
          Set the Test Sequence block in the sltestRollRefTestExample model to use scenarios. Set the
          source that controls the active scenario for the Test Sequence block in the
          sltestRollRefTestModel to the workspace. Close the model without saving it.
          Model = 'sltestRollRefTestExample';
          load_system(Model);
          sltest.testsequence.useScenario...
             ('sltestRollRefTestExample/Test Sequence',...
             'Scenario_1');
          sltest.testsequence.activateScenario...
             ('sltestRollRefTestExample/Test Sequence',...
             'Scenario_1');
          sltest.testsequence.setScenarioControlSource...
             ('sltestRollRefTestExample/Test Sequence',...
              sltest.testsequence.ScenarioControlSource.Workspace);
close_system(Model,0)
          Input Arguments
          blockPath — Test Sequence block path
          string | character vector
          Path to a Test Sequence block, including the block name, specified as a string or character vector.
          Example: 'FanSpeedTestHarness/Test Sequence'
1-170
                                                             sltest.testsequence.setScenarioControlSource
See Also
getScenarioControlSource | sltest.testsequence.useScenario
Topics
“Programmatically Create Multiple Scenarios in a Test Sequence Block”
Introduced in R2020b
                                                                                                  1-171
1   Functions
          sltest.testsequence.useScenario
          Package: sltest.testsequence
          Syntax
          sltest.testsequence.useScenario(blockPath,scenarioName)
          Description
          sltest.testsequence.useScenario(blockPath,scenarioName) converts the Test Sequence
          block, specified by blockPath, to use scenarios. Scenarios are tabs in the Test Sequence editor that
          enable you to define and run separate test sequences in a single Test Sequence block. After
          conversion, all existing steps in the block are moved to a scenario tab named scenarioName. If you
          convert a Test Sequence block to use scenarios, you cannot revert the block to non-scenario mode,
          even if it contains only one scenario.
Examples
          Change the Test Sequence block in the sltestRollRefTestModel to use scenarios and name the
          first scenario Scenario_1. Then, close the model without saving it.
          Model = 'sltestRollRefTestExample';
          load_system(Model);
          sltest.testsequence.useScenario...
             ('sltestRollRefTestExample/Test Sequence',...
             'Scenario_1');
close_system(Model,0)
          Input Arguments
          blockPath — Test Sequence block path
          string | character vector
          Path to a Test Sequence block, including the block name, specified as a string or character vector.
          Example: 'FanSpeedTestHarness/Test Sequence'
1-172
                                                                        sltest.testsequence.useScenario
See Also
activateScenario | addScenario | isUsingScenarios | setScenarioControlSource
Topics
“Programmatically Create Multiple Scenarios in a Test Sequence Block”
Introduced in R2020b
                                                                                                1-173
1   Functions
          sltestiteration
          Create test iteration
          Syntax
          iterObj = sltestiteration
          Description
          iterObj = sltestiteration returns a test iteration object,
          sltest.testmanager.TestIteration. You can use the function in the MATLAB command
          window, or you can use it in the context of a scripted iteration under the Iterations section of a test
          case. For more information on creating test iterations, see “Test Iterations”.
Examples
          This example is a script that must be entered in the Scripted Iterations script text box under the
          Iterations section of a test case. Also, the system under test for this example is a model that contains
          Signal Builder groups.
          Output Arguments
          iterObj — Test iteration
          sltest.testmanager.TestIteration object
1-174
                                           sltestiteration
See Also
sltest.testmanager.TestIteration
Topics
“Test Iterations”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                  1-175
          2
Classes
2     Classes
            sltest.Assessment
            Access assessment from set
            Description
            An sltest.Assessment object is an individual assessment result from an sltest.AssessmentSet
            object.
            Creation
            Create an sltest.Assessment object using result = get(as,index) where as is an
            sltest.AssessmentSet object.
            Properties
            BlockPath — Path to assessment
            fully specified Simulink block path
            Path to block containing the assessment. For a Test Sequence block, the sub path is a path to the test
            step containing the assessment. See Simulink.SimulationData.BlockPath.
            Example: Simulink.SimulationData.BlockPath
            Name of the assessment, specified as a character vector. For a verify() statement, results in the
            Test Manager are identified by the name.
            Example: 'Simulink:verify_low'
            Object Functions
            disp   Display results of sltest.AssessmentSet or sltest.Assessment
            find   Find assessments in sltest.AssessmentSet or sltest.Assessment object
            plot   Plot simulation output data in the Simulation Data Inspector
2-2
                                                                                 sltest.Assessment
Examples
This example shows how to simulate a model with verify statements and obtain assessment results
via the programmatic interface.
open_system('sltestRollRefTestExample.slx')
s = sim('sltestRollRefTestExample');
as = sltest.getAssessments('sltestRollRefTestExample');
as3 = get(as,3);
asSummary = getSummary(as)
                                                                                              2-3
2     Classes
asSummary =
                     Total:    6
                  Untested:    3
                    Passed:    2
                    Failed:    1
                    Result:    Fail
disp(as3)
                sltest.Assessment
                Package: sltest
                Properties:
                       Name:   'Simulink:verify_high'
                  BlockPath:   [1x1 Simulink.SimulationData.BlockPath]
                     Values:   [1x1 timeseries]
                     Result:   Fail
            asFailUntested = find(as,'Result',slTestResult.Fail,'-or',...
                'Result',slTestResult.Untested)
asFailUntested =
                sltest.AssessmentSet
                Summary:
                     Total: 4
                  Untested: 3
                    Passed: 0
                    Failed: 1
                    Result: Fail
4. Find assessments under the Test Assessment block, using a regular expression.
assessBlock = find(as,'-regexp','BlockPath','.[Aa]ssess')
assessBlock =
sltest.AssessmentSet
2-4
                                                      sltest.Assessment
  Summary:
       Total:   6
    Untested:   3
      Passed:   2
      Failed:   1
      Result:   Fail
Re-enable warnings
warning on Stateflow:Runtime:TestVerificationFailed
See Also
sltest.AssessmentSet | sltest.getAssessments
Introduced in R2016b
                                                                   2-5
2     Classes
            sltest.AssessmentSet
            Access a set of assessments from a simulation
            Description
            The function as = sltest.getAssessments('model') creates an sltest.AssessmentSet
            object as containing the assessments for model. Individual assessment results are obtained using
            result = get(as,index). getSummary(as) returns an overview of the assessment set. disp
            returns an overview of individual assessment results.
            Creation
            Create an sltest.AssessmentSet object using sltest.getAssessments.
            Object Functions
            disp           Display results of sltest.AssessmentSet or sltest.Assessment
            find           Find assessments in sltest.AssessmentSet or sltest.Assessment object
            get            Get assessment of sltest.AssessmentSet
            getSummary     Get summary of sltest.AssessmentSet
Examples
            This example shows how to simulate a model with verify statements and obtain assessment results
            via the programmatic interface.
open_system('sltestRollRefTestExample.slx')
2-6
                                                              sltest.AssessmentSet
asSummary =
       Total:   6
    Untested:   3
      Passed:   2
      Failed:   1
      Result:   Fail
  sltest.Assessment
  Package: sltest
                                                                              2-7
2     Classes
                Properties:
                       Name:   'Simulink:verify_high'
                  BlockPath:   [1x1 Simulink.SimulationData.BlockPath]
                     Values:   [1x1 timeseries]
                     Result:   Fail
            asFailUntested = find(as,'Result',slTestResult.Fail,'-or',...
                'Result',slTestResult.Untested)
asFailUntested =
                sltest.AssessmentSet
                Summary:
                     Total: 4
                  Untested: 3
                    Passed: 0
                    Failed: 1
                    Result: Fail
4. Find assessments under the Test Assessment block, using a regular expression.
assessBlock = find(as,'-regexp','BlockPath','.[Aa]ssess')
assessBlock =
                sltest.AssessmentSet
                Summary:
                     Total: 6
                  Untested: 3
                    Passed: 2
                    Failed: 1
                    Result: Fail
2-8
                                                      sltest.AssessmentSet
Re-enable warnings
warning on Stateflow:Runtime:TestVerificationFailed
See Also
sltest.Assessment | sltest.getAssessments
Introduced in R2016b
                                                                      2-9
2   Classes
          sltest.plugins.ModelCoveragePlugin class
          Package: sltest.plugins
          Description
          The sltest.plugins.ModelCoveragePlugin creates coverage reports and allows setting
          coverage metrics for running Simulink Test and MATLAB-based Simulink test cases with the MATLAB
          Unit Test framework. Set desired sltest.plugins.ModelCoveragePlugin property values, and
          add the instance of the sltest.plugins.ModelCoveragePlugin to the test runner. For MATLAB-
          based Simulink tests, calls to the simulate method collect coverage during the test run. These
          coverage results are available in the Test Manager results.
          Creation
          mcp = sltest.plugins.ModelCoveragePlugin(Properties) creates a model coverage plugin
          object mcp with specified properties.
You can also import the plugin, then use the class name to create an instance of the plugin:
          import sltest.plugins.ModelCoveragePlugin
          mcp = ModelCoveragePlugin(Properties)
          Properties
          RecordModelReferenceCoverage — Specify coverage collection for referenced models
          false | true
          Property that disables or enables coverage collection for models referenced by Model blocks.
          Example: 'RecordModelReferenceCoverage',true
          Attributes:
          SetAccess                                                    public
          GetAccess                                                    public
2-10
                                                                  sltest.plugins.ModelCoveragePlugin class
Attributes:
SetAccess                                                      public
GetAccess                                                      public
SetAccess                                                      public
GetAccess                                                      public
Examples
Collect Model Coverage with MATLAB® Unit Test
This example shows how to use MATLAB® Unit Test to collect coverage for tests run on a Simulink®
model.
You run the tests in the AutopilotTestFile.mldatx test file while collecting modified condition/
decision (MCDC) coverage.
1. Import the test runner and the plugins for the example.
import matlab.unittest.TestRunner
import sltest.plugins.ModelCoveragePlugin
import sltest.plugins.coverage.CoverageMetrics
2. Create the model coverage plugin object and the coverage metrics object. In this example, you use
MCDC coverage and record coverage for referenced models.
mcdcMet = CoverageMetrics('Decision',false,'Condition',false,'MCDC',true);
covSettings = ModelCoveragePlugin('RecordModelReferenceCoverage',true,...
    'Collecting',mcdcMet);
3. Create a MATLAB® Unit Test test suite from the test file.
tf = sltest.testmanager.TestFile('AutopilotTestFile.mldatx');
APSuite = testsuite(tf.FilePath);
4. Create the test runner without any plugins, then add the coverage plugin to the runner.
APRun = TestRunner.withNoPlugins();
addPlugin(APRun,covSettings);
                                                                                                    2-11
2   Classes
APResult = run(APRun,APSuite)
          APResult =
            TestResult with properties:
                    Name:   'AutopilotTestFile > New Test Suite 1/New Test Case 1'
                  Passed:   0
                  Failed:   1
              Incomplete:   0
                Duration:   0.2545
                 Details:   [1x1 struct]
          Totals:
             0 Passed, 1 Failed (rerun), 0 Incomplete.
             0.25449 seconds testing time.
6. You can open the link in the command-line output to view the coverage report.
          warning on Stateflow:cdr:VerifyDangerousComparison
          warning on Stateflow:Runtime:TestVerificationFailed
          sltest.testmanager.clearResults;
          sltest.testmanager.clear;
          sltest.testmanager.close;
          See Also
          sltest.plugins.MATLABTestCaseIntegrationPlugin |
          sltest.plugins.ToTestManagerLog | sltest.plugins.coverage.CoverageMetrics |
          sltest.plugins.coverage.ModelCoverageReport
          Topics
          “Test Models Using MATLAB Unit Test”
          “Collect Coverage Using MATLAB-Based Simulink Tests”
          “Test Models Using MATLAB-Based Simulink Tests”
Introduced in R2018a
2-12
                                                     sltest.plugins.MATLABTestCaseIntegrationPlugin class
sltest.plugins.MATLABTestCaseIntegrationPlugin
class
Package: sltest.plugins
Add simulation and test results for MATLAB-based Simulink tests to Test Manager
Description
The sltest.plugins.MATLABTestCaseIntegrationPlugin adds simulation and test results to
the Test Manager test case results for MATLAB-based Simulink tests. A MATLAB-based Simulink test
is a MATLAB code (.m) file that is derived from the sltest.TestCase class. When you add this
plugin to a TestRunner object and run the simulation, these results are added to the Test Manager:
• Test results are created for each test suite element of an sltest.TestCase class when you run
  the test case at the MATLAB command line.
• By default, criteria results are added for suite element failures from the
  fatalAssertSignalsMatch, assertSignalsMatch, assumeSignalsMatch, and
  verifySignalsMatch qualification methods. A comparison run for these failures is added under
  the corresponding test case result. For passing comparison runs, add the
  matlab.unittest.plugins.DiagnosticsOutputPlugin with passing diagnostics enabled to
  the TestRunner.
Simulation results, which are created using the simulate method, are added to the corresponding
test case results.
Creation
To use the MATLABTestCaseIntegrationPlugin, add it to the TestRunner object:
import sltest.plugins.MATLABTestCaseIntegrationPlugin
testRunner.addPlugin...
   (sltest.plugins.MATLABTestCaseIntegrationPlugin());
Examples
    import   matlab.unittest.TestRunner
    import   matlab.unittest.plugins.DiagnosticsOutputPlugin
    import   sltest.plugins.MATLABTestCaseIntegrationPlugin
    import   sltest.plugins.ToTestManagerLog
2   Create a TestSuite array and basic TestRunner object for a test script file, such as one named
    mySltestTestCaseFile.m.
                                                                                                   2-13
2   Classes
              suite = testsuite('mySltestTestCaseFile.m');
              runner = TestRunner.withNoPlugins;
              runner.addPlugin(MATLABTestCaseIntegrationPlugin);
          4   Run the suite to add the failing diagnostics and simulation results to the Test Manager.
              results = runner.run(suite);
          5   Add the passing diagnostics to the Logs section of the test results in the Test Manager.
              runner.addPlugin(DiagnosticsOutputPlugin(ToTestManagerLog(),...
                  'IncludingPassingDiagnostics',true));
          6   Rerun the suite to add the diagnostics and simulation results to the Test Manager.
results = runner.run(suite);
          See Also
          assertSignalsMatch | assumeSignalsMatch | fatalAssertSignalsMatch |
          matlab.unittest.plugins.DiagnosticsOutputPlugin | simulate | sltest.TestCase |
          sltest.plugins.ModelCoveragePlugin | sltest.plugins.ToTestManagerLog |
          verifySignalsMatch
          Topics
          “Test Models Using MATLAB-Based Simulink Tests”
          “Collect Coverage Using MATLAB-Based Simulink Tests”
Introduced in R2020b
2-14
                                                                     sltest.plugins.ToTestManagerLog class
sltest.plugins.ToTestManagerLog class
Package: sltest.plugins
Output stream to write text to Test Manager result Logs for MATLAB-based Simulink tests
Description
The sltest.plugins.ToTestManagerLog creates and writes a text output stream of log
information to the Logs section of test results in the Test Manager for the current TestCaseResult.
Use this plugin with the matlab.unittest.plugins.DiagnosticsOutputPlugin. The
ToTestManagerLog plugin generates output only for MATLAB-based Simulink tests, which are
derived from sltest.TestCase objects.
Creation
Use matlab.sltest.plugins.ToTestMangerLog() with the
matlab.unittest.plugins.DiagnosticsOutputPlugin to write the diagnostics output to the
Test Manager logs. For example,
runner.addPlugin(DiagnosticsOutputPlugin...
   (ToTestManagerLog());
Examples
     import   matlab.unittest.TestRunner
     import   matlab.unittest.plugins.DiagnosticsOutputPlugin
     import   sltest.plugins.MATLABTestCaseIntegrationPlugin
     import   sltest.plugins.ToTestManagerLog
2   Create a TestSuite array and basic TestRunner object for a test script file, such as one named
    mySltestTestCaseFile.m.
     suite = testsuite('mySltestTestCaseFile.m');
     runner = TestRunner.withNoPlugins;
     runner.addPlugin(MATLABTestCaseIntegrationPlugin);
4   Run the test suite to add the failing diagnostics and simulation results to the Test Manager.
     results = runner.run(suite);
5   Add the passing diagnostics to the Logs section of the test results in the Test Manager.
                                                                                                    2-15
2   Classes
              runner.addPlugin(DiagnosticsOutputPlugin(ToTestManagerLog(),...
                 'IncludingPassingDiagnostics',true));
          6   Rerun the suite to add the diagnostics and simulation results to the Test Manager.
results = runner.run(suite);
          See Also
          matlab.unittest.plugins.DiagnosticsOutputPlugin | sltest.TestCase |
          sltest.plugins.MATLABTestCaseIntegrationPlugin |
          sltest.plugins.ModelCoveragePlugin
          Topics
          “Test Models Using MATLAB-Based Simulink Tests”
          “Collect Coverage Using MATLAB-Based Simulink Tests”
Introduced in R2020b
2-16
                                                              sltest.plugins.TestManagerResultsPlugin class
sltest.plugins.TestManagerResultsPlugin class
Package: sltest.plugins
Generate enhanced test results with the MATLAB Unit Test framework
Description
Use the sltest.plugins.TestManagerResultsPlugin class to include Test Manager results
when using the MATLAB Unit Test framework to run Simulink Test files. Test Case and Test Iteration
results appear in the Details field of each TestResult object.
To publish Test Manager results, configure your test file for reporting and add the
TestReportPlugin and TestManagerResultsPlugin classes to the TestRunner object. Test
Case and Test Iteration results appear in the Details section of the MATLAB Test Report. For more
information, see “Test a Model for Continuous Integration Systems”.
Creation
tmr = sltest.plugins.TestManagerResultsPlugin creates a plugin object tmr that directs
the TestRunner to produce an enhanced test result.
You can also import the plugin, and then use the class name to create the object:
import sltest.plugins.TestManagerResultsPlugin
tmr = TestManagerResultsPlugin
Input Arguments
Name-Value Pair Options
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Example: 'ExportToFile','myfile'
Optional file to save results in Simulink Test MLDATX format, specified as the comma-separate pair
consisting of 'ExportToFile' and the file name.
You can open the MLDATX results file in the Test Manager by clicking the Import button on the
toolbar.
Example: 'ExportToFile','myfile'
Example: 'ExportToFile','myfile.mldatx'
Examples
                                                                                                     2-17
2   Classes
          This example shows how to include Test Manager Results in a TestResult object produced through
          the MATLAB Unit Test framework.
          The test case creates a square wave input to a controller subsystem and sweeps through 25 iterations
          of parameters a and b. The test compares the alpha output to a baseline with a tolerance of 0.0046.
          Output that exceeds this tolerance fails the test.
testfile = 'f14ParameterSweepTest.mldatx';
          import matlab.unittest.TestSuite
          suite = testsuite(testfile);
          import matlab.unittest.TestRunner
          runner = TestRunner.withNoPlugins;
          tmr = sltest.plugins.TestManagerResultsPlugin;
          addPlugin(runner,tmr)
results = run(runner,suite);
failure = results(19)
          failure =
            TestResult with properties:
          Totals:
             0 Passed, 1 Failed (rerun), 0 Incomplete.
             0.60422 seconds testing time.
          In the Details field of the TestResult object, test Iteration results appear as a
          SimulinkTestManagerResults object. The SimulinkTestManagerResults object contains
          information such as the type of test case, the cause of the failure, and the values of the parameters
          that led to the failure.
failure.Details.SimulinkTestManagerResults.TestCaseType
2-18
                                                      sltest.plugins.TestManagerResultsPlugin class
ans =
'Baseline Test'
failure.Details.SimulinkTestManagerResults.CauseOfFailure
ans =
'Failed criteria: Baseline'
failure.Details.SimulinkTestManagerResults.IterationSettings.variableParameters(1)
failure.Details.SimulinkTestManagerResults.IterationSettings.variableParameters(2)
See Also
matlab.unittest.plugins.TestReportPlugin
Topics
“Test Models Using MATLAB Unit Test”
“Export Test Results”
“Output Results for Continuous Integration Systems”
Introduced in R2018b
                                                                                             2-19
2   Classes
          sltest.plugins.coverage.CoverageMetrics class
          Package: sltest.plugins.coverage
Specify coverage metrics for tests run with MATLAB Unit Test framework
          Description
          Use the sltest.plugins.coverage.CoverageMetrics class to specify coverage metrics. Pass
          the coverage metrics object to the model coverage plugin object.
          Creation
          cmo = sltest.plugins.coverage.CoverageMetrics(Properties) creates a coverage
          metrics object with specified properties.
You can also import the plugin, then use the class name to create the object:
          import sltest.plugins.coverage.CoverageMetrics
          cmo = CoverageMetrics(Properties)
          Properties
          Decision — Decision coverage
          true (default) | false
          SetAccess                                                    public
          GetAccess                                                    public
          SetAccess                                                    public
          GetAccess                                                    public
2-20
                                                             sltest.plugins.coverage.CoverageMetrics class
Attributes:
SetAccess                                                    public
GetAccess                                                    public
SetAccess                                                    public
GetAccess                                                    public
SetAccess                                                    public
GetAccess                                                    public
SetAccess                                                    public
GetAccess                                                    public
SetAccess                                                    public
GetAccess                                                    public
Enable or disable recording the number of times the block saturates on integer overflow.
Example: 'SaturationOnIntegerOverflow',true
                                                                                                    2-21
2   Classes
Attributes:
          SetAccess                                                      public
          GetAccess                                                      public
          SetAccess                                                      public
          GetAccess                                                      public
          Examples
          Collect Model Coverage with MATLAB® Unit Test
          This example shows how to use MATLAB® Unit Test to collect coverage for tests run on a Simulink®
          model.
          You run the tests in the AutopilotTestFile.mldatx test file while collecting modified condition/
          decision (MCDC) coverage.
          1. Import the test runner and the plugins for the example.
          import matlab.unittest.TestRunner
          import sltest.plugins.ModelCoveragePlugin
          import sltest.plugins.coverage.CoverageMetrics
          2. Create the model coverage plugin object and the coverage metrics object. In this example, you use
          MCDC coverage and record coverage for referenced models.
          mcdcMet = CoverageMetrics('Decision',false,'Condition',false,'MCDC',true);
          covSettings = ModelCoveragePlugin('RecordModelReferenceCoverage',true,...
              'Collecting',mcdcMet);
          3. Create a MATLAB® Unit Test test suite from the test file.
          tf = sltest.testmanager.TestFile('AutopilotTestFile.mldatx');
          APSuite = testsuite(tf.FilePath);
          4. Create the test runner without any plugins, then add the coverage plugin to the runner.
          APRun = TestRunner.withNoPlugins();
          addPlugin(APRun,covSettings);
APResult = run(APRun,APSuite)
2-22
                                                            sltest.plugins.coverage.CoverageMetrics class
APResult =
  TestResult with properties:
          Name:   'AutopilotTestFile > New Test Suite 1/New Test Case 1'
        Passed:   0
        Failed:   1
    Incomplete:   0
      Duration:   0.2545
       Details:   [1x1 struct]
Totals:
   0 Passed, 1 Failed (rerun), 0 Incomplete.
   0.25449 seconds testing time.
6. You can open the link in the command-line output to view the coverage report.
warning on Stateflow:cdr:VerifyDangerousComparison
warning on Stateflow:Runtime:TestVerificationFailed
sltest.testmanager.clearResults;
sltest.testmanager.clear;
sltest.testmanager.close;
See Also
sltest.plugins.ModelCoveragePlugin |
sltest.plugins.coverage.ModelCoverageReport
Topics
“Test Models Using MATLAB Unit Test”
“Types of Model Coverage” (Simulink Coverage)
Introduced in R2018a
                                                                                                   2-23
2   Classes
          sltest.plugins.coverage.ModelCoverageReport
          class
          Package: sltest.plugins.coverage
Specify model coverage report details for tests run with MATLAB Unit Test
          Description
          mcr = sltest.plugins.coverage.ModelCoverageReport(path) creates mcr, a
          ModelCoverageReport that specifies the report folder path. Use a ModelCoverageReport to
          specify report properties when you run Simulink Test test files run with the MATLAB Unit Test
          framework.
          1   Create a ModelCoverageReport.
          2   Create a ModelCoveragePlugin, and specify the ModelCoverageReport by using the
              Producing property.
          3   Add the ModelCoveragePlugin to the TestRunner.
          4   Run the test.
          Construction
          mcr = sltest.plugins.coverage.ModelCoverageReport(path) creates mcr, a
          ModelCoverageReport that specifies the report folder path.
You can also import the class, then use the name:
          import sltest.plugins.coverage.ModelCoverageReport
          mcr = ModelCoverageReport(path)
Input Arguments
          The path of the folder in which the model coverage report is saved after the test is complete.
          Example: 'results/reports/coverage/model'
Examples
          This example shows how to specify model coverage report properties when running a Simulink®
          Test™ test file with MATLAB® Unit Test.
2-24
                                                      sltest.plugins.coverage.ModelCoverageReport class
import   matlab.unittest.TestSuite
import   matlab.unittest.TestRunner
import   sltest.plugins.ModelCoveragePlugin
import   sltest.plugins.coverage.ModelCoverageReport
Create a MATLAB Unit Test suite from AutopilotTestFile. Also create a test runner.
ste = testsuite('AutopilotTestFile.mldatx');
trn = TestRunner.withNoPlugins;
Create a subfolder in the current folder, and create a ModelCoverageReport object specifying the
new folder.
mkdir('./exReports/coverage');
path = './exReports/coverage';
mcr = ModelCoverageReport(path)
mcr =
  ModelCoverageReport with no properties.
Use the Producing property to specify the ModelCoverageReport when creating the plugin.
mc = ModelCoveragePlugin('Producing',mcr)
mc =
  ModelCoveragePlugin with properties:
    RecordModelReferenceCoverage: '<default>'
                 MetricsSettings: '<default>'
5. Add the coverage plugin to the test runner, and run the test.
addPlugin(trn,mc);
run(trn,ste)
ans =
  TestResult with properties:
                                                                                                 2-25
2   Classes
              Incomplete: 0
                Duration: 9.7627
                 Details: [1x1 struct]
          Totals:
             0 Passed, 1 Failed (rerun), 0 Incomplete.
             9.7627 seconds testing time.
          warning on Stateflow:cdr:VerifyDangerousComparison
          warning on Stateflow:Runtime:TestVerificationFailed
          rmdir('./exReports','s');
          clear('ste','trn','fldr','path','mcr','mc');
          See Also
          sltest.plugins.ModelCoveragePlugin | sltest.plugins.coverage.CoverageMetrics
          Topics
          “Test Models Using MATLAB Unit Test”
Introduced in R2018b
2-26
                                                                                     sltest.TestCase class
sltest.TestCase class
Package: sltest
Test case class for MATLAB-based Simulink tests integrated with Test Manager
Description
The sltest.TestCase class enables authoring MATLAB-based Simulink tests. You define a
MATLAB-based Simulink test in a .m file that inherits from sltest.TestCase. Since
sltest.TestCase is a matlab.unittest.TestCase, the matlab.unittest.TestCase methods
and behaviors are available when authoring a MATLAB-based Simulink test.
Class Attributes
Abstract true
Creation
To create a test that you can load, run, and analyze its results in the Test Manager, create a class
definition file that inherits from sltest.TestCase. The file contains methods that define the test
case.
For debugging at the command line without having to run an sltest.TestCase test, use the
forInteractiveUse static method to create a TestCase.
Methods
Public Methods
In addition to the listed methods, the sltest.TestCase class can use the methods of the
matlab.unittest.TestCase class.
loadSystem                           Load model for MATLAB-based Simulink test
simulate                             Simulate model or Simulink.SimulationInput for MATLAB-based
                                     Simulink test
createTemporaryFolder                Create temporary folder
sltest.TestCase.forInteractiveUse Create test case for interactive use
assumeSignalsMatch                   Assume two data sets are equivalent
assertSignalsMatch                   Assert two data sets are equivalent
fatalAssertSignalsMatch              Fatally assert two data sets are equivalent
verifySignalsMatch                   Verify two sets of data are equivalent
Examples
                                                                                                    2-27
2   Classes
          This myBaselineTest.m class definition file defines a test case that compares a set of baseline
          values and values produced from a simulation using the simulate method. See “Using MATLAB-
          Based Simulink Tests in the Test Manager” for the full example that includes the baseline data file
          and other files and commands required to run this test and then load it into the Test Manager.
          The first line of the file shows the inheritance from sltest.TestCase. The method section, which
          has a Test attribute, contains the testOne test case. The test case loads a model, sets some variable
          values, simulates the model, and tests whether the simulation and baseline signals match.
                    simOut = testCase.simulate(in);
                    testCase.verifySignalsMatch(simOut,'baseline1.mat');
                 end
              end
          end
          See Also
          matlab.unittest.TestCase | sltest.plugins.MATLABTestCaseIntegrationPlugin |
          sltest.plugins.ModelCoveragePlugin | sltest.plugins.ToTestManagerLog
          Topics
          “Test Models Using MATLAB-Based Simulink Tests”
          “Using MATLAB-Based Simulink Tests in the Test Manager”
          “Collect Coverage Using MATLAB-Based Simulink Tests”
Introduced in R2020b
2-28
                                                                        sltest.testmanager.BaselineCriteria class
sltest.testmanager.BaselineCriteria class
Package: sltest.testmanager
Description
An instance of sltest.testmanager.BaselineCriteria is a set of signals in a test case that
determines the pass-fail criteria in a baseline test case.
Construction
obj = sltest.testmanager.TestCase.addBaselineCriteria creates a
sltest.testmanager.BaselineCriteria object for a test case object.
Properties
AbsTol — Absolute tolerance
scalar
Sheet and range information for Microsoft Excel baseline file, returned as a 1-by-N array, where each
row has a Sheet and Range value. Specify Range as shown in the table.
Example: 'Range','Corner1:Corner2'
                                                                                                           2-29
2   Classes
                                               Example: 'Range','1:7'
              'Column1:Column2'                You can identify the range by specifying the beginning and
                                               ending columns using Excel column designators. Then
              Column Range                     readtable automatically detects the used row range within the
                                               designated columns. For instance, the importing function
                                               interprets the range specification 'A:F' as an instruction to
                                               read all rows in the used range in columns A through F
                                               (inclusive).
                                               Example: 'Range','A:F'
              'NamedRange'                     In Excel, you can create names to identify ranges in the
                                               spreadsheet. For instance, you can select a rectangular portion
              Excel’s Named Range              of the spreadsheet and call it 'myTable'. If such named ranges
                                               exist in a spreadsheet, then the importing function can read that
                                               range using its name.
Example: 'Range','myTable'
Lagging time tolerance for the baseline criteria set, specified as a scalar.
Leading time tolerance for the baseline criteria set, specified as a scalar.
2-30
                                                                      sltest.testmanager.BaselineCriteria class
Methods
addExcelSpecification         Add a Microsoft Excel sheet to baseline criteria or test case inputs
getSignalCriteria             Get signal criteria
remove                        Remove baseline criteria
Examples
This example captures a baseline for a test and changes the absolute tolerance from 0 to 9.
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('API Test File');
ts = createTestSuite(tf,'API Test Suite');
tc = createTestCase(ts,'baseline','Baseline API Test Case');
See Also
sltest.testmanager.SignalCriteria | sltest.testmanager.TestCase
Topics
“Set Signal Tolerances”
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                                                                         2-31
2   Classes
          sltest.testmanager.ComparisonRunResult class
          Package: sltest.testmanager
          Description
          You can access the results of a data comparison (such as a baseline or equivalence test) with
          instances of sltest.testmanager.ComparisonRunResult.
          Creation
          getComparisonResult(t) creates instances of sltest.testmanager.ComparisonRunResult,
          where t is a test results object.
          Properties
          Outcome — Comparison result
          sltest.testmanager.ComparisonSignalOutcomes object
          SetAccess                                                     private
          GetAccess                                                     public
          Methods
          Public Methods
          getComparisonSignalResults           Get test signal comparison result from comparison run result
          Examples
          Get Comparison Results of a Baseline Test
          This example shows how to programmatically get the comparison results of the second iteration of a
          baseline test case.
          1. Get the path to the test file, then run the test file.
          extf = 'sltestTestCaseRealTimeReuseExample.mldatx';
          tf = sltest.testmanager.TestFile(extf);
          ro = run(tf);
2-32
                                                         sltest.testmanager.ComparisonRunResult class
tcr = getTestCaseResults(tsr);
tir = getIterationResults(tcr);
cr2 = getComparisonResult(tir(2))
cr2sig = getComparisonSignalResults(cr2)
sltest.testmanager.clearResults;
sltest.testmanager.clear;
sltest.testmanager.close;
See Also
Introduced in R2017b
                                                                                               2-33
2   Classes
          sltest.testmanager.ComparisonSignalResult class
          Package: sltest.testmanager
          Description
          You can access the results of a data comparison (such as a baseline or equivalence test) with
          instances of sltest.testmanager.ComparisonSignalResult.
          Creation
          getComparisonSignalResults(cr) creates instances of
          sltest.testmanager.ComparisonSignalResult, where cr is a
          sltest.testmanager.ComparisonRunResult object.
          Properties
          Outcome — Comparison result
          sltest.testmanager.ComparisonSignalOutcomes object
          SetAccess                                                private
          GetAccess                                                public
          SetAccess                                                private
          GetAccess                                                public
          SetAccess                                                private
          GetAccess                                                public
2-34
                                                               sltest.testmanager.ComparisonSignalResult class
Attributes:
SetAccess                                                     private
GetAccess                                                     public
Methods
Public Methods
getComparisonSignalResults           Get test signal comparison result from comparison run result
Examples
Get Comparison Results of a Baseline Test
This example shows how to programmatically get the comparison results of the second iteration of a
baseline test case.
1. Get the path to the test file, then run the test file.
extf = 'sltestTestCaseRealTimeReuseExample.mldatx';
tf = sltest.testmanager.TestFile(extf);
ro = run(tf);
tfr   =   getTestFileResults(ro);
tsr   =   getTestSuiteResults(tfr);
tcr   =   getTestCaseResults(tsr);
tir   =   getIterationResults(tcr);
cr2 = getComparisonResult(tir(2))
cr2sig = getComparisonSignalResults(cr2)
sltest.testmanager.clearResults;
sltest.testmanager.clear;
sltest.testmanager.close;
See Also
Introduced in R2017b
                                                                                                        2-35
2   Classes
          sltest.testmanager.CoverageSettings class
          Package: sltest.testmanager
          Description
          Instances of sltest.testmanager.CoverageSettings let you set the values in the Coverage
          Settings section in a test file, test suite, or test case.
          Construction
          The getCoverageSettings methods for test file, test suite, and test case objects returns a
          sltest.testmanager.CoverageSettings object, which lets you access the coverage collection
          and metric settings.
          Properties
          RecordCoverage — Enable coverage collection
          false (default) | true
Specify if the coverage collection is on or off, false for off and true for on.
          Coverage collection is enabled or disabled in the Test Manager Coverage Settings. The
          corresponding UI option is Record coverage for system under test.
          Coverage collection for referenced models is enabled or disabled in the Test Manager Coverage
          Settings. The corresponding UI option is Record coverage for referenced models.
          Selection of coverage settings that are enabled or disabled, specified as a string. For the set of
          possible strings, see the parameter info for CovMetricSettings in Coverage metric settings and
          sltest.plugins.coverage.CoverageMetrics. Coverage metric settings can be modified only at
          the test file level.
          Coverage metrics are enabled or disabled in the Test Manager by selecting the check boxes in the
          Coverage Settings section.
          Example: "dw"
          The file name of a coverage filter file or files on the MATLAB path, specified as a string array. The file
          names specify the coverage filters that override filter files specified in the model configuration
2-36
                                                                sltest.testmanager.CoverageSettings class
settings. An empty value, "", attaches no coverage filter. For more information on coverage filters,
see “Coverage Filtering” (Simulink Coverage). The coverage filter setting propagates down from test
files to test suites and test cases, and its results are displayed at the Result Set level.
Specify the coverage filter filename in the Test Manager, in the Coverage filter filename table of the
Coverage Settings section.
Example: "covfilter.cvf"
Example: ["covfilter.cvf1";"covfilter2.cvf"]
Example: ""
Examples
Enable MCDC and Signal Range Coverage Metrics and Specify a Coverage Filter
See Also
sltest.plugins.coverage.CoverageMetrics | sltest.testmanager.TestCase |
sltest.testmanager.TestFile | sltest.testmanager.TestSuite
Topics
“Collect Coverage in Tests”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                                                   2-37
2   Classes
          sltest.testmanager.CustomCriteria class
          Package: sltest.testmanager
          Description
          An instance of sltest.testmanager.CustomCriteria is a test case custom criteria that
          evaluates the simulation output, returning a pass or fail result.
          Construction
          obj = getCustomCriteria(tc) creates an sltest.testmanager.CustomCriteria object for
          a test case object tc.
output_args = function(input_args,Name,Value).
          Properties
          Enabled — Enable or disable custom criteria
          false (default) | true
          Property that enables or disables the custom criteria for evaluation, specified as a logical.
          Example: true
          Property that defines the custom criteria script, specified as a character array.
          Example: test.verifyEqual(lastPhi,0,['Final: ',num2str(lastPhi),'.']);
Examples
tcCriteria = getCustomCriteria(tc);
tcCriteria.Callback = 'test.verifyEqual(lastPhi,0);'
2-38
                                                   sltest.testmanager.CustomCriteria class
tcCriteria.Enabled = true;
See Also
getCustomCriteria
Topics
“Process Test Results with Custom Scripts”
“Custom Criteria Programmatic Interface Example”
“Create and Run Test Cases with Scripts”
Introduced in R2016b
                                                                                    2-39
2   Classes
          sltest.testmanager.CustomCriteriaResult class
          Package: sltest.testmanager
          Description
          An instance of sltest.testmanager.CustomCriteriaResult is a test result of the evaluation of
          custom criteria.
          Construction
          obj = getCustomCriteriaResult(tcr) creates an
          sltest.testmanager.CustomCriteriaResult object for a test case result object tcr.
          Properties
          Outcome — Result of custom criteria evaluation
          sltest.testmanager.TestResultOutcomes object.
Examples
tcResultSet = run(tc);
tcResult = getTestCaseResults(tcResultSet);
Get the custom criteria result from the test case result.
2-40
                                                   sltest.testmanager.CustomCriteriaResult class
ccResult = getCustomCriteriaResult(tcResult);
See Also
getCustomCriteria
Topics
“Process Test Results with Custom Scripts”
“Custom Criteria Programmatic Interface Example”
“Create and Run Test Cases with Scripts”
Introduced in R2016b
                                                                                          2-41
2   Classes
          sltest.testmanager.DiagnosticRecord class
          Package: sltest.testmanager
          Description
          An instance of sltest.testmanager.DiagnosticRecord displays diagnostic information returned
          a verification during custom criteria analysis.
          Construction
          obj = getCustomCriteriaResult(tcResult) creates an
          sltest.testmanager.CustomCriteriaResult object, which has a property
          DiagnosticRecord. DiagnosticRecord is an sltest.testmanager.DiagnosticRecord object
          for the test case result object tcResult.
          Properties
          Outcome — Record outcome of diagnostic
          sltest.testmanager.TestResultOutcomes object.
          Framework diagnostic record of the custom criteria result, returned as a cell array.
          Example: 'verifyEqual passed.…'
2-42
                                                                sltest.testmanager.DiagnosticRecord class
If the custom criteria returns an error, it constructs an Mexception object containing information
about the error.
Example: MException
Examples
tcResultSet = run(tc);
tcResult = getTestCaseResults(tcResultSet);
Get the custom criteria result from the test case result.
ccResult = getCustomCriteriaResult(tcResult);
ccResult.DiagnosticRecord
ans =
                      Outcome:        Passed
         TestDiagnosticResult:        {'Final: 0.'}
    FrameworkDiagnosticResult:        {'verifyEqual passed.…'}
                        Event:        'VerificationPassed'
                       Report:        '=============================…'
See Also
getCustomCriteria
Topics
“Process Test Results with Custom Scripts”
“Custom Criteria Programmatic Interface Example”
“Create and Run Test Cases with Scripts”
Introduced in R2016b
                                                                                                   2-43
2   Classes
          sltest.testmanager.EquivalenceCriteria class
          Package: sltest.testmanager
          Description
          Instances of sltest.testmanager.EquivalenceCriteria is a set of signals in a test case that
          determines the pass-fail criteria in an equivalence test case.
          Construction
          obj = sltest.testmanager.TestCase.captureEquivalenceCriteria creates a
          sltest.testmanager.EquivalenceCriteria object for a test case object.
          Properties
          Enabled — Enabled indicator
          0|1
Methods
Examples
          % Create the test file, test suite, and test case structure
          tf = sltest.testmanager.TestFile('API Test File');
          ts = createTestSuite(tf,'API Test Suite');
          tc = createTestCase(ts,'equivalence','Equivalence Test Case');
2-44
                                           sltest.testmanager.EquivalenceCriteria class
See Also
sltest.testmanager.TestCase
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                                                 2-45
2   Classes
          sltest.testmanager.LoggedSignal class
          Package: sltest.testmanager
          Description
          An instance of sltest.testmanager.LoggedSignal stores a logged signal for use in a
          sltest.testmanager.LoggedSignalSet object. You can use the logged signal for data
          comparison with baseline criteria, equivalence criteria, custom criteria, or in iterations.
          Creation
          Description
Input Arguments
Simulink.BlockPath object that uniquely identifies the block that outputs the signal.
Index of the output port for the block designated by BlockPath, starting from 1.
          Properties
          Name — Signal name
          character vector
2-46
                                                                     sltest.testmanager.LoggedSignal class
Simulink.BlockPath object that uniquely identifies the block that outputs the signal. This property
is read-only.
Index of the output port for the block designated by BlockPath, starting from 1. This property is
read-only.
Name of the block path for the object. If the signal corresponds to a Simulink.Signal object, the
field displays 'base workspace' or 'model workspace' to describe the location of the object.
This property is read-only.
Methods
Public Methods
remove Remove a logged signal
Examples
% Open model
sldemo_absbrake
Select the Vehicle Speed block and enter gcb. Use the returned path to create a
Simulink.BlockPath object.
                                                                                                    2-47
2   Classes
setProperty(tc,'Model','sldemo_absbrake');
          See Also
          Simulink.BlockPath | addDataStoreSignal | addLoggedSignal | getLoggedSignals |
          sltest.testmanager.LoggedSignalSet
          Topics
          “Create and Run Test Cases with Scripts”
          “Capture Simulation Data in a Test Case”
Introduced in R2019a
2-48
                                                                  sltest.testmanager.LoggedSignalSet class
sltest.testmanager.LoggedSignalSet class
Package: sltest.testmanager
Description
An instance of sltest.testmanager.LoggedSignalSet stores a set of
sltest.testmanager.LoggedSignal objects. You can use the logged signals for data comparison
with baseline criteria, equivalence criteria, custom criteria, or in iterations.
Creation
Description
Input Arguments
tc — Test case
sltest.testmanager.TestCase object
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
When the test case is an equivalence test, this index specifies the simulation that contains the signal
set.
Example: obj = getLoggedSignalSets(tc_equiv,'SimulationIndex',2);
                                                                                                    2-49
2   Classes
          Properties
          Name — Name of the signal set
          character vector
Indicates whether the signals contained in the set are used during test case execution.
          Methods
          Public Methods
          addDataStoreSignal    Add a data store or Simulink.Signal object to a set
          addLoggedSignal       Add a logged signal to a set
          getLoggedSignals      Return logged signals contained in a set
          remove                Remove a logged signal set
Examples
          % Open model
          sldemo_absbrake
          See Also
          addLoggedSignalSet | getLoggedSignalSets |
          sltest.testmanager.EquivalenceCriteria | sltest.testmanager.LoggedSignal
          Topics
          “Create and Run Test Cases with Scripts”
          “Capture Simulation Data in a Test Case”
Introduced in R2019a
2-50
                                                                           sltest.testmanager.Options class
sltest.testmanager.Options class
Package: sltest.testmanager
Description
Get instances of sltest.testmanager.Options to view test file options, including report
generation options. For test files, you can also set these options. View options using:
• getOptions (TestCase)
• getOptions (TestSuite)
• getOptions (TestFile)
Construction
obj = getOptions(test) returns the test file options object associated with the test case, suite,
or file.
Input Arguments
Properties
Author — Report author
character vector
Option to close figures at the end of the test, specified as true to close the figures and false to
leave them open.
Custom report generation class, specified as a character vector. For information, see “Customize Test
Results Reports”.
                                                                                                      2-51
2   Classes
          Path name of report generation custom template file, specified as a character vector. For information,
          see “Customize Test Results Reports”.
Option to generate a report at the end of the test, specified as true or false.
Option to include simulation output and baseline plots in report, specified as true or false.
Option to include error and log messages in reports, specified as true or false.
          Option to include figures generated from MATLAB code in reports, specified as true or false.
          Specify the MATLAB code as custom criteria on the test case or as a callback on the test case, suite,
          or file. You must also set SaveFigures to true for this setting to apply.
Option to include the MATLAB version you are running in the report, specified as true or false.
Option to include criteria and assessment plots in reports, specified as true or false.
          Number of rows of plots to include on report pages, specified as an integer from 1 to 4. This property
          is used only if the IncludeSimulationSignalPlots property is true.
2-52
                                                                         sltest.testmanager.Options class
Number of columns of plots to include on report pages, specified as an integer from 1 to 4. This
property is used only if the IncludeSimulationSignalPlots property is true.
Test results to include in the report, specified as 'failed', 'passed', or 'all'. You can
alternatively use an enumerated value:
• sltest.testmanager.TestResultsIncludedInReport.AllTests
• sltest.testmanager.TestResultsIncludedInReport.FailedOnly
• sltest.testmanager.TestResultsIncludedInReport.PassedOnly
Output format for report, specified as 'pdf', 'zip', or 'docx'. You can alternatively use an
enumerated value:
• sltest.testmanager.ReportFileFormat.doc
• sltest.testmanager.ReportFileFormat.pdf
• sltest.testmanager.ReportFileFormat.zip
Option to save MATLAB figures with test results, specified as true or false. If you want to include
figures in results or reports, set this option to true.
Examples
                                                                                                   2-53
2   Classes
          % Set the title for the report, save figures, and include
          % 3 rows of plots per page. Columns per page default to 2.
          opt.Title = 'ABC Co. Test Results';
          opt.SaveFigures = true;
          opt.IncludeSimulationSignalPlots = true;
          opt.NumPlotRowsPerPage = 3;
          See Also
          getOptions (TestCase) | getOptions (TestFile) | getOptions (TestSuite)
          Topics
          “Create, Store, and Open MATLAB Figures”
          “Export Test Results”
Introduced in R2017a
2-54
                                                                   sltest.testmanager.ParameterOverride class
sltest.testmanager.ParameterOverride class
Package: sltest.testmanager
Description
Instances of sltest.testmanager.ParameterOverride are parameters overrides contained in a
parameter set within a test case that can override model parameters.
Construction
obj = sltest.testmanager.ParameterSet.addParameterOverride creates a
sltest.testmanager.ParameterOverride object for a parameter set object.
Properties
Name — Parameter override name
character vector
Value of the parameter override, specified as a scalar or vector value. If the value is a string, it is
evaluated as a MATLAB expression when the test executes.
Source of the parameter override, returned as a character vector. Two examples of sources are the
base workspace and a Model reference. The parameter is read-only.
Methods
                                                                                                          2-55
2   Classes
Examples
          % Create the test file, test suite, and test case structure
          tf = sltest.testmanager.TestFile('API Test File');
          ts = createTestSuite(tf,'API Test Suite');
          tc = createTestCase(ts,'baseline','Baseline API Test Case');
          See Also
          sltest.testmanager.ParameterSet | sltest.testmanager.TestCase
          Topics
          “Create and Run Test Cases with Scripts”
Introduced in R2015b
2-56
                                                                        sltest.testmanager.ParameterSet class
sltest.testmanager.ParameterSet class
Package: sltest.testmanager
Description
Instances of sltest.testmanager.ParameterSet are sets of parameters in a test case that can
override model parameters.
Construction
obj = sltest.testmanager.TestCase.addParameterSet creates a
sltest.testmanager.ParameterSet object for a test case object.
Properties
Name — Parameter set name
character vector
File path of the parameter set if parameters were added from a file, returned as a character vector.
Methods
addParameterOverride                   Add parameter override to parameter set
export                                 Export parameter set to Excel spreadsheet
getParameterOverrides                  Get parameter overrides
remove                                 Remove parameter set
Examples
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('API Test File');
ts = createTestSuite(tf,'API Test Suite');
tc = createTestCase(ts,'baseline','Baseline API Test Case');
                                                                                                       2-57
2   Classes
          See Also
          sltest.testmanager.TestCase
          Topics
          “Create and Run Test Cases with Scripts”
Introduced in R2015b
2-58
                                                                     sltest.testmanager.ResultSet class
sltest.testmanager.ResultSet class
Package: sltest.testmanager
Description
Instances of sltest.testmanager.ResultSet enable you to access the results from test execution
performed by the Test Manager.
Construction
The function sltest.testmanager.run creates a sltest.testmanager.ResultSet object.
Properties
CoverageResults — Coverage analysis results
row vector of cvdata objects
Coverage analysis results, returned as a row vector of cvdata objects. For information on cvdata
objects, see cv.cvdatagroup (Simulink Coverage).
                                                                                                 2-59
2   Classes
Number of test case results that are direct children of the results set object.
Number of test suite results that are direct children of the results set object.
Number of test file results that are direct children of the results set object.
2-60
                                                                            sltest.testmanager.ResultSet class
Custom data stored with the result set, specified as any type of data.
Methods
getCoverageResults                          Get coverage results
remove                                      Remove result set
getTestCaseResults                          Get test case results object
getTestFileResults                          Get test suite results object
getTestSuiteResults                         Get test suite results object
Examples
result = sltest.testmanager.run;
testCaseResultArray = result.getTestCaseResults;
testSuiteResultArray = result.getTestSuiteResults;
See Also
sltest.testmanager.TestCaseResult | sltest.testmanager.TestFileResult |
sltest.testmanager.TestSuiteResult
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015a
                                                                                                        2-61
2   Classes
          sltest.testmanager.SignalCriteria class
          Package: sltest.testmanager
          Description
          An instance of sltest.testmanager.SignalCriteria is an individual signal in a criteria set in a
          test case that determines the pass-fail criteria.
          Construction
          obj = getAllSignalCriteria creates a sltest.testmanager.SignalCriteria object for a
          baseline or equivalence test case object.
          Properties
          AbsTol — Absolute tolerance
          scalar
          Absolute tolerance at a signal level, specified as a scalar. Set this value on the signal to override the
          value set in the baseline or equivalence criteria set.
          The method of interpolation used to align signal data, specified as 'zoh' or 'linear'. The method
          can be one of the following:
          • 'zoh' — Zero-order hold. Data values are interpolated by holding their value at the previous time
            point.
          • 'linear' — Interpolated data values are determined by taking the data values at the previous
            and next time points. These two points form the linear interpolant, which becomes a straight line
            between these points. The interpolated data value is the point at which the linear interpolant and
            time point meet.
2-62
                                                                        sltest.testmanager.SignalCriteria class
Lagging time tolerance at a signal level, specified as a scalar. Set this value on the signal to override
the value set in the baseline or equivalence criteria set.
Leading time tolerance at a signal level, specified as a scalar. Set this value on the signal to override
the value set in the baseline or equivalence criteria set.
Relative tolerance at a signal level, specified as a scalar. Set this value on the signal to override the
value set in the baseline or equivalence criteria set.
The method of time synchronization used when a signal is compared to another signal, specified as
'union' or 'intersection'. The method can be one of the following:
• 'union' — Compare using a time vector that is the union of the time vectors of both timeseries.
  This method of time synchronization might require value interpolation.
• 'intersection' — Compare using a time vector that is the intersection of the time vectors of
  both timeseries. This method of time synchronization does not require value interpolation because
  only time points common to both time series are considered.
Methods
Examples
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('API Test File');
ts = createTestSuite(tf,'API Test Suite');
tc = createTestCase(ts,'baseline','Baseline API Test Case');
                                                                                                         2-63
2   Classes
          See Also
          sltest.testmanager.BaselineCriteria | sltest.testmanager.EquivalenceCriteria |
          sltest.testmanager.TestCase
          Topics
          “Create and Run Test Cases with Scripts”
          “Set Signal Tolerances”
Introduced in R2015b
2-64
                                                                          sltest.testmanager.TestCase class
sltest.testmanager.TestCase class
Package: sltest.testmanager
Description
Instances of sltest.testmanager.TestCase are test case objects.
If you want to modify the test case settings that define how the test case executes, use the methods
setProperty and getProperty.
For MATLAB-based Simulink tests, test methods defined in the class file correspond to test cases. See
“Test Models Using MATLAB-Based Simulink Tests” for more information.
Construction
obj = sltest.testmanager.TestCase(parent,type,name) creates a
sltest.testmanager.TestCase object as a child of the specified parent. You can specify the name
of the test case and the test case type: baseline, equivalence, or simulation.
Input Arguments
Parent test suite for the test case to reside in, specified as an sltest.testmanager.TestSuite
object.
• Baseline tests compare outputs from a simulation to expected results stored as baseline data.
• Equivalence tests compare the outputs from two different simulations. Simulations can run in
  different modes, such as normal simulation and software-in-the-loop.
• Simulation tests run the system under test and capture simulation data. If the system under test
  contains blocks that verify simulation, such as Test Sequence and Test Assessment blocks, pass/
  fail results are reflected in the simulation test results.
Name of the test suite, specified as a character vector. If this is empty, a unique name is created.
Example: 'Test Case 5'
                                                                                                       2-65
2   Classes
          Specify if you want to run the test case simulation on a target, specified as a cell array of Booleans.
          This is an optional argument. For more information on real-time testing, see “Test Models in Real
          Time”.
          Properties
          Description — Test case description
          character vector
Indicates if the test case will execute, specified as a logical value true or false.
          Test suite that is the parent of the specified test case, returned as an
          sltest.testmanager.TestSuite object.
          Description text for why the test file was disabled, specified as a character vector. This property is
          visible only when the Enabled property is set to false.
          Releases available for testing, returned as a string array. Add releases using
          sltest.testmanager.setpref.
The requirements that are attached at the test-file level, returned as a structure.
2-66
                                                                            sltest.testmanager.TestCase class
The test case type, returned as a character vector. The test case type can be one of the three types:
simulation, equivalence, or baseline.
Test file that is the parent of the test case, returned as an sltest.testmanager.TestFile object.
Test file, test suite, and test case hierarchy, returned as a character vector.
Methods
                                                                                                       2-67
2   Classes
Examples
testcase =
          See Also
          sltest.testmanager.TestFile | sltest.testmanager.TestSuite
          Topics
          “Create and Run Test Cases with Scripts”
          “Collect Coverage Using MATLAB-Based Simulink Tests”
          “Author Class-Based Unit Tests in MATLAB”
          “Test Models Using MATLAB-Based Simulink Tests”
Introduced in R2015b
2-68
                                                                     sltest.testmanager.TestCaseResult class
sltest.testmanager.TestCaseResult class
Package: sltest.testmanager
Description
An sltest.testmanager.TestCaseResult enables you to access results from executing test
cases or test files.
Construction
tcr = getTestCaseResults(ResultSet) returns tcr a test case result from a ResultSet.
Properties
Duration — Length of time the test case ran, in seconds
duration
The number of disabled tests in an individual test case result, returned as an integer.
The number of failed tests in an individual test case result, returned as an integer.
The number of incomplete tests in an individual test case result, returned as an integer.
The number of passed tests in an individual test case result, returned as an integer.
The total number of tests in an individual test case result, returned as an integer.
                                                                                                      2-69
2   Classes
          The outcome of an individual test case result. The integer 0 means the test case was disabled, 1
          means the test case execution was incomplete, 2 means the test case passed, and 3 means the test
          case failed.
Parent of the result. The parent of a test case result is a test suite result or result set object.
          Tags to filter the test file results. Use tags to view a subset of the test results. See “Tags” for more
          information.
          The type of test case from the three available test cases in the Test Manager: simulation, baseline,
          and equivalence.
2-70
                                                                      sltest.testmanager.TestCaseResult class
The path of the test file used to create the test case result.
Methods
getBaselineRun                   Get test case baseline dataset
getTestCase                      Get test case that produced result
getComparisonResult              Get test data comparison result
getComparisonRun                 Get test case signal comparison results
getCoverageResults               Get coverage results
getCustomCriteriaPlots           Get plots from test case custom criteria
getCustomCriteriaResult          Get custom criteria results from test case result
getIterationResults              Get iteration results
getInputRuns                     Get inputs from simulations captured with the test result
getOutputRuns                    Get test case simulation output results
getSimulationPlots               Get plots from test case callbacks
getVerifyRuns                    Get test case verify statement
Examples
See Also
sltest.testmanager.TestFileResult | sltest.testmanager.TestSuiteResult
Topics
“Create and Run Test Cases with Scripts”
                                                                                                       2-71
2   Classes
Introduced in R2015a
2-72
                                                                                sltest.testmanager.TestFile class
sltest.testmanager.TestFile class
Package: sltest.testmanager
Description
Instances of sltest.testmanager.TestFile are files that can contain test suites and test cases.
For MATLAB-based Simulink tests, test files correspond to the file name. See “Test Models Using
MATLAB-Based Simulink Tests” for more information.
Construction
obj = sltest.testmanager.TestFile(filePath,mode) creates a
sltest.testmanager.TestFile object with a default test suite and test case as children of the
test file. The default test case type is a baseline test case. If the test file exists on the path, a new test
file is not created.
Input Arguments
The file name and path of the test file, specified as a character vector. The file can be a test file
(.mldatx), or a MATLAB script test file (.m), if that script file is a derived class from
sltest.TestCase. The specified file name determines the name of the test file as seen in the Test
Manager.
Example: 'C:\MATLAB\TestFile.mldatx'
Indicate if you want to override a test file with the same file name and path, specified as either true
or false.
Properties
Description — Test file description
character vector
Indicates if the test file has unsaved changes, 0 if there are no unsaved changes, and 1 if there are
unsaved changes.
                                                                                                           2-73
2   Classes
          Indicates if test cases that are children of the test file will execute, specified as a logical value true
          or false.
          File path and name of the test file, returned as a character vector.
          Example: 'C:\MATLAB\test_file.mldatx'
Name of the test file without the file path and file extension, returned as a character vector.
          Releases available for testing, returned as a string array. Add releases using
          sltest.testmanager.setpref.
          Description text for why the test file was disabled, specified as a character vector. This property is
          visible only when the Enabled property is set to false.
The requirements that are attached at the test-file level, returned as a structure.
2-74
                                                                         sltest.testmanager.TestFile class
Methods
Examples
Create a new test file and return the test file object.
testfile = sltest.testmanager.TestFile('C:\MATLAB\test_file.mldatx')
testfile =
              Name:   'test_file'
          FilePath:   'C:\MATLAB\test_file.mldatx'
             Dirty:   1
      Requirements:   [0x1 struct]
       Description:   ''
           Enabled:   1
See Also
sltest.TestCase | sltest.testmanager.TestCase | sltest.testmanager.TestSuite
Topics
“Create and Run Test Cases with Scripts”
“Test Models Using MATLAB-Based Simulink Tests”
“Using MATLAB-Based Simulink Tests in the Test Manager”
“Collect Coverage Using MATLAB-Based Simulink Tests”
Introduced in R2015b
                                                                                                    2-75
2   Classes
          sltest.testmanager.TestFileResult class
          Package: sltest.testmanager
          Description
          Instances of sltest.testmanager.TestFileResult enable you to access the results from test
          execution performed by the Test Manager at a test-file level.
          Construction
          The function sltest.testmanager.run creates a sltest.testmanager.ResultSet object,
          which contains the test file result object. You can also create a test file result directly if you use run
          to execute tests in an individual test file.
          Properties
          Duration — Length of time the test ran, in seconds
          duration
The number of test cases that were disabled in the test file result.
The number of test cases that did not execute in the test file result.
The number of test case results that are direct children of the test file result.
2-76
                                                                          sltest.testmanager.TestFileResult class
The number of test suite results that are direct children of the test file result.
Parent of the result. The parent of a test file result is a result set object.
Tags to filter the test file results. Use tags to view a subset of the test results. See “Tags” for more
information.
                                                                                                           2-77
2   Classes
          Methods
              getCleanupPlots                   Get plots from cleanup callbacks
              getCoverageResults                Get coverage results
              getSetupPlots                     Get plots from setup callbacks
              getTestSuiteResults               Get test suite results object
Examples
          See Also
          sltest.testmanager.TestCaseResult | sltest.testmanager.TestSuiteResult
          Topics
          “Create and Run Test Cases with Scripts”
Introduced in R2016a
2-78
                                                                               sltest.testmanager.TestInput class
sltest.testmanager.TestInput class
Package: sltest.testmanager
Description
Instances of sltest.testmanager.TestInput are sets of signal input data that can be mapped to
override the inputs in the System Under Test.
Construction
obj = sltest.testmanager.TestCase.addInput creates a
sltest.testmanager.TestInput object for a test case object.
Properties
Active — Enabled indicator
0|1
Indicates if the input is set to override in the test case, 0 if it is not enabled, and 1 if it is enabled.
Sheet and range information for Microsoft Excel baseline file, returned as a 1-by-N array, where each
row has a Sheet and Range value. Specify Range as shown in the table.
Example: 'Range','Corner1:Corner2'
                                                                                                           2-79
2   Classes
                                               Example: 'Range','1:7'
              'Column1:Column2'                You can identify the range by specifying the beginning and
                                               ending columns using Excel column designators. Then
              Column Range                     readtable automatically detects the used row range within the
                                               designated columns. For instance, the importing function
                                               interprets the range specification 'A:F' as an instruction to
                                               read all rows in the used range in columns A through F
                                               (inclusive).
                                               Example: 'Range','A:F'
              'NamedRange'                     In Excel, you can create names to identify ranges in the
                                               spreadsheet. For instance, you can select a rectangular portion
              Excel’s Named Range              of the spreadsheet and call it 'myTable'. If such named ranges
                                               exist in a spreadsheet, then the importing function can read that
                                               range using its name.
Example: 'Range','myTable'
          InputString — Input
          character vector
          Evaluated during test case execution in the LoadExternalInput configuration parameter of the
          System Under Test, specified as a character vector.
          Example: 'Acceleration.getElement(1),Acceleration.getElement(2)'
2-80
                                                                        sltest.testmanager.TestInput class
Mapping status to indicate if the inport mapping was successful. For more information about
troubleshooting the mapping status, see “Understand Mapping Results”.
Example: 'Successfully mapped inputs.'
Methods
addExcelSpecification     Add a Microsoft Excel sheet to baseline criteria or test case inputs
map                       Map test input to system under test
remove                    Remove test input
Examples
You can add data from a Microsoft Excel spreadsheet. The spreadsheet used in this example is
located in the example folder.
See Also
addInput | sltest.testmanager.TestCase
                                                                                                    2-81
2   Classes
          Topics
          “Create and Run Test Cases with Scripts”
Introduced in R2015b
2-82
                                                                        sltest.testmanager.TestIteration class
sltest.testmanager.TestIteration class
Package: sltest.testmanager
Description
Iterations let you test a combination of model settings for testing methods such as Monte Carlo and
parameter sweeping. Iterations initialize during test execution but before model callbacks and test
callbacks. Once you create a test iteration object, you can override aspects of the test case for each
iteration using the class methods.
You create your iteration script in the text window under the Iterations section of a test case.
Iteration scripts cannot run in the MATLAB command window.
The examples scripts in this reference page must be inserted into this section and other sections of
the test case must be defined. For more information on iterations and scripted iterations, see “Test
Iterations”.
Construction
iterationObj = sltest.testmanager.TestIteration returns a test iteration object. The
object is used to construct a single iteration in a test case. Each iteration you want to create in the
test must use a single iteration object.
You can also create a test iteration within a iteration script using the sltestiteration function.
                                                                                                        2-83
2   Classes
          If you use a for loop in the MATLAB command window to add many iterations to a test case, then the
          MATLAB command window might become temporarily unusable. Instead, use vectorization in the
          command window to add iterations to a test case. For example:
          iterations(100) = sltest.testmanager.TestIteration;
          addIteration(tc,iterations);
          Properties
          Name — Iteration name
          empty (default) | character vector
          Name of the test iteration, specified as a character vector. The iteration name must be unique from
          other iterations in the test case.
          Example: 'Iteration 1a'
Set of model parameter overrides for the iteration, returned as a cell array of character vectors.
Set of test parameter settings for the iteration, returned as a cell array of character vectors.
Set of model variable overrides for the iteration, returned as a cell array of character vectors.
Option to run the iteration with the test case, specified as a logical.
          Methods
              getIterationResults                 Get test iteration results history
              setModelParam                       Set model parameter for iteration
              setTestParam                        Set test case parameter
              setVariable                         Set model variable override
Examples
          In this example of a scripted iteration, specify the model in the test case to be sldemo_absbrake.
          The iterations are generated during test execution. This section of script is in the Scripted
          Iterations section of the test case. It will execute only in the Scripted Iterations section. The
2-84
                                                                        sltest.testmanager.TestIteration class
sltest_testCase is a variable defined for you in the Scripted Iterations section, which is the
parent test case object of the iteration.
% Specify the parameter sweep
vars = 32 : 0.5 : 34;
In this example of a scripted iteration, there must be parameter sets defined in the Parameter
Overrides section of the test case. The iterations are generated during test execution. This section of
script is in the Scripted Iterations section of the test case. It will execute only in the Scripted
Iterations section. The sltest_testCase is a variable defined for you in the Scripted Iterations
section, which is the parent test case object of the iteration.
% Define parameter sets for a test case and add this code in the
Alternatives
If you do not want to use a script to create iterations, then you can use table iterations in the test
case. For more information about table iterations, see “Test Iterations”.
See Also
sltest.testmanager.TestIterationResult
                                                                                                        2-85
2   Classes
          Topics
          “Test Iterations”
          “Create and Run Test Cases with Scripts”
Introduced in R2016a
2-86
                                                                      sltest.testmanager.TestIterationResult class
sltest.testmanager.TestIterationResult class
Package: sltest.testmanager
Description
Instances of sltest.testmanager.TestIterationResult enable you to access the results from
test execution performed by the Test Manager at a test-iteration level. The hierarchy of test results is
Result Set > Test File Result > Test Suite Result > Test Case Result > Test Iteration Result.
Construction
The function sltest.testmanager.run creates a sltest.testmanager.ResultSet object,
which contains the test case result object.
Properties
Outcome — Outcome of test iteration result
0|1|2|3
The outcome of an individual test iteration result. The integer 0 means the test iteration was
disabled, 1 means the test iteration execution was incomplete, 2 means the test iteration passed, and
3 means the test iteration failed.
The path of the test file used to create the test iteration result.
                                                                                                            2-87
2   Classes
          The type of test case from the three available test cases in the Test Manager: simulation, baseline,
          and equivalence.
Indicates if the simulation ran on the target or not, returned as an array of Booleans.
Parent of the result. The parent of a test iteration result is a test case result object.
Methods
Examples
2-88
                                                     sltest.testmanager.TestIterationResult class
% Specify iterations
vars = 32 : 0.5 : 34;
for k = 1 : length(vars)
See Also
sltest.testmanager.TestIteration
Topics
“Test Iterations”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                                           2-89
2   Classes
          sltest.testmanager.TestResultReport class
          Package: sltest.testmanager
          Description
          sltest.testmanager.TestResultReport is a class that enables you to customize report
          generation of result from the Test Manager. You can derive the class and override various methods to
          customize your report. By customizing the methods, you can change the report title, plots, tables,
          headers, icons, and more.
For more information and examples on customizing reports, see “Customize Test Results Reports”.
          Construction
          Obj = sltest.testmanager.TestResultReport(resultObjects,reportFilePath) creates
          a report generation object.
          To use this class, you must inherit from the class. Use the following code as the first lines in your
          class definition code to inherit from the class.
          % class definition
          classdef CustomReport < sltest.testmanager.TestResultReport
              %
              % Report customization code here
              %
          end
Input Arguments
          File name and path of the generated report. File path must have file extension of pdf, docx, or zip,
          which are the only supported file types.
          Example: 'C:\MATLAB\Report.pdf'
          Properties
          AuthorName — Author name
          empty character vector (default)
          The name of the author or the generated report, specified as a character vector.
          Example: 'Test Engineer'
2-90
                                                                    sltest.testmanager.TestResultReport class
The file name and path to a Microsoft Word template file for report customization, specified as a
character vector. For more information about using template files, see “Generate Reports Using
Templates”. The use of this argument is valid only available if you have a MATLAB Report Generator
license.
Example: 'C:\MATLAB\CustomReportTemplate.dotx'
                                                                                                       2-91
2   Classes
          File name and path of an icon image for a disabled test result, specified as a character vector. The
          icon file specified replaces the default icon image. The icon image is reduced to 16x16 pixels.
          Example: 'C:\MATLAB\disabled_test_icon.png'
          File name and path of an icon image for a failed test result, specified as a character vector. The icon
          file specified replaces the default icon image. The icon image is reduced to 16x16 pixels.
          Example: 'C:\MATLAB\failed_test_icon.png'
          File name and path of an icon image for an incomplete test result, specified as a character vector. The
          icon file specified replaces the default icon image. The icon image is reduced to 16x16 pixels.
          Example: 'C:\MATLAB\incomplete_test_icon.png'
          File name and path of an icon image for a misaligned test result, specified as a character vector. The
          icon file specified replaces the default icon image. The icon image is reduced to 16x16 pixels.
          Example: 'C:\MATLAB\misaligned_test_icon.png'
          File name and path of an icon image for a passed test result, specified as a character vector. The icon
          file specified replaces the default icon image. The icon image is reduced to 16x16 pixels.
          Example: 'C:\MATLAB\passed_test_icon.png'
          File name and path of an icon image for a test case result, specified as a character vector. The icon
          file specified replaces the default icon image. The icon image is reduced to 16x16 pixels.
2-92
                                                                    sltest.testmanager.TestResultReport class
Example: 'C:\MATLAB\test_case_result_icon.png'
File name and path of an icon image for a test file result, specified as a character vector. The icon file
specified replaces the default icon image. The icon image is reduced to 16x16 pixels.
Example: 'C:\MATLAB\test_file_result_icon.png'
File name and path of an icon image for an iteration result, specified as a character vector. The icon
file specified replaces the default icon image. The icon image is reduced to 16x16 pixels.
Example: 'C:\MATLAB\iteration_result_icon.png'
File name and path of an icon image for a test suite result, specified as a character vector. The icon
file specified replaces the default icon image. The icon image is reduced to 16x16 pixels.
Example: 'C:\MATLAB\test_suite_result_icon.png'
File name and path of an icon image for a model reference in the coverage report, specified as a
character vector. The icon file specified replaces the default icon image. The icon image is reduced to
16x16 pixels.
Example: 'C:\MATLAB\model_reference_icon.png'
File name and path of an icon image for a top-level model in the coverage report, specified as a
character vector. The icon file specified replaces the default icon image. The icon image is reduced to
16x16 pixels.
Example: 'C:\MATLAB\top_level_model_icon.png'
Include the signal comparison plots in the report, specified as true or false.
                                                                                                       2-93
2   Classes
Include the version of MATLAB used to run the tests in the report, specified as true or false.
          Include simulation metadata in the report, specified as true or false. The metadata includes:
          Simulink version, model version, model author, date, model user ID, model path, machine name,
          solver name, solver type, fixed step size, simulation start time, simulation stop time, and platform.
Include the simulation signal output plots in the report, specified as true or false.
          Include the test requirements linked to the test file, test suite, or test case in the report, specified as
          true or false.
          Include all or a subset of test results in the report. You can select all passed and failed results,
          specified as the value 0, select only passed results, specified as the value 1, or select only failed
          results, specified as the value 2.
          Open the report when it is finished generating, specified as a boolean value, true or to not open the
          report, false.
2-94
                                                              sltest.testmanager.TestResultReport class
                                                                                                 2-95
2   Classes
Methods
Examples
          % class definition
          classdef CustomReport < sltest.testmanager.TestResultReport
              % This custom class used by Test Manager
              % adds a custom message in the title page
                  % Class constructor
                  methods
                      function this = CustomReport(resultObjects, reportFilePath)
                          this@sltest.testmanager.TestResultReport...
                             (resultObjects,reportFilePath);
                      end
                  end
                  methods(Access=protected)
                      function addTitlePage(obj)
                          import mlreportgen.dom.*;
2-96
                                                             sltest.testmanager.TestResultReport class
See Also
sltest.testmanager.ResultSet | sltest.testmanager.report
Topics
“Customize Test Results Reports”
“Export Test Results”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                                                2-97
2   Classes
          sltest.testmanager.TestSuite class
          Package: sltest.testmanager
          Description
          Instances of sltest.testmanager.TestSuite can contain other test suites and test cases. For
          MATLAB-based Simulink tests, test suites are implemented using class and method parameters. See
          “Test Models Using MATLAB-Based Simulink Tests” for more information.
          Construction
          obj = sltest.testmanager.TestSuite(parent,name) creates a
          sltest.testmanager.TestSuite object as a child of the specified parent. You can use test files or
          other test suites as the parent.
Input Arguments
          Parent object for the test suite to reside in. The parent object can be a test file or a another test suite,
          specified as an sltest.testmanager.TestFile or sltest.testmanager.TestSuite object.
          Name of the test suite, specified as a character vector. If this is empty, a unique name is created.
          Example: 'Coverage Test Suite'
          Properties
          Description — Test suite description
          character vector
          Indicates if test cases that are children of the test suite execute, specified as a logical value true or
          false.
Name of the test file without the file path and file extension, returned as a character vector.
2-98
                                                                          sltest.testmanager.TestSuite class
Test file or test suite that is the parent of the specified test suite, returned as a
sltest.testmanager.TestFile or sltest.testmanager.TestSuite object.
Description text for why the test suite was disabled, specified as a character vector. This property is
visible only when the Enabled property is set to false.
Releases available for testing, returned as a string array. Add releases using
sltest.testmanager.setpref.
The requirements that are attached at the test-suite level, returned as a structure.
Test file that is the parent of the test suite, returned as a sltest.testmanager.TestFile object.
                                                                                                      2-99
2   Classes
Methods
Examples
testsuite =
          See Also
          sltest.testmanager.TestCase | sltest.testmanager.TestFile | testsuite
          Topics
          “Create and Run Test Cases with Scripts”
          “Use Parameters in Class-Based Tests”
          “Test Models Using MATLAB-Based Simulink Tests”
2-100
                       sltest.testmanager.TestSuite class
Introduced in R2015b
                                                 2-101
2   Classes
          sltest.testmanager.TestSuiteResult class
          Package: sltest.testmanager
          Description
          Instances of sltest.testmanager.TestSuiteResult enable you to access the results from test
          execution performed by the Test Manager at a test-suite level.
          Construction
          The function sltest.testmanager.run creates a sltest.testmanager.ResultSet object,
          which contains the test suite result object. You can also create a test suite result directly if you use
          run to execute tests in an individual test suite.
          Properties
          Duration — Length of time the test suite ran, in seconds
          duration
The number of test cases that were disabled in the test suite result.
The number of test case results that are direct children of the test suite result.
The number of test suite results that are direct children of the test suite result.
2-102
                                                                        sltest.testmanager.TestSuiteResult class
Parent of the result. The parent of a test suite result is another test suite result, test file result, or
result set object.
Tags to filter the test file results. Use tags to view a subset of the test results. See “Tags” for more
information.
                                                                                                        2-103
2   Classes
          Methods
              getCleanupPlots            Get plots from cleanup callbacks of test suite
              getCoverageResults         Get coverage results
              getSetupPlots              Plots from setup callbacks
              getTestCaseResults         Get test case results object
              getTestSuiteResults        Get test suite results object
Examples
          See Also
          sltest.testmanager.TestCaseResult | sltest.testmanager.TestFileResult
          Topics
          “Create and Run Test Cases with Scripts”
Introduced in R2015a
2-104
          3
Methods
3     Methods
           assertSignalsMatch
           Class: sltest.TestCase
           Package: sltest
           Syntax
           assertSignalsMatch(testCase,actual,expected)
           assertSignalsMatch( ___ ,diagnostic)
           assertSignalsMatch( ___ ,Name,Value)
           Description
           assertSignalsMatch(testCase,actual,expected) filters test content by asserting that the
           actual and expected signal data values are equivalent. When an assertion fails, the test point or test
           file stops running, and that test is marked as failed. This qualification is useful when a failure at the
           assertion point renders the rest of the current test method invalid, but does not prevent proper
           execution of other test methods. Often, you use assertions to check that preconditions of the current
           test are not violated or that fixtures are set up correctly. For more information, see
           matlab.unittest.qualifications.Assertable.
           assertSignalsMatch( ___ ,diagnostic) returns diagnostic information when the actual and
           expected data values are not equivalent.
           assertSignalsMatch( ___ ,Name,Value) filters test content with additional options specified by
           one or more Name,Value pair arguments.
           Input Arguments
           testCase — Instance of test case
           sltest.TestCase object
           Actual values to compare to expected values, specified as time series data, a string, or character
           array. The data for each actual value must pair data value with time value. The data must be in a
           format supported by the Simulation Data Inspector. The Simulation Data Inspector requires data in a
           format that associates sample values with time. Supported formats include timeseries, Structure
           with time, and Dataset.
           Example: 'C:/matlab/data/actualData.mat'
           Expected values to use as the baseline for the comparison. The data for each expected value must
           pair data value with time value. The data must be in a format supported by the Simulation Data
3-2
                                                                                       assertSignalsMatch
Inspector. The Simulation Data Inspector requires data in a format that associates sample values with
time. Supported formats include timeseries, Structure with time, and Dataset.
Example: 'C:/matlab/data/expectedData.mat'
Diagnostic information to display when the assertion that the actual and expected values are
equivalent fails, specified as a string, character array, a function handle, or an instance of a
matlab.unittest.diagnostics.Diagnostic class.
Example: 'Simulation output does not match.'
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Absolute tolerance, specified as the comma-separated pair consisting of 'AbsTol' and the scalar
value of the tolerance. The tolerance specifies the magnitude of the difference between the actual
and expected values.
Example: 'AbsTol',1e-9
Relative tolerance, specified as the comma-separated pair consisting of 'RelTol' and the scalar
value of the tolerance. The relative tolerance specifies the magnitude of the difference between the
actual and expected values, relative to the expected value.
Example: 'RelTol',.002
Time tolerance, specified as the comma-separated pair consisting of 'TimeTol' and the scalar value
of the tolerance.
Example: 'TimeTol',.2
Attributes
Access                                               public
Sealed                                               true
                                                                                                     3-3
3     Methods
Examples
           Create a test case for interactive use. Then, simulate the model in normal mode to obtain the
           expected values, and simulate in rapid accelerator mode to obtain the actual values. Use
           assertSignalsMatch to compare the values.
           testCase =...
              sltest.TestCase.forInteractiveUse;
           expected = testCase.simulate('myModel',...
              'SimulationMode','Normal');
           actual = testCase.simulate('myModel',...
              'SimulationMode','Rapid-Accelerator');
testCase.assertSignalsMatch(actual,expected)
           Create a test case for interactive use. Simulate the model in rapid accelerator mode to obtain the
           actual values. Use assertSignalsMatch to compare the actual values to the baseline values saved
           in a MAT=file. Set a relative tolerance.
           testCase =...
              sltest.TestCase.forInteractiveUse;
           actual = testCase.simulate('myModel',...
              'SimulationMode','Rapid-Accelerator');
           testCase.assertSignalsMatch(actual,'baseline.mat',...
              'RelTol',0.001)
           Create a test case for interactive use. Then, simulate the model in rapid accelerator mode to obtain
           the actual values. Use assertSignalsMatch to compare the actual values to the baseline values
           saved in a MAT-file. Specify the diagnostic message to display if the assertion fails.
           testCase =...
              sltest.TestCase.forInteractiveUse;
           actual = testCase.simulate('myModel',...
              'SimulationMode','Rapid-Accelerator');
testCase.assertSignalsMatch(actual,'baseline.mat',...
3-4
                                                                   assertSignalsMatch
See Also
Simulink.sdi.constraints.MatchesSignal | assumeSignalsMatch |
fatalAssertSignalsMatch | matlab.unittest.constraints.AbsoluteTolerance |
matlab.unittest.constraints.RelativeTolerance |
matlab.unittest.qualifications.Assertable | sltest.TestCase | verifySignalsMatch
Topics
“Test Models Using MATLAB-Based Simulink Tests”
Introduced in R2020b
                                                                                 3-5
3     Methods
           assumeSignalsMatch
           Class: sltest.TestCase
           Package: sltest
           Syntax
           assumeSignalsMatch(testCase,actual,expected)
           assumeSignalsMatch( ___ ,diagnostic)
           assumeSignalsMatch( ___ ,Name,Value)
           Description
           assumeSignalsMatch(testCase,actual,expected) assumes that the actual and expected
           signal data values are equivalent. When an assumption fails, the test stops running at the test point
           or test file, and the test is marked as incomplete. For more information, see
           matlab.unittest.qualifications.Assumable.
           assumeSignalsMatch( ___ ,diagnostic) returns diagnostic information when the actual and
           expected data values are not equivalent.
           assumeSignalsMatch( ___ ,Name,Value) filters test content with additional options specified by
           one or more Name,Value pair arguments.
           Input Arguments
           testCase — Instance of test case
           sltest.TestCase object
           Actual values to compare to expected values, specified as time series data, a string, or character
           array. The data for each actual value must pair data value with time value. The data must be in a
           format supported by the Simulation Data Inspector. The Simulation Data Inspector requires data in a
           format that associates sample values with time. Supported formats include timeseries, Structure
           with time, and Dataset.
           Example: 'C:/matlab/data/actualData.mat'
           Expected values to use as the baseline for the comparison. The data for each expected value must
           pair data value with time value. The data must be in a format supported by the Simulation Data
           Inspector. The Simulation Data Inspector requires data in a format that associates sample values with
           time. Supported formats include timeseries, Structure with time, and Dataset.
3-6
                                                                                    assumeSignalsMatch
Example: 'C:/matlab/data/expectedData.mat'
Diagnostic information to display when the assumption that the actual and expected values are
equivalent fails, specified as a string, character array, a function handle, or an instance of a
matlab.unittest.diagnostics.Diagnostic class.
Example: 'Simulation output does not match.'
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Absolute tolerance, specified as the comma-separated pair consisting of 'AbsTol' and the scalar
value of the tolerance. The tolerance specifies the magnitude of the difference between the actual
and expected values.
Example: 'AbsTol',1e-9
Relative tolerance, specified as the comma-separated pair consisting of 'RelTol' and the scalar
value of the tolerance. The relative tolerance specifies the magnitude of the difference between the
actual and expected values, relative to the expected value.
Example: 'RelTol',.002
Time tolerance, specified as the comma-separated pair consisting of 'TimeTol' and the scalar value
of the tolerance.
Example: 'TimeTol',.2
Attributes
Access                                              public
Sealed                                              true
                                                                                                     3-7
3     Methods
Examples
           Create a test case for interactive use. Then, simulate the model in normal mode to obtain the
           expected values, and simulate in rapid accelerator mode to obtain the actual values. Use
           assumeSignalsMatch to compare the values.
           testCase =...
              sltest.TestCase.forInteractiveUse;
           expected = testCase.simulate('myModel',...
              'SimulationMode','Normal');
           actual = testCase.simulate('myModel',...
              'SimulationMode','Rapid-Accelerator');
testCase.assumeSignalsMatch(actual,expected)
           Create a test case for interactive use. Simulate the model in rapid accelerator mode to obtain the
           actual values. Use assumeSignalsMatch to compare the actual values to the baseline values saved
           in a MAT-file. Set an absolute tolerance.
           testCase =...
              sltest.TestCase.forInteractiveUse;
           actual = testCase.simulate('myModel',...
              'SimulationMode','Rapid-Accelerator');
           testCase.assumeSignalsMatch(actual,'baseline.mat',...
              'AbsTol',1e-12)
           Create a test case for interactive use. Then, simulate the model in rapid accelerator mode to obtain
           the actual values. Use assumeSignalsMatch to compare the actual values to the baseline values
           saved in a MAT-file. Specify the diagnostic message to display if the assumption fails.
           testCase =...
              sltest.TestCase.forInteractiveUse;
           actual = testCase.simulate('myModel',...
              'SimulationMode','Rapid-Accelerator');
testCase.assumeSignalsMatch(actual,'baseline.mat',...
3-8
                                                                assumeSignalsMatch
See Also
Simulink.sdi.constraints.MatchesSignal | Simulink.sdi.constraints.MatchesSignal
| assertSignalsMatch | fatalAssertSignalsMatch |
matlab.unittest.constraints.AbsoluteTolerance |
matlab.unittest.constraints.RelativeTolerance |
matlab.unittest.qualifications.Assumable | sltest.TestCase | verifySignalsMatch
Topics
“Test Models Using MATLAB-Based Simulink Tests”
Introduced in R2020b
                                                                              3-9
3   Methods
         createTemporaryFolder
         Class: sltest.TestCase
         Package: sltest
         Syntax
         folder = createTemporaryFolder(testCase)
         Description
         folder = createTemporaryFolder(testCase) returns a temporary folder This folder is deleted
         based on the scope of the test case. For example, for a folder created by a method, that folder is
         deleted when the method is complete and goes out of scope. Temporary folders are useful if you want
         to use a separate folder to store methods of a test case. See“Create Temporary Folder for Each Test
         Method” on page 3-10 “Write Plugins to Extend TestRunner” for information on test case scope.
         Input Arguments
         testCase — Instance of test case
         sltest.TestCase object
         Output Arguments
         folder — Temporary folder path
         character vector
         Attributes
          Access                                             public
Examples
              properties
                 Folder;
              end
3-10
                                                  createTemporaryFolder
    methods (TestMethodSetup)
        function setup(testCase)
           testCase.Folder = ...
              testCase.createTemporaryFolder();
       end
    end
    methods (Test)
       function test1(testCase)
          testCase.simulate('myModel1',...
             'InFolder',testCase.Folder);
       end
         function test2(testCase)
             testCase.simulate('myModel2',...
                'InFolder',testCase.Folder);
         end
   end
end
See Also
sltest.TestCase
Topics
“Test Models Using MATLAB-Based Simulink Tests”
Introduced in R2020b
                                                                 3-11
3   Methods
         fatalAssertSignalsMatch
         Class: sltest.TestCase
         Package: sltest
         Syntax
         fatalAssertSignalsMatch(testCase,actual,expected)
         fatalAssertSignalsMatch( ___ ,diagnostic)
         fatalAssertSignalsMatch( ___ ,Name,Value)
         Description
         fatalAssertSignalsMatch(testCase,actual,expected) fatally asserts that the actual and
         expected signal data values are equivalent. When a fatal assertion fails, the whole test session is
         stopped. This is useful when the test contains so many errors that it does not make sense to continue
         the test session.
         Input Arguments
         testCase — Instance of test case
         sltest.TestCase object
         Actual values to compare to expected values, specified as time series data, a string, or character
         array. The data for each actual value must pair data value with time value. The data must be in a
         format supported by the Simulation Data Inspector. The Simulation Data Inspector requires data in a
         format that associates sample values with time. Supported formats include timeseries, Structure
         with time, and Dataset.
         Example: 'C:/matlab/data/actualData.mat'
         Expected values to use as the baseline for the comparison. The data for each expected value must
         pair data value with time value. The data must be in a format supported by the Simulation Data
         Inspector. The Simulation Data Inspector requires data in a format that associates sample values with
         time. Supported formats include timeseries, Structure with time, and Dataset.
3-12
                                                                                 fatalAssertSignalsMatch
Example: 'C:/matlab/data/expectedData.mat'
Diagnostic information to display when the fatal assertion that the actual and expected values are
equivalent fails, specified as a string, character array, a function handle, or an instance of a
matlab.unittest.diagnostics.Diagnostic class.
Example: 'Simulation output does not match.'
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Absolute tolerance, specified as the comma-separated pair consisting of 'AbsTol' and the scalar
value of the tolerance. The tolerance specifies the magnitude of the difference between the actual
and expected values.
Example: 'AbsTol',1e-9
Relative tolerance, specified as the comma-separated pair consisting of 'RelTol' and the scalar
value of the tolerance. The relative tolerance specifies the magnitude of the difference between the
actual and expected values, relative to the expected value.
Example: 'RelTol',.002
Time tolerance, specified as the comma-separated pair consisting of 'TimeTol' and the scalar value
of the tolerance.
Example: 'TimeTol',.2
Attributes
Access                                             public
Sealed                                             true
                                                                                                  3-13
3   Methods
Examples
         Create a test case for interactive use. Then, simulate the model in normal mode to obtain the
         expected values, and simulate in rapid accelerator mode to obtain the actual values. Use
         fatalAssertSignalsMatch to compare the values.
         testCase =...
            sltest.TestCase.forInteractiveUse;
         expected = testCase.simulate('myModel',...
            'SimulationMode','Normal');
         actual = testCase.simulate('myModel',...
            'SimulationMode','Rapid-Accelerator');
testCase.fatalAssertSignalsMatch(actual,expected)
         Create a test case for interactive use. Simulate the model in rapid accelerator mode to obtain the
         actual values. Use fatalAssertSignalsMatch to compare the actual values to the baseline values
         saved in a MAT-file. Set a relative tolerance.
         testCase =...
            sltest.TestCase.forInteractiveUse;
         actual = testCase.simulate('myModel',...
            'SimulationMode','Rapid-Accelerator');
         testCase.fatalAssertSignalsMatch(actual,'baseline.mat',...
            'RelTol',0.001)
Fatal Assert that Simulations Match and Display Custom Diagnostic Message
         Create a test case for interactive use. Then, simulate the model in rapid accelerator mode to obtain
         the actual values. Use fatalAssertSignalsMatch to compare the actual values to the baseline
         values saved in a MAT-file. Specify the diagnostic message to display if the assertion fails.
         testCase =...
            sltest.TestCase.forInteractiveUse;
         actual = testCase.simulate('myModel',...
            'SimulationMode','Rapid-Accelerator');
testCase.fatalAssertSignalsMatch(actual,'baseline.mat',...
3-14
                                                                fatalAssertSignalsMatch
See Also
Simulink.sdi.constraints.MatchesSignal | assertSignalsMatch | assumeSignalsMatch
| matlab.unittest.constraints.AbsoluteTolerance |
matlab.unittest.constraints.RelativeTolerance |
matlab.unittest.qualifications.FatalAssertable | sltest.TestCase |
verifySignalsMatch
Topics
“Test Models Using MATLAB-Based Simulink Tests”
Introduced in R2020b
                                                                                 3-15
3   Methods
         sltest.TestCase.forInteractiveUse
         Class: sltest.TestCase
         Package: sltest
         Syntax
         testCase = forInteractiveUse
         Description
         testCase = forInteractiveUse returns a test case instance configured for interactive use at the
         MATLAB command line. Use this method at the MATLAB command line to debug a TestCase object
         without having to write a complete test file. You cannot use this method within a test file.
         Output Arguments
         testCase — Instance of test case
         sltest.TestCase object
         Instance of a test case, returned as an sltest.TestCase object. This instance is configured to print
         qualification failures and successes to the standard output, which is usually the screen.
         Attributes
          Access                                           public
Examples
         testCase =...
            sltest.TestCase.forInteractiveUse;
         expected = testCase.simulate('myModel',...
            'SimulationMode','Normal');
         actual = testCase.simulate('myModel',...
            'SimulationMode','Rapid-Accelerator');
testCase.verifySignalsMatch(actual,expected)
         See Also
         assertSignalsMatch | assumeSignalsMatch | fatalAssertSignalsMatch |
         sltest.TestCase | verifySignalsMatch
3-16
                                                          sltest.TestCase.forInteractiveUse
Topics
“Test Models Using MATLAB-Based Simulink Tests”
“Using MATLAB-Based Simulink Tests in the Test Manager”
“Collect Coverage Using MATLAB-Based Simulink Tests”
Introduced in R2020b
                                                                                     3-17
3   Methods
         loadSystem
         Class: sltest.TestCase
         Package: sltest
         Syntax
         [modelname,modelhandle,modelpath] = loadSystem(testCase,model)
         [modelname,modelhandle,modelpath] = loadSystem( ___ ,Name,Value)
         Description
         [modelname,modelhandle,modelpath] = loadSystem(testCase,model) loads the specified
         model and returns the name of the model, the model handle, and the path to the model.
         loadSystem loads a Simulink model within the scope of a single TestCase method class. The life
         cycle of the model is tied to the test case. When the test case goes out of scope, the testing
         framework closes the model without saving any changes to the model and clears any base workspace
         variables loaded by the model. Previously loaded models remain loaded. Variable values of previously
         loaded models might be overridden if, for example, the model being opened has model callbacks. To
         retain the variable values of opened models, add PreservingBaseWorkspace as an input Name-
         Value pair.
         Input Arguments
         testCase — Instance of test case
         sltest.TestCase object
         Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
         Value is the corresponding value. Name must appear inside quotes. You can specify several name and
         value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
         Example: 'PreservingBaseWorkspace',true
3-18
                                                                                         loadSystem
Whether to preserve existing base workspace variable values, specified as the comma-separated pair
consisting of 'PreservingBaseWorkspace' and true or false.
Whether to load the model and its referenced models, specified as the comma-separated pair
consisting of 'IncludingReferencedModels' and true or false.
Output Arguments
modelname — Name of loaded model
string | character vector
Attributes
Access                                            public
Examples
Load Model
                                                                                              3-19
3   Methods
         See Also
         sltest.TestCase
         Topics
         “Test Models Using MATLAB-Based Simulink Tests”
         “Using MATLAB-Based Simulink Tests in the Test Manager”
         “Collect Coverage Using MATLAB-Based Simulink Tests”
Introduced in R2020b
3-20
                                                                                          simulate
simulate
Class: sltest.TestCase
Package: sltest
Syntax
simulate(testcase,model)
simulate(testcase,siminput)
simulate(testcase,Name,Value)
Description
simout = simulate(testcase,model) simulates the specified model and returns a
Simulink.SimulationOutput object.
Input Arguments
testCase — Instance of test case
sltest.TestCase object
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Example: 'InFolder','C:\matlab\myTest'
                                                                                             3-21
3   Methods
         Name of folder that contains the model to simulate, specified as the comma-separated pair consisting
         of 'InFolder' and the name of the folder specified as a string or character vector.
Note You can use the sim function name-value pairs with the simulate method.
         Output Arguments
         simout — Simulation result object
         Simulink.SimulationOutput object
         Attributes
          Access                                           public
          Sealed                                           true
Examples
3-22
                                                                               simulate
                  'InFolder','C:/matlab/newTestFolder');
            end
      end
end
See Also
Simulink.SimulationInput | Simulink.SimulationOutput | sim | sltest.TestCase
Topics
“Test Models Using MATLAB-Based Simulink Tests”
“Using MATLAB-Based Simulink Tests in the Test Manager”
“Collect Coverage Using MATLAB-Based Simulink Tests”
Introduced in R2020b
                                                                                 3-23
3   Methods
         verifySignalsMatch
         Class: sltest.TestCase
         Package: sltest
         Syntax
         verifySignalsMatch(testCase,actual,expected)
         verifySignalsMatch( ___ ,diagnostic)
         verifySignalsMatch( ___ ,Name,Value)
         Description
         verifySignalsMatch(testCase,actual,expected) verifies that the actual and expected signal
         data values are equivalent. When a verification fails, the failure is recorded and the test runs to
         completion. For more information, see matlab.unittest.qualifications.Verifiable.
         verifySignalsMatch( ___ ,diagnostic) returns diagnostic information when the actual and
         expected data values are not equivalent.
         verifySignalsMatch( ___ ,Name,Value) filters test content with additional options specified by
         one or more Name,Value pair arguments.
         Input Arguments
         testCase — Instance of test case
         sltest.TestCase object
         Actual values to compare to expected values, specified as time series data, a string, or character
         array. The data for each actual value must pair data value with time value. The data must be in a
         format supported by the Simulation Data Inspector. The Simulation Data Inspector requires data in a
         format that associates sample values with time. Supported formats include timeseries, Structure
         with time, and Dataset.
         Example: 'C:/matlab/data/actualData.mat'
         Expected values to use as the baseline for the comparison. The data for each expected value must
         pair data value with time value. The data must be in a format supported by the Simulation Data
         Inspector. The Simulation Data Inspector requires data in a format that associates sample values with
         time. Supported formats include timeseries, Structure with time, and Dataset.
         Example: 'C:/matlab/data/expectedData.mat'
3-24
                                                                                      verifySignalsMatch
Diagnostic information to display when the verification that the actual and expected values are
equivalent fails, specified as a string, character array, a function handle, or an instance of a
matlab.unittest.diagnostics.Diagnostic class.
Example: 'Simulation output does not match.'
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Absolute tolerance, specified as the comma-separated pair consisting of 'AbsTol' and the scalar
value of the tolerance. The tolerance specifies the magnitude of the difference between the actual
and expected values.
Example: 'AbsTol',1e-9
Relative tolerance, specified as the comma-separated pair consisting of 'RelTol' and the scalar
value of the tolerance. The relative tolerance specifies the magnitude of the difference between the
actual and expected values, relative to the expected value.
Example: 'RelTol',.002
Time tolerance, specified as the comma-separated pair consisting of 'TimeTol' and the scalar value
of the tolerance.
Example: 'TimeTol',.2
Attributes
Access                                              public
Sealed                                              true
                                                                                                   3-25
3   Methods
Examples
         Create a test case for interactive use. Then, simulate the model in normal mode to obtain the
         expected values, and simulate in rapid accelerator mode to obtain the actual values. Use
         verifySignalsMatch to compare the values.
         testCase =...
            sltest.TestCase.forInteractiveUse;
         expected = testCase.simulate('myModel',...
            'SimulationMode','Normal');
         actual = testCase.simulate('myModel',...
            'SimulationMode','Rapid-Accelerator');
testCase.verifySignalsMatch(actual,expected)
         Create a test case for interactive use. Simulate the model in rapid accelerator mode to obtain the
         actual values. Use verifySignalsMatch to compare the actual values to the baseline values saved
         in a MAT-file. Set a relative tolerance.
         testCase =...
            sltest.TestCase.forInteractiveUse;
         actual = testCase.simulate('myModel',...
            'SimulationMode','Rapid-Accelerator');
         testCase.verifySignalsMatch(actual,'baseline.mat',...
            'RelTol',0.001)
         Create a test case for interactive use. Then, simulate the model in rapid accelerator mode to obtain
         the actual values. Use verifySignalsMatch to compare the actual values to the baseline values
         saved in a MAT-file. Specify the diagnostic message to display if the verification fails.
         testCase =...
            sltest.TestCase.forInteractiveUse;
         actual = testCase.simulate('myModel',...
            'SimulationMode','Rapid-Accelerator');
         testCase.verifySignalsMatch(actual,'baseline.mat',...
            'Rapid-Accel output did not match.')
         See Also
         Simulink.sdi.constraints.MatchesSignal | assertSignalsMatch | assumeSignalsMatch
         | fatalAssertSignalsMatch | matlab.unittest.constraints.AbsoluteTolerance |
3-26
                                                              verifySignalsMatch
matlab.unittest.constraints.RelativeTolerance |
matlab.unittest.qualifications.Verifiable | sltest.TestCase
Topics
“Test Models Using MATLAB-Based Simulink Tests”
Introduced in R2020b
                                                                          3-27
3   Methods
         addBaselineCriteria
         Class: sltest.testmanager.TestCase
         Package: sltest.testmanager
         Syntax
         base = addBaselineCriteria(tc,file)
         base = addBaselineCriteria(tc,file,'RefreshIfExists',true)
         base = addBaselineCriteria(tc,excel,'SeparateBaselines',false)
         base = addBaselineCriteria(tc,excel,'Sheets',sheets,Name,Value)
         Description
         base = addBaselineCriteria(tc,file) adds a MAT-file, Simulation Data Inspector (SDI)
         MLDATX file, or Microsoft Excel file as baseline criteria to a baseline test case. If file is an Excel file
         that has multiple sheets, each is added to the test case as a separate baseline set.
         Input Arguments
         tc — Test case
         sltest.testmanager.TestCase object
         Test case that you want to add the baseline criteria to, specified as an
         sltest.testmanager.TestCase object.
         File and path name of the baseline criteria file, specified as a character vector. You can specify a MAT-
         file, Simulation Data Inspector MLDATX file, or a Microsoft Excel file.
         Example: 'C:\MATLAB\baseline_API.mat'
File and path name of the Excel file to use as the baseline criteria, specified as a character vector.
3-28
                                                                                        addBaselineCriteria
Example: 'C:\MATLAB\baseline.xlsx'
Names of sheets from Excel file to add, specified as a character vector, string, or array of strings.
Example: 'signals', ["Heater","Plant"]
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Example: 'Ranges','B1:C4','RefreshIfExists',false
Ranges of cells from the sheets that you add as baseline criteria, specified as a character vector, a
string, or an array of strings. The ranges you specify must correspond to the sheets you specify. For
example, if you specify one sheet, specify one range. If you specify a cell array of sheets, each value
in the 'Ranges' cell array must correspond to a sheet in the 'Sheets' cell array. Specify an empty
range to use the entire sheet.
Example: 'B2:C30', "D2:E30", ["B2:C30", "D2:E30", "B2:C30"],
["B2:C30","","D2:E30"]
Option to replace the test case baseline criteria, specified as a Boolean. Use false to return an error
if the test case already has baseline criteria, that is, to prevent overwriting the baseline. Use true to
add the baseline criteria, replacing the existing baseline.
Option to use each sheet in specified by the 'Sheets' argument as a separate baseline, specified as
true or false.
Output Arguments
base — Baseline criteria
sltest.testmanager.BaselineCriteria object | array of
sltest.testmanager.BaselineCriteria objects
Examples
                                                                                                     3-29
3   Methods
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('API Test File');
         ts = createTestSuite(tf,'API Test Suite');
         tc = createTestCase(ts,'baseline','Baseline API Test Case');
         Use an Excel file as baseline, overwriting the existing baseline on the test case.
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('Excel Test File');
         ts = createTestSuite(tf,'Excel Test Suite');
         tc = createTestCase(ts,'baseline','Baseline Excel Test Case');
         Use an Excel file as baseline, creating one baseline even if the Excel file has multiple sheets.
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('Excel Test File');
         ts = createTestSuite(tf,'Excel Test Suite');
         tc = createTestCase(ts,'baseline','Baseline Excel Test Case');
         Select three sheets from an Excel file to use as the baseline. For each sheet, specify a range of cells.
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('Excel Test File');
3-30
                                                                                               addBaselineCriteria
% Add baseline criteria from file, using the sheets and cell ranges specified
baseline = addBaselineCriteria(tc,'C:\MATLAB\myexcel.xlsx','Sheets',sheets,'Ranges',ranges);
See Also
sltest.testmanager.BaselineCriteria
Topics
“Baseline Criteria”
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                                                                            3-31
3   Methods
         addDataStoreSignal
         Class: sltest.testmanager.LoggedSignalSet
         Package: sltest.testmanager
         Syntax
         obj = addDataStoreSignal(lgset,BlockPath)
         Description
         obj = addDataStoreSignal(lgset,BlockPath) creates and adds an
         sltest.testmanager.LoggedSignal object to a set when the LoggedSignal object derives from
         a data store or Simulink.Signal object. You must open or load the model to add a LoggedSignal
         from the model.
         Input Arguments
         lgset — Logged signal set
         sltest.testmanager.LoggedSignalSet object
         Simulink.BlockPath object that uniquely identifies a Data Store Write block and the associated
         data store memory or associated Simulink.Signal object.
Examples
3-32
                                                                          addDataStoreSignal
Begin with the model and signal set created in the previous example.
See Also
gcb | sltest.testmanager.LoggedSignal
Topics
“Create and Run Test Cases with Scripts”
“Capture Simulation Data in a Test Case”
Introduced in R2019a
                                                                                      3-33
3   Methods
         addExcelSpecification
         Package: sltest.testmanager
         Syntax
         addExcelSpecification(obj,'Sheet',sheet)
         addExcelSpecification(obj,'Sheet',sheet,'Range',range)
         Description
         addExcelSpecification(obj,'Sheet',sheet) adds the specified Excel sheet to the baseline
         criteria or test case inputs obj.
Examples
Create the test file, test suite, and test case structure.
         Add baseline criteria from an Excel file. Specifying two sheets creates two baseline criteria.
         base = addBaselineCriteria(tc,'C:\MATLAB\baseline.xlsx','Sheets',{'Optics','Converter'});
base(1).addExcelSpecification('Sheet','X2Out');
         Show the contents of the Sheet property of the Excel specifications for each baseline criteria. The
         first set now includes the X2Out sheet.
         base(1).ExcelSpecifications(:).Sheet
         base(2).ExcelSpecifications(:).Sheet
         ans =
             'Optics'
         ans =
             'X2Out'
3-34
                                                                                      addExcelSpecification
ans =
    'Converter'
Input Arguments
obj — Object to which to add Excel sheet or cell data
baseline criteria object | test case object
Object to which to add Excel sheet or cell data, specified as a baseline criteria or test case input
object.
Excel sheet to add to baseline criteria or test case inputs, specified as a character vector.
Example: 'Optics'
Range of cells from the specified sheet to add to test case inputs, specified as a character vector or
string in one of these forms:
                                     Example: 'Range','Corner1:Corner2'
''                                   If unspecified, the importing function automatically detects the
                                     used range.
Unspecified or Empty
                                     Example: 'Range',''
Example: 'Range','1:7'
                                                                                                       3-35
3   Methods
                                           Example: 'Range','A:F'
          'NamedRange'                     In Excel, you can create names to identify ranges in the
                                           spreadsheet. For instance, you can select a rectangular portion
          Excel Named Range                of the spreadsheet and call it 'myTable'. If such named ranges
                                           exist in a spreadsheet, then the importing function can read that
                                           range using its name.
Example: 'Range','myTable'
Example: 'A1:C20'
         See Also
         sltest.testmanager.BaselineCriteria | sltest.testmanager.TestInput
         Topics
         “Baseline Criteria”
         “Inputs”
         “Run Tests Using External Data”
Introduced in R2017b
3-36
                                                                                                  addInput
addInput
Class: sltest.testmanager.TestCase
Package: sltest.testmanager
Syntax
input = addInput(tc,file,Name,Value)
Description
input = addInput(tc,file,Name,Value) adds a file to the Inputs section of the test case and
returns a test input object, sltest.testmanager.TestInput.
Input Arguments
tc — Test case
sltest.testmanager.TestCase object
Test case that you want to add the test input to, specified as a sltest.testmanager.TestCase
object.
Name and path of MAT-file or Microsoft Excel input file, specified as a character vector.
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Example: 'Sheets','mysheet','Ranges','C1:F10','CreateIterations',false
Test case simulation number that the inputs apply to, specified as 1 or 2. This setting applies to
equivalence tests.
Example: 'SimulationIndex',2
Option to add the input file to the iteration table under Iterations in the test case, specified as
Boolean.
                                                                                                      3-37
3   Methods
Example: 'CreateIterations',false
         Names of sheets from Excel file to use as test case inputs, specified as a character vector, string, or
         array of strings.
         Example: 'testinputs', ["Heater","Plant"]
         Ranges of cells from the sheets that you added as inputs, specified as a character vector, string, or
         array of strings. You can specify 'Ranges' only if you also specify 'Sheets'. The ranges you specify
         must correspond to the sheets. For example, if you specify one sheet, specify one range. If you specify
         a cell array of sheets, each value in the 'Ranges' cell array must correspond with a sheet in the
         'Sheets' cell array.
                                               Example: 'Range','Corner1:Corner2'
          ''                                   If unspecified, the importing function automatically detects the
                                               used range.
          Unspecified or Empty
                                               Example: 'Range',''
Example: 'Range','1:7'
3-38
                                                                                             addInput
                                   Example: 'Range','A:F'
'NamedRange'                       In Excel, you can create names to identify ranges in the
                                   spreadsheet. For instance, you can select a rectangular portion
Excel’s Named Range                of the spreadsheet and call it 'myTable'. If such named ranges
                                   exist in a spreadsheet, then the importing function can read that
                                   range using its name.
Example: 'Range','myTable'
Option to use each sheet in the Excel file or specified by the 'Sheets' argument as a separate input,
specified as true or false.
Output Arguments
input — Test input
sltest.testmanager.TestInput object | array of sltest.testmanager.TestInput objects
Examples
You can add data from a Microsoft Excel spreadsheet. The spreadsheet used in this example is
located in the example folder. Add only the two sheets that have data as input.
                                                                                                3-39
3   Methods
setProperty(tc,'Model','sltestExcelExample');
This example shows the syntax to add Excel file sheets and range.
         See Also
         sltest.testmanager.TestCase
         Topics
         “Create and Run Test Cases with Scripts”
         “Format Test Case Data in Excel”
         “Inputs”
Introduced in R2015b
3-40
                                                                                              addIteration
addIteration
Class: sltest.testmanager.TestCase
Package: sltest.testmanager
Syntax
addIteration(tc,iter)
addIteration( ___ ,name)
Description
addIteration(tc,iter) adds a test iteration to the test case. The Test Manager gives the
iteration a unique name.
addIteration( ___ ,name) adds a test iteration to the test case with a specified name, which must
be unique.
Input Arguments
tc — Test case to add iteration to
sltest.testmanager.TestCase object
Test case that you want to add the iteration to, specified as a sltest.testmanager.TestCase
object.
Test iteration that you want to add to the test case, specified as a
sltest.testmanager.TestIteration object.
Test iteration name, specified as a character vector. The name must be unique with respect to other
iterations in the test case. This is an optional argument.
Example: 'Test Iteration 5'
Examples
In this example, there must be parameter sets defined in the Parameter Overrides section of the
test case. The iterations are generated during test execution. This section of script is in the Scripted
Iterations section of the test case. It will execute only in the Scripted Iterations section.
                                                                                                    3-41
3   Methods
% Define parameter sets for a test case and add this code in the
         See Also
         sltest.testmanager.TestIteration
         Topics
         “Test Iterations”
         “Create and Run Test Cases with Scripts”
Introduced in R2016a
3-42
                                                                                      getTestCaseResults
getTestCaseResults
Class: sltest.testmanager.TestCase
Package: sltest.testmanager
Syntax
tcresult = getTestCaseResults(tc)
Description
tcresult = getTestCaseResults(tc) returns the test case results history for the specified test
case, tc. The test case history includes the results for all runs of the test case in the Test Manager.
Input Arguments
tc — Test case
sltest.testmanager.TestCase object
Test case for which to obtain result history, specified as an sltest.testmanager.TestCase object.
Output Arguments
tcresult — Test case result history
array of sltest.testmanager.TestCaseResult objects
Examples
This example shows how to create a test file, test suite, and simulation test case programmatically. It
also show how to obtain the results. The test case runs on the sldemo_autotrans model.
sltest.testmanager.clear;
tf = sltest.testmanager.TestFile('TestFile1');
ts = createTestSuite(tf,'TestSuite1');
tc = createTestCase(ts,'simulation','TestCase1');
Remove default test suite so that only the created test suite is used.
                                                                                                   3-43
3   Methods
         tsDel = tf.getTestSuites();
         remove(tsDel(1));
Assign the system under test to the test case. Run the test.
         setProperty(tc,'Model','sldemo_autotrans');
         tcresult = run(tc);
tcresultobj = getTestCaseResults(tc);
         See Also
         getTestCase
Introduced in R2019b
3-44
                                                                                          addLoggedSignal
addLoggedSignal
Class: sltest.testmanager.LoggedSignalSet
Package: sltest.testmanager
Syntax
obj = addLoggedSignal(lgset,BlockPath,PortIndex)
obj = addLoggedSignal( ___ ,'LeafElement',busleaf)
Description
obj = addLoggedSignal(lgset,BlockPath,PortIndex) creates and adds an
sltest.testmanager.LoggedSignal object to a sltest.testmanager.LoggedSignalSet
object. You must open or load the model to add signals from the model.
Input Arguments
lgset — Logged signal set
sltest.testmanager.LoggedSignalSet object
Simulink.BlockPath object that uniquely identifies the block that outputs the signal.
Index of the output port for the block designated by BlockPath, starting from 1.
Examples
% Open model
sldemo_absbrake
                                                                                                    3-45
3   Methods
         ts = sltest.testmanager.TestSuite(tf,'myts');
         tc = sltest.testmanager.TestCase(ts,'baseline','mytc');
         Select the Vehicle Speed block and enter gcb. Use the returned path to create a
         Simulink.BlockPath object.
setProperty(tc,'Model','sldemo_absbrake');
         See Also
         gcb
         Topics
         “Create and Run Test Cases with Scripts”
         “Capture Simulation Data in a Test Case”
Introduced in R2019a
3-46
                                                                                      addLoggedSignalSet
addLoggedSignalSet
Class: sltest.testmanager.TestCase
Package: sltest.testmanager
Syntax
obj = addLoggedSignalSet(tc,Name,Value)
Description
obj = addLoggedSignalSet(tc,Name,Value) creates and adds a LoggedSignalSet object to
an sltest.testmanager.TestCase object.
Input Arguments
tc — Test case
sltest.testmanager.TestCase object
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
When the test case is an equivalence test, this index specifies the simulation that contains the signal
set.
Example: obj = getLoggedSignalSets(tc_equiv,'SimulationIndex',2);
Examples
                                                                                                   3-47
3   Methods
         See Also
         sltest.testmanager.EquivalenceCriteria | sltest.testmanager.LoggedSignalSet
         Topics
         “Create and Run Test Cases with Scripts”
         “Capture Simulation Data in a Test Case”
Introduced in R2019a
3-48
                                                                                      addParameterOverride
addParameterOverride
Class: sltest.testmanager.ParameterSet
Package: sltest.testmanager
Syntax
ovr = addParameterOverride(ps,Name,Value)
Description
ovr = addParameterOverride(ps,Name,Value) adds a parameter override to a parameter set
and returns a parameter override object, sltest.testmanager.ParameterOverride.
Input Arguments
ps — Parameter set
sltest.testmanager.ParameterSet object
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Example: 'Value',5.2
Name of the parameter to override, specified as a string or character vector. Name is a required
input.
Value of the parameter to override, specified as a numeric or a string. If the value is a string, it is
evaluated as a MATLAB expression when the test executes. Value is a required input.
Block path of the parameter to override, specified as a string or character vector. A block path is
required only if the parameter to override is a block parameter. The combination of Name and
BlockPath properties must be unique within a parameter set.
                                                                                                          3-49
3   Methods
         Output Arguments
         ovr — Parameter override
         sltest.testmanager.ParameterOverride object
Examples
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('API Test File');
         ts = createTestSuite(tf,'API Test Suite');
         tc = createTestCase(ts,'baseline','Baseline API Test Case');
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015b
3-50
                                                                                                     export
export
Class: sltest.testmanager.ParameterSet
Package: sltest.testmanager
Syntax
export(ps,filename)
export(ps,filename,sheet)
Description
export(ps,filename) exports sltest.testmanager.ParameterSet object data to an Excel
file. The data for each parameter is exported into the spreadsheet columns, Parameter, Value, and
BlockPath. For example, this spreadsheet shows three parameters from different model workspaces:
the top model (which is unnamed), the MdlRefLeaf1 model workspace, and the MdlRefLeaf2 model
workspace.
Note By default, the parameter set data is exported to the first sheet in the specified file and existing
data in that sheet is overwritten.
export(ps,filename,sheet) exports the parameter set data to the specified sheet in the Excel
file.
Input Arguments
ps — Parameter set to export
sltest.testmanager.ParameterSet object
File name of the Excel workbook, specified as a string or character vector. If the file does not exist, it
is created.
                                                                                                      3-51
3   Methods
         Name of Excel workbook sheet, specified as a string or character vector. If you do not specify a sheet
         name, the parameter set data is exported to the first sheet in the specified file and existing data in
         that sheet is overwritten. If you specify a sheet name that does not exist, that sheet is created.
Examples
         Add a parameter set a to a test case (tc), then override the value of parameter a in that parameter
         set. Export the parameter set to a sheet in an Excel file.
         ps = addParameterSet(tc,'Name','Param Set');
         addParameterOverride(ps,'a',1);
         export(ps,'myPSfile.xlsx','Sheet2');
         See Also
         addParameterOverride | sltest.testmanager.ParameterSet
         Topics
         “Override Model Parameters in a Test Case”
Introduced in R2020b
3-52
                                                                                       addParameterSet
addParameterSet
Class: sltest.testmanager.TestCase
Package: sltest.testmanager
Syntax
pset = addParameterSet(tc,Name,Value)
Description
pset = addParameterSet(tc,Name,Value) adds a parameter set to the test case and returns a
parameter set object, sltest.testmanager.ParameterSet.
Input Arguments
tc — Test case
sltest.testmanager.TestCase object
Test case that you want to add the parameter set to, specified as a
sltest.testmanager.TestCase object.
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Example: 'SimulationIndex',2
Name of the parameter set, specified as a character vector. This name is the label shown in the test
case parameter set table. If you do not specify a name, the function creates an auto-generated unique
name.
The full name and path of the .m file or MAT-file, which contains the parameter values, specified as a
character vector. If no parameter file path is given, then the function creates an empty parameter set.
Simulation number that the parameter set applies to, specified as an integer, 1 or 2. This parameter
applies to the simulation test case where there are two simulations. For baseline and simulation test
cases, the simulation index is 1.
                                                                                                  3-53
3   Methods
         Output Arguments
         pset — Parameter set
         sltest.testmanager.ParameterSet object
Examples
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('API Test File');
         ts = createTestSuite(tf,'API Test Suite');
         tc = createTestCase(ts,'baseline','Baseline API Test Case');
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015b
3-54
                                                                                         createInputDataFile
createInputDataFile
Class: sltest.testmanager.TestCase
Package: sltest.testmanager
Syntax
input = createInputDataFile(tc,file)
input = createInputDataFile(tc,file,Name,Value)
Description
input = createInputDataFile(tc,file) creates an input file for a test case. The file includes
the signals based on the inport blocks in the model specified for the test case tc. You enter the time
and signal data either in Microsoft Excel or, for MAT-files, using the signal editor in the Test Manager.
For information on the file format the Test Manager uses for Microsoft Excel files, see “Format Test
Case Data in Excel”.
Examples
Create the input file template for a test case, using the Excel file format. Name the sheet for the
template Optics. Creating the file also adds it as input in the test case. After you create the file, edit
it to populate it with signal data.
% Create test file
tf = sltest.testmanager.TestFile('Excel Input Test File');
% Generate Excel file template and add it to Inputs section, specifying the sheet name
input = createInputDataFile(tc,'C:\MyHomeDir\myexcel.xlsx','Sheet','Optics');
Input Arguments
tc — Test case
sltest.testmanager.TestCase object
Test case that you want to create the template input file from, specified as a
sltest.testmanager.TestCase object.
                                                                                                      3-55
3   Methods
Name and path of MAT-file or Microsoft Excel to create, specified as a character vector.
         Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
         Value is the corresponding value. Name must appear inside quotes. You can specify several name and
         value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
         Example: 'Sheet','mysheet','Range','C1:F10','CreateIterations',false
         Name to give the sheet in the new Excel file, specified as a character vector.
         Example: 'Sheet','testinputs'
         Ranges of cells to add the inputs to in the sheet, specified as a character vector. You can specify
         'Range' only if you also specify 'Sheet'.
         Example: 'Range','B2:C30'
         Output Arguments
         input — Test input file
         sltest.testmanager.TestInput object
         See Also
         addInput | sltest.testmanager.TestCase
         Topics
         “Format Test Case Data in Excel”
         “Run Tests Using External Data”
         “Test Case Input Data Files”
Introduced in R2018a
3-56
                                                                          addReportBody
addReportBody
Class: sltest.testmanager.TestResultReport
Package: sltest.testmanager
Syntax
addReportBody(obj)
Description
addReportBody(obj) adds the main body pages to the report.
• genResultSetBlock
• genTestSuiteResultBlock
• genTestCaseResultBlock
Input Arguments
obj — Test report object
sltest.testmanager.TestResultReport object
See Also
sltest.testmanager.TestResultReport
Topics
“Export Test Results”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                                  3-57
3   Methods
         addReportTOC
         Class: sltest.testmanager.TestResultReport
         Package: sltest.testmanager
         Syntax
         addReportTOC(obj)
         Description
         addReportTOC(obj) adds the table of contents page to the report.
         Input Arguments
         obj — Test report object
         sltest.testmanager.TestResultReport object
         See Also
         sltest.testmanager.TestResultReport
         Topics
         “Export Test Results”
         “Create and Run Test Cases with Scripts”
Introduced in R2016a
3-58
                                                                          addTitlePage
addTitlePage
Class: sltest.testmanager.TestResultReport
Package: sltest.testmanager
Syntax
addTitlePage(obj)
Description
addTitlePage(obj) adds the title page to the report.
Input Arguments
obj — Test report object
sltest.testmanager.TestResultReport object
See Also
sltest.testmanager.TestResultReport
Topics
“Export Test Results”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                                3-59
3   Methods
         captureBaselineCriteria
         Class: sltest.testmanager.TestCase
         Package: sltest.testmanager
         Syntax
         baseline = captureBaselineCriteria(tc,file,append)
         baseline = captureBaselineCriteria(tc,file,append,Name,Value)
         Description
         baseline = captureBaselineCriteria(tc,file,append) runs the system under test and
         captures a baseline criteria set as a MAT-file, Simulation Data Inspector (SDI) MLDATX file, or
         Microsoft Excel file. The function returns a baseline criteria object,
         sltest.testmanager.BaselineCriteria. Use this function only if the test type is a baseline test
         case.
         Input Arguments
         tc — Test case
         sltest.testmanager.TestCase object
         File and path name of the baseline criteria file, specified as a character vector. You can specify a MAT-
         file, Simulation Data Inspector MLDATX file, or a Microsoft Excel file.
         Example: 'C:\MATLAB\baseline_API.mat'
         Append baseline criteria if criteria already exists, specified as a Boolean. The Boolean true appends
         to existing criteria, and false replaces existing criteria.
         Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
         Value is the corresponding value. Name must appear inside quotes. You can specify several name and
         value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
         Example: 'Sheet','mysheet','Range','C1:F10'
3-60
                                                                                     captureBaselineCriteria
Pairs for MAT-Files, Simulation Data Inspector (SDI) .mldatx file, and Microsoft Excel Files
Simulink release to capture the baseline data in, specified as a character vector or string array. Use a
release specified in your preferences. For more information, see sltest.testmanager.getpref
and sltest.testmanager.setpref.
Example: 'Release','R2017a'
Whether to capture baseline data for test case iterations, specified as a Boolean.
Example: 'CaptureForIterations',true
Name to sheet to capture baseline criteria to, specified as a character vector or string array.
Example: 'Sheet','testinputs'
Ranges of cells to capture baseline criteria to, specified as a character vector or string array. You can
specify 'Range' only if you also specify 'Sheet'.
Example: 'Range','B2:C30'
Output Arguments
baseline — Baseline criteria object
object
Examples
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('API Test File');
ts = createTestSuite(tf,'API Test Suite');
tc = createTestCase(ts,'baseline','Baseline API Test Case');
                                                                                                      3-61
3   Methods
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
         “Capture Baseline Criteria”
Introduced in R2015b
3-62
                                                                                 captureEquivalenceCriteria
captureEquivalenceCriteria
Class: sltest.testmanager.TestCase
Package: sltest.testmanager
Syntax
eq = captureEquivalenceCriteria(tc,replaceAll)
Description
eq = captureEquivalenceCriteria(tc,replaceAll) runs the System Under Test in
Simulation 1 and captures an equivalence criteria set. The function returns an equivalence criteria
object, sltest.testmanager.EquivalenceCriteria. This function can be used only if the test
type is an equivalence test case.
Input Arguments
tc — Test case
sltest.testmanager.TestCase object
Replace existing equivalence criteria if criteria already exist in the test case, specified as a Boolean.
true replaces existing criteria, and false produces an error if criteria already exist in the test case.
Output Arguments
eq — Equivalence criteria object
object
Examples
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('API Test File');
ts = createTestSuite(tf,'API Test Suite');
tc = createTestCase(ts,'equivalence','Equivalence Test Case');
                                                                                                     3-63
3   Methods
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015b
3-64
                                                                                        close
close
Class: sltest.testmanager.TestFile
Package: sltest.testmanager
Syntax
close(tf)
Description
close(tf) closes the test file in the Test Manager and does not save unsaved changes.
Input Arguments
tf — Test file
sltest.testmanager.TestFile object
Examples
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                                                        3-65
3   Methods
         convertTestType
         Class: sltest.testmanager.TestCase
         Package: sltest.testmanager
         Syntax
         convertTestType(tc,testType)
         Description
         convertTestType(tc,testType) converts the test case type to a different type.
         If you convert certain test case types to another type, then you can lose information about the
         original test case:
         Input Arguments
         tc — Test case
         sltest.testmanager.TestCase object
         Test case type that you want to convert to, specified as a sltest.testmanager.TestCaseTypes
         enumeration. Specify:
Examples
         % Create new test file with test suite and default test case
         tf = sltest.testmanager.TestFile('API Test File');
         ts = getTestSuites(tf);
         tc = getTestCases(ts);
3-66
                                                                                        convertTestType
Alternatives
You can also convert the test case type using the context menu in the Test Browser pane. Right-click
the test case, select Convert to, and then select the test case type you want to convert the test case
to.
See Also
sltest.testmanager.TestCase
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2016b
                                                                                                 3-67
3   Methods
         convertTestType
         Class: sltest.testmanager.TestFile
         Package: sltest.testmanager
         Syntax
         convertTestType(tf,testType)
         Description
         convertTestType(tf,testType) converts the test case type to a different type. The function
         converts all test cases contained in the test file. If you want to convert a single test case, then use the
         convertTestType (TestCase) method.
         If you convert certain test case types to another type, then you can lose information about the
         original test case:
         Input Arguments
         tf — Test file
         sltest.testmanager.TestFile object
         Test file that contains the test cases you want to convert to a different type, specified as a
         sltest.testmanager.TestFile object.
         Test case type that you want to convert to, specified as a sltest.testmanager.TestCaseTypes
         enumeration. Specify:
Examples
         % Create new test file with test suite and default test case
         tf = sltest.testmanager.TestFile('API Test File');
3-68
                                                                                         convertTestType
ts = getTestSuites(tf);
tc1 = getTestCases(ts);
Alternatives
You can also convert the test case type using the context menu in the Test Browser pane. Right-click
the test file, select Convert to, and then select the test case type you want to convert the test cases
to.
See Also
sltest.testmanager.TestCase
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2016b
                                                                                                  3-69
3   Methods
         convertTestType
         Class: sltest.testmanager.TestSuite
         Package: sltest.testmanager
         Syntax
         convertTestType(ts,testType)
         Description
         convertTestType(ts,testType) converts the test case type to a different type. The function
         converts all of the test cases contained in the test suite. If you want to convert a single test case, then
         use the convertTestType (TestCase) method.
         If you convert certain test case types to another type, then you can lose information about the
         original test case:
         Input Arguments
         ts — Test suite
         sltest.testmanager.TestSuite object
         Test suite that contains the test cases you want to convert to a different type, specified as a
         sltest.testmanager.TestSuite object.
         Test case type that you want to convert to, specified as a sltest.testmanager.TestCaseTypes
         enumeration. Specify:
Examples
         % Create new test file with test suite and default test case
         tf = sltest.testmanager.TestFile('API Test File');
3-70
                                                                                         convertTestType
ts = getTestSuites(tf);
tc1 = getTestCases(ts);
Alternatives
You can also convert the test case type using the context menu in the Test Browser pane. Right-click
the test suite, select Convert to, and then select the test case type you want to convert the test cases
to.
See Also
sltest.testmanager.TestCase
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2016b
                                                                                                   3-71
3   Methods
         copySimulationSettings
         Class: sltest.testmanager.TestCase
         Package: sltest.testmanager
         Syntax
         copySimulationSettings(tc,fromSimIndex,toSimIndex)
         Description
         copySimulationSettings(tc,fromSimIndex,toSimIndex) copies the simulation setting from
         one simulation number to another within an equivalence test case. This function works only for
         equivalence test case types.
         Input Arguments
         tc — Equivalence test case
         sltest.testmanager.TestCase object
         Equivalence test case that you want to copy simulation settings in, specified as a
         sltest.testmanager.TestCase object.
         Simulation number you want to copy the settings from, specified as an integer, 1 or 2. This is the
         source simulation.
         Simulation number you want to copy the settings to, specified as an integer, 1 or 2. This is the target
         simulation.
Examples
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('API Test File');
         ts = createTestSuite(tf,'API Test Suite');
         tc = createTestCase(ts,'equivalence','Equivalence Test Case');
3-72
                                                                 copySimulationSettings
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                                                 3-73
3   Methods
         createTestCase
         Class: sltest.testmanager.TestSuite
         Package: sltest.testmanager
         Syntax
         tc = createTestCase(ts,type,name,runOnTarget)
         Description
         tc = createTestCase(ts,type,name,runOnTarget) creates a new test case within the test
         suite. You can specify the test case name and type: baseline, equivalence, and simulation. Also, if you
         are using the test case for real-time testing, you can specify this using the runOnTarget argument.
         Input Arguments
         ts — Test suite
         sltest.testmanager.TestSuite object
         Test suite that you want to add a test case to, specified as an sltest.testmanager.TestSuite
         object.
         Test case name, specified as a character vector. If this input argument is empty, then the Test
         Manager gives the test case a unique name.
         Specify if you want to run the test case simulation on a target, specified as a cell array of Booleans.
         This is an optional argument. For more information on real-time testing, see “Test Models in Real
         Time”.
         Output Arguments
         tc — Test case
         sltest.testmanager.TestCase object
3-74
                                                                  createTestCase
Examples
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                                          3-75
3   Methods
         createTestForSubsystem
         Class: sltest.testmanager.TestFile
         Package: sltest.testmanager
(To be removed) Create test harness and test case for subsystem in test file
         Syntax
         tc = createTestForSubsystem(tf,'Subsystem',subsystem)
         tc = createTestForSubsystem(tf,'Subsystem',subsystem,Name,Value)
         Description
         tc = createTestForSubsystem(tf,'Subsystem',subsystem) creates a harness on the
         specified subsystem, model reference block, Stateflow chart, or another supported model component
         (see “Test Harness and Model Relationship”. It also creates a baseline test case and test suite in the
         specified teExcelst file. This function also simulates the model and adds the input and the output files
         to the test case, as MAT-files. For more information, see “Generate Tests and Test Harness for a
         Component or Model”.
         Input Arguments
         tf — Test file
         sltest.testmanager.TestFile object
         Full path of the subsystem, specified as a character vector or string array. If the subsystem or
         component is in a Model block, you do not have to include the name of the block in the path. You can
         specify only the top-level model and system or the component under test.
         Example: 'f14/Controller'
         Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
         Value is the corresponding value. Name must appear inside quotes. You can specify several name and
         value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
3-76
                                                                                 createTestForSubsystem
Example: 'CreateExcelFile',true,'Sheet','mysheet'
Model name at the top of the hierarchy if the subsystem is in a referenced model, specified as a
character vector or string.
Example: 'TopModel','Plant'
Option to simulate the model to obtain subsystem inputs to use as inputs in the created test harness,
specified as a logical. If this property is true, the test harness uses the subsystem inputs from the
model simulation. If this property is false, the test harness does not use the subsystem inputs from
the simulation.
Example: 'UseSubsystemInputs',false
Simulation mode for simulation 2 of an equivalence test, specified as one of these values:
• "Normal"
• "Accelerator"
• "Rapid Accelerator"
• "Software-in-the-Loop (SIL)"
• "Processor-in-the-Loop (PIL)"
If you do not specify a simulation mode, the mode of the system under test is used. For information
about simulation modes, see “Choosing a Simulation Mode”. If TestType is equivalence and
Simulation2Mode is Software-in-the-Loop (SIL), an extra test harness is created in addition
to the test case and test harness.
Example: "Simulation2Mode","Software-in-the-Loop (SIL)"
                                                                                                   3-77
3   Methods
         Input file name and path for MAT-files, specified as a character vector or string array. Include the file
         extension .mat.
         Example: 'InputsLocation','C:\MATLAB\inputs_data.mat'
         File name and path to save baseline data to, specified as a character vector or string. Include the file
         extension .mat.
         Example: 'BaselineLocation','C:\MATLAB\baseline_data.mat'
         Pairs for Microsoft Excel Files
         Option to use Excel format for inputs and, for baseline tests only, outputs, specified as true or
         false. If you use the ExcelFileLocation argument to specify the file name and location, you do
         not need to also use CreateExcelFile.
         Example: 'CreateExcelFile',true
         File name and path to save the Excel file to, specified as a character vector or string. Include the
         extension .xlsx. If you specify a location, you do not need to also use the 'CreateExcelFile'
         option.
Example: 'ExcelFileLocation','C:\MATLAB\baseline_data.xlsx'
         Name of the sheet to save Excel data to, specified as a character vector or string.
         Example: 'Sheet','MySubsysTest'
         Pairs for Simulink Design Verifier
         Whether to generate tests using Simulink Design Verifier, specified as a logical. If this property is
         true, Simulink Design Verifier generates the tests to include in the test file. An error occurs if this
         property is true, but Simulink Design Verifier is not installed.
3-78
                                                                                createTestForSubsystem
Note To generate tests from Simulink Design Verifier, the system under test must be an atomic
subsystem.
Example: 'SLDVTestGeneration',true
Input source block for the test harness, specified as "Inport" or "Signal Editor".
Example: "HarnessSource","Signal Editor"
Output Arguments
tc — Test case
sltest.testmanager.testcase object
Examples
Create a baseline test case and test harness for a subsystem in a model reference, then save the
inputs in Excel format. Baseline tests are used primarily for debugging.
% Load the model
load_system('sltestBasicCruiseControl');
Compatibility Considerations
sltest.testmanager.TestFile.createTestForSubsystem will be removed
Not recommended starting in R2020b
• TestFile — Required name-value pair to specify the test file for the created test case
• Component — Required name-value pair to specify the component or model to test
• CreateTestFile — Optional name-value pair for whether to create a new test file
• CreateHarness — Optional name-value pair for whether to create a test harness in addition to
  the test case
                                                                                                   3-79
3   Methods
         See Also
         sltest.testmanager.createTestForComponent
         Topics
         “Create and Run Test Cases with Scripts”
         “Generate Tests and Test Harness for a Component or Model”
         “Create and Run a Back-to-Back Test”
Introduced in R2016a
3-80
                                                                                  createTestForSubsystem
createTestForSubsystem
Class: sltest.testmanager.TestSuite
Package: sltest.testmanager
(To be removed) Create test harness and test case for subsystem in test suite
Syntax
tc = createTestForSubsystem(ts,'Subsystem',subsystem)
tc = createTestForSubsystem(ts,'Subsystem',subsystem,Name,Value)
Description
tc = createTestForSubsystem(ts,'Subsystem',subsystem) creates a harness on the
specified subsystem and a baseline test case in the specified test suite. This function also simulates
the model and adds the input and the output files to the test case as MAT-files. files. For more
information, see “Generate Tests and Test Harness for a Component or Model”.
Input Arguments
ts — Test suite
sltest.testmanager.TestSuite object
Test suite in which to add the new test case, specified as an sltest.testmanager.TestSuite
object.
Full path of the subsystem, specified as a character vector or string array. If the subsystem or
component is in a Model block, you do not have to include the name of the block in the path. You can
specify only the top-level model and system or the component under test.
Example: 'f14/Controller'
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Example: 'CreateExcelFile',true,'Sheet','mysheet'
                                                                                                    3-81
3   Methods
         Model name at the top of the hierarchy if the subsystem is in a referenced model, specified as a
         character vector or string array.
         Example: 'TopModel','Plant'
         Test case type, specified as one of these strings: 'baseline', 'equivalence', or 'simulation'.
         Example: 'TestType','equivalence'
         Option to simulate the model to obtain subsystem inputs to use as inputs in the created test harness,
         specified as a logical. If this property is true, the test harness uses the subsystem inputs from the
         model simulation. If this property is false, the test harness does not use the subsystem inputs from
         the simulation.
         Example: 'UseSubsystemInputs',false
Simulation mode for simulation 2 of an equivalence test, specified as one of these values:
         • "Normal"
         • "Accelerator"
         • "Rapid Accelerator"
         • "Software-in-the-Loop (SIL)"
         • "Processor-in-the-Loop (PIL)"
         If you do not specify a simulation mode, the mode of the system under test is used. If TestType is
         equivalence and Simulation2Mode is Software-in-the-Loop (SIL), an extra test harness is
         created in addition to the test case and test harness.
         Example: "Simulation2Mode","Software-in-the-Loop (SIL)"
3-82
                                                                                   createTestForSubsystem
Input file name and location for MAT-files, specified as a character vector or string array. Include the
file extension .mat.
Example: 'InputsLocation','C:\MATLAB\inputs_data.mat'
File name and path to save baseline data to, specified as a character vector or string. Include the file
extension .mat.
Example: 'BaselineLocation','C:\MATLAB\baseline_data.mat'
Option to use Excel format for inputs and, for baseline tests only, outputs, specified as true or
false. If you use the 'ExcelFileLocation argument to specify the file name and location, you do
not need to also use 'CreateExcelFile.
Example: 'CreateExcelFile',true
File name and path to save the Excel file to, specified as a character vector or string array. Include
the extension .xlsx. If you specify a location, you do not need to also use the 'CreateExcelFile'
option.
Example: 'ExcelFileLocation','C:\MATLAB\baseline_data.xlsx'
Name of the sheet to save Excel data to, specified as a character vector or string array.
Example: 'Sheet','MySubsysTest'
Whether to generate tests using Simulink Design Verifier, specified as a logical. If this property is
true, Simulink Design Verifier generates the tests to include in the test suite.
Note To generate tests from Simulink Design Verifier, the system under test must be an atomic
subsystem.
                                                                                                    3-83
3   Methods
Example: 'SLDVTestGeneration',true
         Input source block for the test harness, specified as "Inport" or "Signal Editor".
         Example: "HarnessSource","Signal Editor"
         Output Arguments
         tc — Test case
         sltest.testmanager.testcase object
         Examples
         Create Test for a Subsystem
         Create a baseline test case and test harness for a subsystem, then save the inputs in Excel format.
         % Load the model
         load_system('rtwdemo_sil_block');
         Compatibility Considerations
         sltest.testmanager.TestSuite.createTestForSubsystem Will Be Removed
         Not recommended starting in R2020b
         • TestFile — Required name-value pair to specify the test file for the created test case
         • Component — Required name-value pair to specify the component or model to test
         • CreateTestFile — Optional name-value pair for whether to create a new test file
         • CreateHarness — Optional name-value pair for whether to create a test harness in addition to
           the test case
         See Also
         sltest.testmanager.createTestForComponent
         Topics
         “Create and Run Test Cases with Scripts”
3-84
                                                             createTestForSubsystem
Introduced in R2016a
                                                                             3-85
3   Methods
         createTestSuite
         Class: sltest.testmanager.TestFile
         Package: sltest.testmanager
         Syntax
         ts = createTestSuite(tf,suiteName)
         Description
         ts = createTestSuite(tf,suiteName) creates a test suite and adds it to the test file.
         Input Arguments
         tf — Test file
         sltest.testmanager.TestFile object
         Test file that you want to create the test suite within, specified as a
         sltest.testmanager.TestFile object.
         Output Arguments
         ts — Test suite object
         object
Examples
3-86
                                            createTestSuite
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                     3-87
3   Methods
         createTestSuite
         Class: sltest.testmanager.TestSuite
         Package: sltest.testmanager
         Syntax
         tsOut = createTestSuite(ts,suiteName)
         Description
         tsOut = createTestSuite(ts,suiteName) creates a new test suite.
         Input Arguments
         ts — Test suite
         sltest.testmanager.TestSuite object
         Test suite that want to add another test suite to, specified as an sltest.testmanager.TestSuite
         object.
         Test suite name, specified as a character vector. If this input argument is empty, then the Test
         Manager gives the test suite a unique name.
         Output Arguments
         tsOut — Test suite
         sltest.testmanager.TestSuite object
Examples
3-88
                                               createTestSuite
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                        3-89
3   Methods
         deleteIterations
         Class: sltest.testmanager.TestCase
         Package: sltest.testmanager
         Syntax
         deleteIterations(tc,iter)
         Description
         deleteIterations(tc,iter) deletes one or more test iterations from the test case.
         Input Arguments
         tc — Test case to delete iteration from
         sltest.testmanager.TestCase object
         Test case that you want to delete the iteration from, specified as a sltest.testmanager.TestCase
         object.
         Test iterations that you want to delete from the test case, specified as an array of
         sltest.testmanager.TestIteration objects.
Examples
3-90
                                                          deleteIterations
testItr2 = sltestiteration;
% Set iteration settings
setTestParam(testItr2,'SignalBuilderGroup','Coasting');
% Add the iteration to test case
addIteration(tc,testItr2);
See Also
sltest.testmanager.TestIteration
Topics
“Test Iterations”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                    3-91
3   Methods
         genBaselineInfoTable
         Class: sltest.testmanager.TestResultReport
         Package: sltest.testmanager
         Syntax
         baselineTable = genBaselineInfoTable(obj,result)
         Description
         baselineTable = genBaselineInfoTable(obj,result) generates a section for the baseline
         dataset information used in the test case.
         Input Arguments
         obj — Test report object
         sltest.testmanager.TestResultReport object
         Output Arguments
         baselineTable — Table
         mlreportgen.dom.FormalTable object
3-92
                                                                              genBaselineInfoTable
The test case baseline dataset table generated by the method, returned as a
mlreportgen.dom.FormalTable object.
See Also
mlreportgen.dom.FormalTable | sltest.testmanager.TestResultReport
Topics
“Export Test Results”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                                            3-93
3   Methods
         genCoverageTable
         Class: sltest.testmanager.TestResultReport
         Package: sltest.testmanager
         Syntax
         groupObj = genCoverageTable(obj,resultObj)
         Description
         groupObj = genCoverageTable(obj,resultObj) generates a section for coverage that was
         collected during the test.
         Input Arguments
         obj — Test report object
         sltest.testmanager.TestResultReport object
         Output Arguments
         groupObj — Group object
         mlreportgen.dom.Group object
         See Also
         mlreportgen.dom.Group | sltest.testmanager.TestResultReport
         Topics
         “Export Test Results”
         “Create and Run Test Cases with Scripts”
3-94
                       genCoverageTable
Introduced in R2016a
                                  3-95
3   Methods
         genHyperLinkToToC
         Class: sltest.testmanager.TestResultReport
         Package: sltest.testmanager
         Syntax
         para = genHyperLinkToToC(obj,indent)
         Description
         para = genHyperLinkToToC(obj,indent) generates link to the report table of contents.
         Input Arguments
         obj — Test report
         sltest.testmanager.TestResultReport object
         Space between the left outer boundary of this paragraph and the left inner boundary of the link,
         specified as a character vector.
         The character vector has the format valueUnits, where Units is an abbreviation for the units in
         which the indentation is expressed. Use one of these abbreviations for the units for indentation.
         • no abbreviation — pixels
         • cm — centimeters
         • in — inches
         • mm — millimeters
         • pi — picas
         • pt — points
         • px — pixels
Example: '5mm'
3-96
                                                                             genHyperLinkToToC
Output Arguments
para — Paragraph
mlreportgen.dom.Paragraph object
See Also
mlreportgen.dom.Paragraph | sltest.testmanager.TestResultReport
Topics
“Export Test Results”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                                         3-97
3   Methods
         genIterationSettingTable
         Class: sltest.testmanager.TestResultReport
         Package: sltest.testmanager
         Syntax
         groupObj = genIterationSettingTable(obj,result)
         Description
         groupObj = genIterationSettingTable(obj,result) generates a section for the iteration
         settings used to override the parent test case settings.
         Input Arguments
         obj — Test report object
         sltest.testmanager.TestResultReport object
         Output Arguments
         groupObj — Group object
         mlreportgen.dom.Group object
         See Also
         mlreportgen.dom.Group | sltest.testmanager.TestResultReport
         Topics
         “Export Test Results”
         “Create and Run Test Cases with Scripts”
3-98
                       genIterationSettingTable
Introduced in R2016a
                                         3-99
3   Methods
         genMetadataBlockForTestResult
         Class: sltest.testmanager.TestResultReport
         Package: sltest.testmanager
         Syntax
         groupObj = genMetadataBlockForTestResult(obj,result,isTestSuiteResult)
         Description
         groupObj = genMetadataBlockForTestResult(obj,result,isTestSuiteResult)
         generates a result metadata section for a test suite or test case result.
         • sgenTableRowsForResultMetaInfo
         • genRequirementLinksTable
         • genTableRowsForResultMetaInfo
         • genRequirementLinksTable
         • genIterationSettingTable
         Input Arguments
         obj — Test report object
         sltest.testmanager.TestResultReport object
         Flag to indicate whether the test result metadata block is for a test suite result or not, specified as a
         Boolean, true or false.
         Output Arguments
         groupObj — Group object
         mlreportgen.dom.Group object
3-100
                                                                     genMetadataBlockForTestResult
The result set section generated by the method, returned as an mlreportgen.dom.Group object.
See Also
mlreportgen.dom.Group | sltest.testmanager.TestResultReport
Topics
“Export Test Results”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                                           3-101
3   Methods
         genParameterOverridesTable
         Class: sltest.testmanager.TestResultReport
         Package: sltest.testmanager
         Syntax
         overridesTable = genParameterOverridesTable(obj,result,simIndex)
         Description
         overridesTable = genParameterOverridesTable(obj,result,simIndex) generates a
         section for parameter overrides used in the test case.
         Input Arguments
         obj — Test report object
         sltest.testmanager.TestResultReport object
         Simulation number that the test case parameter overrides table applies to, specified as an integer, 1
         or 2. This setting applies to the simulation test case.
3-102
                                                                          genParameterOverridesTable
Output Arguments
overridesTable — Table
mlreportgen.dom.FormalTable object
The test case parameter overrides table generated by the method, returned as a
mlreportgen.dom.FormalTable object.
See Also
mlreportgen.dom.FormalTable | sltest.testmanager.TestResultReport
Topics
“Export Test Results”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                                             3-103
3   Methods
         genRequirementLinksTable
         Class: sltest.testmanager.TestResultReport
         Package: sltest.testmanager
         Syntax
         reqTable = genRequirementLinksTable(obj,resultObj,isTestSuiteResult)
         Description
         reqTable = genRequirementLinksTable(obj,resultObj,isTestSuiteResult) generates a
         section for table of requirement links.
         Input Arguments
         obj — Test report object
         sltest.testmanager.TestResultReport object
         Flag to indicate whether the requirement links table is for a test suite result or not, specified as a
         Boolean, true or false.
         Output Arguments
         reqTable — Table
         mlreportgen.dom.FormalTable object
         See Also
         mlreportgen.dom.FormalTable | sltest.testmanager.TestResultReport
3-104
                                           genRequirementLinksTable
Topics
“Export Test Results”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                            3-105
3   Methods
         genResultSetBlock
         Class: sltest.testmanager.TestResultReport
         Package: sltest.testmanager
         Syntax
         groupObj = genResultSetBlock(obj,result)
         Description
         groupObj = genResultSetBlock(obj,result) generates the results set section.
         • genTableRowsForResultMetaInfo
         • genCoverageTable
         • genHyperLinkToToC
         Input Arguments
         obj — Test report object
         sltest.testmanager.TestResultReport object
3-106
                                                                               genResultSetBlock
Output Arguments
groupObj — Group object
mlreportgen.dom.Group object
The result set section generated by the method, returned as an mlreportgen.dom.Group object.
See Also
mlreportgen.dom.Group | sltest.testmanager.TestResultReport
Topics
“Export Test Results”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                                         3-107
3   Methods
         genRunBlockForTestCaseResult
         Class: sltest.testmanager.TestResultReport
         Package: sltest.testmanager
         Syntax
         groupObj = genRunBlockForTestCaseResult(obj,run,runType,result,simIndex)
         Description
         groupObj = genRunBlockForTestCaseResult(obj,run,runType,result,simIndex)
         generates a combined section for baseline data, simulation configuration, parameter overrides,
         simulation output, criteria comparison, and verify run data.
         • genBaselineInfoTable
         • genSimulationConfigurationTable
         • genParameterOverridesTable
         • genSignalSummaryTable
         • plotOneSignalToFile
         • genHyperLinkToToC
         Input Arguments
         obj — Test report object
         sltest.testmanager.TestResultReport object
         result — Result
         sltest.testmanager.ReportUtility.ReportResultData object
3-108
                                                                             genRunBlockForTestCaseResult
Simulation number that the result applies to, specified as an integer, 1 or 2. This setting applies to
the simulation test case.
Output Arguments
groupObj — Group object
mlreportgen.dom.Group object
The result set section generated by the method, returned as an mlreportgen.dom.Group object.
See Also
Simulink.sdi.Run | mlreportgen.dom.Group | sltest.testmanager.TestResultReport
Topics
“Export Test Results”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                                                   3-109
3   Methods
         genSignalSummaryTable
         Class: sltest.testmanager.TestResultReport
         Package: sltest.testmanager
         Syntax
         groupObj = genSignalSummaryTable(obj,signalList,isComparison,isSummaryTable)
         Description
         groupObj = genSignalSummaryTable(obj,signalList,isComparison,isSummaryTable)
         generates a section for signal output and comparison data.
         Input Arguments
         obj — Test report object
         sltest.testmanager.TestResultReport object
         Flag to indicate whether the signal is from a comparison run or not, specified as a Boolean, true or
         false.
         Flag to indicate whether this is for a signal summary table in the report or an individual signal plot,
         specified as a Boolean. true for the signal summary table or false for an individual signal plot.
3-110
                                                                        genSignalSummaryTable
Output Arguments
groupObj — Group object
mlreportgen.dom.Group object
See Also
mlreportgen.dom.Group | sltest.testmanager.TestResultReport
Topics
“Export Test Results”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                                      3-111
3   Methods
         genSimulationConfigurationTable
         Class: sltest.testmanager.TestResultReport
         Package: sltest.testmanager
         Syntax
         simCfgTable = genSimulationConfigurationTable(obj,result,simIndex)
         Description
         simCfgTable = genSimulationConfigurationTable(obj,result,simIndex) generates a
         section for simulation configuration data used in the test case.
         Input Arguments
         obj — Test report object
         sltest.testmanager.TestResultReport object
         Simulation number that the test case configuration table applies to, specified as an integer, 1 or 2.
         This setting applies to the simulation test case.
3-112
                                                                       genSimulationConfigurationTable
Output Arguments
simCfgTable — Table
mlreportgen.dom.FormalTable object
The test case simulation configuration table generated by the method, returned as a
mlreportgen.dom.FormalTable object.
See Also
mlreportgen.dom.FormalTable | sltest.testmanager.TestResultReport
Topics
“Export Test Results”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                                               3-113
3   Methods
         genTableRowsForResultMetaInfo
         Class: sltest.testmanager.TestResultReport
         Package: sltest.testmanager
         Syntax
         rowList = genTableRowsForResultMetaInfo(obj,result)
         Description
         rowList = genTableRowsForResultMetaInfo(obj,result) generates a section for test result
         metadata used in a result set, test file, test suite, test case, or test iteration.
         Input Arguments
         obj — Test report object
         sltest.testmanager.TestResultReport object
         Output Arguments
         rowList — Table row
         mlreportgen.dom.TableRow object
         See Also
         mlreportgen.dom.TableRow | sltest.testmanager.TestResultReport
3-114
                                           genTableRowsForResultMetaInfo
Topics
“Export Test Results”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                 3-115
3   Methods
         genTestCaseResultBlock
         Class: sltest.testmanager.TestResultReport
         Package: sltest.testmanager
         Syntax
         groupObj = genTestCaseResultBlock(obj,result)
         Description
         groupObj = genTestCaseResultBlock(obj,result) generates a test case result section.
         • genMetadataBlockForTestResult
         • genCoverageTable
         • genHyperLinkToToC
         Input Arguments
         obj — Test report object
         sltest.testmanager.TestResultReport object
         Output Arguments
         groupObj — Group object
         mlreportgen.dom.Group object
The result set section generated by the method, returned as a mlreportgen.dom.Group object.
         See Also
         mlreportgen.dom.Group | sltest.testmanager.TestResultReport
         Topics
         “Export Test Results”
         “Create and Run Test Cases with Scripts”
Introduced in R2016a
3-116
                                                                          genTestSuiteResultBlock
genTestSuiteResultBlock
Class: sltest.testmanager.TestResultReport
Package: sltest.testmanager
Syntax
groupObj = genTestSuiteResultBlock(obj,result)
Description
groupObj = genTestSuiteResultBlock(obj,result) generates a test suite result section.
• genMetadataBlockForTestResult
• genCoverageTable
• genHyperLinkToToC
Input Arguments
obj — Test report object
sltest.testmanager.TestResultReport object
                                                                                          3-117
3   Methods
         Output Arguments
         groupObj — Group
         mlreportgen.dom.Group object
The result set section generated by the method, returned as a mlreportgen.dom.Group object.
         See Also
         mlreportgen.dom.Group | sltest.testmanager.TestResultReport
         Topics
         “Export Test Results”
         “Create and Run Test Cases with Scripts”
Introduced in R2016a
3-118
                                                                                 getBaselineCriteria
getBaselineCriteria
Class: sltest.testmanager.TestCase
Package: sltest.testmanager
Syntax
baselines = getBaselineCriteria(tc)
Description
baselines = getBaselineCriteria(tc) gets the baseline criteria sets in a test case and
returns them as an array of baseline criteria objects, sltest.testmanager.BaselineCriteria.
Input Arguments
tc — Baseline test case
sltest.testmanager.TestCase object
Baseline test case that you want to get baseline criteria from, specified as a
sltest.testmanager.TestCase object.
Output Arguments
baselines — Baseline criteria object
sltest.testmanager.BaselineCriteria object array
Baseline criteria that are in the baseline test case, returned as an array of
sltest.testmanager.BaselineCriteria objects.
Examples
                                                                                            3-119
3   Methods
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015b
3-120
                                                                                            getBaselineRun
getBaselineRun
Class: sltest.testmanager.TestCaseResult
Package: sltest.testmanager
Syntax
baseline = getBaselineRun(result)
Description
baseline = getBaselineRun(result) gets the baseline dataset used in a test case, which
belongs to the test case results object. The baseline dataset is saved with the test case result only if
the Save baseline data in test result check box is selected in the test case under the Baseline
Criteria section.
To record the baseline data in the test case result, you must set the
SaveBaselineRunInTestResult test case property to true:
setProperty(testcase,'SaveBaselineRunInTestResult',true);
Input Arguments
result — Test case result
sltest.testmanager.TestCaseResult object
Output Arguments
baseline — Baseline dataset
Simulink.sdi.Run object
Test case baseline dataset, returned as a Simulink.sdi.Run object. If the Save baseline data in
test result check box is not selected in the test case, then the function returns an empty array.
Examples
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('API Test File');
ts = createTestSuite(tf,'API Test Suite');
tc = createTestCase(ts,'baseline','Baseline API Test Case');
                                                                                                    3-121
3   Methods
         % Run the test case and return an object with results data
         resultsObj = run(tc);
         See Also
         Simulink.sdi.Run
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2016a
3-122
                                                                                          getTestCase
getTestCase
Class: sltest.testmanager.TestCaseResult
Package: sltest.testmanager
Syntax
tc = getTestCase(tcresult)
Description
tc = getTestCase(tcresult) returns the test case that produced the test case results, tc.
Input Arguments
tcresult — Test case result
sltest.testmanager.TestCaseResult object
Output Arguments
tc — Test case
sltest.testmanager.TestCase object
Test case that produced the test case results, returned as an sltest.testmanager.TestCase
object.
Examples
This example shows how to create a test file, test suite, and simulation test case programmatically.
The test case runs on the sldemo_autotrans model and uses getTestCase to obtain the test case
that produced the test results.
sltest.testmanager.clear;
Remove default test suite so that only the created test suite is used.
                                                                                               3-123
3   Methods
         tsDel = tf.getTestSuites();
         remove(tsDel(1));
Assign the system under test to the test case. Run the test.
         setProperty(tc,'Model','sldemo_autotrans');
         tcresult = run(tc);
tcresultobj = getTestCaseResults(tc);
tcobj = getTestCase(tcresultobj);
         See Also
         getTestCaseResults
Introduced in R2019b
3-124
                                                                                           getBaselineRun
getBaselineRun
Class: sltest.testmanager.TestIterationResult
Package: sltest.testmanager
Syntax
baseline = getBaselineRun(resultObj)
Description
baseline = getBaselineRun(resultObj) gets the baseline dataset used in a test iteration,
which belongs to the test iteration results object. The baseline dataset is saved with the test iteration
result only if the Save baseline data in test result check box is selected in the parent test case
under the Baseline Criteria section.
Input Arguments
resultObj — Test iteration result
object
Output Arguments
baseline — Baseline dataset
object
Test iteration baseline dataset, returned as a Simulink.sdi.Run object. If the Save baseline data
in test result check box is not selected in the parent test case, then the function returns an empty
array.
See Also
Simulink.sdi.Run
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                                                   3-125
3   Methods
         getCleanupPlots
         Class: sltest.testmanager.TestFileResult
         Package: sltest.testmanager
         Syntax
         figs = getCleanupPlots(result)
         Description
         figs = getCleanupPlots(result) returns figure handles of plots generated from the cleanup
         callbacks of the test file associated with the results. Figures returned using this method are not
         visible. To see the plots, set the figure handle Visible property to 'on'.
         Input Arguments
         result — Test file results
         sltest.testmanager.TestFileResult object
         Test file results to get cleanup plot figure handles from, specified as a
         sltest.testmanager.TestFileResult object.
         Output Arguments
         figs — Figures from test file cleanup callbacks
         array of figure handles
Figures from test file cleanup callbacks, returned as an array of figure handles.
Examples
3-126
                                                                      getCleanupPlots
opt.SaveFigures = true;
See Also
setProperty | sltest.testmanager.Options | sltest.testmanager.TestFile |
sltest.testmanager.TestFileResult
Topics
“Create, Store, and Open MATLAB Figures”
“Export Test Results”
Introduced in R2017a
                                                                              3-127
3   Methods
         getCleanupPlots
         Class: sltest.testmanager.TestSuiteResult
         Package: sltest.testmanager
         Syntax
         figs = getCleanupPlots(result)
         Description
         figs = getCleanupPlots(result) returns figure handles of plots from the cleanup callbacks of
         the test suite associated with the results. Figures returned using this method are not visible. To see
         the plots, set the figure handle Visible property to 'on'.
         Input Arguments
         result — Test suite results
         sltest.testmanager.TestSuiteResult object
         Test suite results to get cleanup plot figure handles from, specified as an
         sltest.testmanager.TestSuiteResult object.
         Output Arguments
         figs — Figures from test suite cleanup callbacks
         array of figure handles
Figures from test suite cleanup callbacks, returned as an array of figure handles.
Examples
3-128
                                                                    getCleanupPlots
opt.SaveFigures = true;
See Also
setProperty (Test Suite) | sltest.testmanager.Options |
sltest.testmanager.TestSuite | sltest.testmanager.TestSuiteResult
Topics
“Create, Store, and Open MATLAB Figures”
“Export Test Results”
Introduced in R2017a
                                                                            3-129
3   Methods
         getComparisonResult
         Class: sltest.testmanager.TestCaseResult
         Package: sltest.testmanager
         Syntax
         cr = getComparisonResult(tcr)
         Description
         cr = getComparisonResult(tcr) returns baseline or equivalence data comparison results cr
         from the sltest.testmanager.TestCaseResult object tcr.
         Input Arguments
         tcr — Test case result
         sltest.testmanager.TestCaseResult object
         Test case result to get baseline or equivalence data results from, specified as a
         sltest.testmanager.TestCaseResult object.
         Output Arguments
         cr — Data comparison result
         sltest.testmanager.ComparisonRunResult object
         Examples
         Get Comparison Results of a Baseline Test
         This example shows how to programmatically get the comparison results of the second iteration of a
         baseline test case.
         1. Get the path to the test file, then run the test file.
         extf = 'sltestTestCaseRealTimeReuseExample.mldatx';
         tf = sltest.testmanager.TestFile(extf);
         ro = run(tf);
3-130
                                                         getComparisonResult
cr2 = getComparisonResult(tir(2))
cr2sig = getComparisonSignalResults(cr2)
sltest.testmanager.clearResults;
sltest.testmanager.clear;
sltest.testmanager.close;
See Also
Introduced in R2017b
                                                                     3-131
3   Methods
         getComparisonResult
         Class: sltest.testmanager.TestIterationResult
         Package: sltest.testmanager
         Syntax
         cr = getComparisonResult(tir)
         Description
         cr = getComparisonResult(tir) returns baseline or equivalence data comparison results cr
         from the sltest.testmanager.TestIterationResult object tir.
         Input Arguments
         tir — Test iteration result
         sltest.testmanager.TestIterationResult object
         Test iteration result to get baseline or equivalence data results from, specified as an
         sltest.testmanager.TestIterationResult object.
         Output Arguments
         cr — Data comparison result
         sltest.testmanager.TestIterationResult object | object
         Examples
         Get Comparison Results of a Baseline Test
         This example shows how to programmatically get the comparison results of the second iteration of a
         baseline test case.
         1. Get the path to the test file, then run the test file.
         extf = 'sltestTestCaseRealTimeReuseExample.mldatx';
         tf = sltest.testmanager.TestFile(extf);
         ro = run(tf);
3-132
                                                         getComparisonResult
cr2 = getComparisonResult(tir(2))
cr2sig = getComparisonSignalResults(cr2)
sltest.testmanager.clearResults;
sltest.testmanager.clear;
sltest.testmanager.close;
See Also
sltest.testmanager.ComparisonRunResult
Introduced in R2017b
                                                                     3-133
3   Methods
         getTestIteration
         Class: sltest.testmanager.TestIterationResult
         Package: sltest.testmanager
         Syntax
         ti = getTestIteration(ti_result)
         Description
         ti = getTestIteration(ti_result) returns the test iteration that produced the test iteration
         results, ti_result.
         Input Arguments
         ti_result — Test iteration result
         sltest.testmanager.TestIterationResult object
         Output Arguments
         ti — Test iteration
         sltest.testmanager.TestIteration object
         See Also
         getIterationResults
Introduced in R2019b
3-134
                                                                                 getComparisonRun
getComparisonRun
Class: sltest.testmanager.TestCaseResult
Package: sltest.testmanager
Syntax
run = getComparisonRun(result)
Description
run = getComparisonRun(result) gets the test case comparison results that belong to the test
case results object. The results are output to a Simulink.sdi.Run object, which contains signal
data for each comparison, tolerance, and difference result.
Input Arguments
result — Test case result
sltest.testmanager.TestCaseResult object
Output Arguments
run — Comparison results
Simulink.sdi.Run object
Examples
                                                                                           3-135
3   Methods
         % Run the test case and return an object with results data
         resultsObj = run(tc);
         See Also
         Simulink.sdi.Run
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015a
3-136
                                                                                   getComparisonRun
getComparisonRun
Class: sltest.testmanager.TestIterationResult
Package: sltest.testmanager
Syntax
run = getComparisonRun(result)
Description
run = getComparisonRun(result) gets the test iteration comparison results that belong to the
test iteration results object. The results are output to a Simulink.sdi.Run object, which contains
signal data for each comparison, tolerance, and difference result.
Input Arguments
result — Test iteration result
sltest.testmanager.TestIterationResult object
Output Arguments
run — Comparison results
Simulink.sdi.Run object
See Also
sltest.testmanager.TestIterationResult
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                                              3-137
3   Methods
         getComparisonSignalResults
         Class: sltest.testmanager.ComparisonRunResult
         Package: sltest.testmanager
         Syntax
         csr = getComparisonSignalResults(cr)
         Description
         csr = getComparisonSignalResults(cr) returns baseline or equivalence signal comparison
         results csr as a sltest.testmanager.ComparisonSignalResult object from the
         sltest.testmanager.ComparisonRunResult object cr.
         Input Arguments
         cr — Overall data comparison result
         sltest.testmanager.ComparisonRunResult object
         Output Arguments
         csr — Signal data comparison result
         sltest.testmanager.ComparisonSignalResult object
         Examples
         Get Comparison Results of a Baseline Test
         This example shows how to programmatically get the comparison results of the second iteration of a
         baseline test case.
         1. Get the path to the test file, then run the test file.
         extf = 'sltestTestCaseRealTimeReuseExample.mldatx';
         tf = sltest.testmanager.TestFile(extf);
         ro = run(tf);
3-138
                                                         getComparisonSignalResults
tcr = getTestCaseResults(tsr);
tir = getIterationResults(tcr);
cr2 = getComparisonResult(tir(2))
cr2sig = getComparisonSignalResults(cr2)
sltest.testmanager.clearResults;
sltest.testmanager.clear;
sltest.testmanager.close;
See Also
Introduced in R2017b
                                                                            3-139
3   Methods
         getCoverageResults
         Class: sltest.testmanager.ResultSet
         Package: sltest.testmanager
         Syntax
         covResult = getCoverageResults(result)
         covResult = getCoverageResults(result,model)
         Description
         covResult = getCoverageResults(result) gets the coverage results that belong to the result
         set object.
         Input Arguments
         result — Result set
         sltest.testmanager.ResultSet object
Name of a model within the set of coverage results, specified as a character vector.
         Output Arguments
         covResult — Coverage results
         object array
         Coverage results contained in the result set, returned as an array of cvdata objects. For more
         information on cvdata objects, see cv.cvdatagroup (Simulink Coverage).
Examples
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('API Test File');
         ts = createTestSuite(tf,'API Test Suite');
         tc = createTestCase(ts,'simulation','Coverage Test Case');
3-140
                                                             getCoverageResults
% Run the test case and return an object with results data
ro = run(tf);
See Also
sltest.testmanager.CoverageSettings
Topics
“Create and Run Test Cases with Scripts”
“Collect Coverage in Tests”
Introduced in R2016a
                                                                        3-141
3   Methods
         remove
         Class: sltest.testmanager.ResultSet
         Package: sltest.testmanager
         Syntax
         remove(result)
         Description
         remove(result) removes result, a sltest.testmanager.ResultSet object. If the Test
         Manager is visible, the corresponding results are removed from the Results and Artifacts pane.
         Input Arguments
         result — Results set
         sltest.testmanager.ResultSet object
Results set to get test file results from, specified as a sltest.testmanager.ResultSet object.
Examples
This example shows how to run a test and remove the result.
tf = sltest.testmanager.TestFile('f14ParameterSweepTest.mldatx');
result = run(tf)
         result =
           ResultSet with properties:
3-142
                                                                     remove
remove(result)
See Also
sltest.testmanager.ResultSet | sltest.testmanager.TestCaseResult |
sltest.testmanager.TestSuiteResult
Introduced in R2019a
                                                                     3-143
3   Methods
         getCoverageResults
         Class: sltest.testmanager.TestCaseResult
         Package: sltest.testmanager
         Syntax
         covResult = getCoverageResults(result)
         covResult = getCoverageResults(result,model)
         Description
         covResult = getCoverageResults(result) gets the coverage results that belong to the test
         case results object.
         Input Arguments
         result — Test case result
         sltest.testmanager.TestCaseResult object
Name of a model within the set of coverage results, specified as a character vector.
         Output Arguments
         covResult — Coverage results
         object array
         Coverage results contained in the test case result, returned as an array of cvdata objects. For more
         information on cvdata objects, see cv.cvdatagroup (Simulink Coverage).
Examples
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('API Test File');
         ts = createTestSuite(tf,'API Test Suite');
         tc = createTestCase(ts,'simulation','Coverage Test Case');
3-144
                                                             getCoverageResults
% Run the test case and return an object with results data
rs = run(tf);
See Also
sltest.testmanager.CoverageSettings
Topics
“Create and Run Test Cases with Scripts”
“Collect Coverage in Tests”
Introduced in R2016a
                                                                        3-145
3   Methods
         getCoverageResults
         Class: sltest.testmanager.TestFileResult
         Package: sltest.testmanager
         Syntax
         covResult = getCoverageResults(result)
         covResult = getCoverageResults(result,model)
         Description
         covResult = getCoverageResults(result) gets the coverage results that belong to the test
         file results object.
         Input Arguments
         result — Test file result
         sltest.testmanager.ResultSet object
Name of a model within the set of coverage results, specified as a character vector.
         Output Arguments
         covResult — Coverage results
         object array
         Coverage results contained in the test file result, returned as an array of cvdata objects. For more
         information on cvdata objects, see cv.cvdatagroup (Simulink Coverage).
Examples
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('API Test File');
         ts = createTestSuite(tf,'API Test Suite');
         tc = createTestCase(ts,'simulation','Coverage Test Case');
3-146
                                                             getCoverageResults
% Run the test case and return an object with results data
rs = run(tf);
See Also
sltest.testmanager.CoverageSettings
Topics
“Create and Run Test Cases with Scripts”
“Collect Coverage in Tests”
Introduced in R2016a
                                                                        3-147
3   Methods
         getCoverageResults
         Class: sltest.testmanager.TestIterationResult
         Package: sltest.testmanager
         Syntax
         covResult = getCoverageResults(resultObj)
         covResult = getCoverageResults(resultObj,model)
         Description
         covResult = getCoverageResults(resultObj) gets the coverage results that belong to the
         test iteration results object.
         Input Arguments
         resultObj — Test iteration result
         sltest.testmanager.TestIterationResult object
         Name of a model within the set of coverage results, specified as a character vector.
         Example: 'sldemo_absbrake'
         Output Arguments
         covResult — Coverage results
         object array
         Coverage results contained in the test iteration result, returned as an array of cvdata objects. For
         more information on cvdata objects, see cv.cvdatagroup (Simulink Coverage).
         See Also
         sltest.testmanager.CoverageSettings
         Topics
         “Create and Run Test Cases with Scripts”
         “Collect Coverage in Tests”
3-148
                       getCoverageResults
Introduced in R2016a
                                  3-149
3   Methods
         getCoverageResults
         Class: sltest.testmanager.TestSuiteResult
         Package: sltest.testmanager
         Syntax
         covResult = getCoverageResults(result)
         covResult = getCoverageResults(result,model)
         Description
         covResult = getCoverageResults(result) gets the coverage results that belong to the test
         suite results object.
         Input Arguments
         result — Test suite result
         sltest.testmanager.TestSuiteResult object
Name of a model within the set of coverage results, specified as a character vector.
         Output Arguments
         covResult — Coverage results
         object array
         Coverage results contained in the test suite result, returned as an array of cvdata objects. For more
         information on cvdata objects, see cv.cvdatagroup (Simulink Coverage).
Examples
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('API Test File');
         ts = createTestSuite(tf,'API Test Suite');
         tc = createTestCase(ts,'simulation','Coverage Test Case');
3-150
                                                             getCoverageResults
% Run the test case and return an object with results data
rs = run(tf);
See Also
sltest.testmanager.CoverageSettings
Topics
“Create and Run Test Cases with Scripts”
“Collect Coverage in Tests”
Introduced in R2016a
                                                                        3-151
3   Methods
         getCoverageSettings
         Class: sltest.testmanager.TestCase
         Package: sltest.testmanager
         Syntax
         covSettings = getCoverageSettings(tc)
         Description
         covSettings = getCoverageSettings(tc) gets the coverage settings for a test case and
         returns an sltest.testmanager.CoverageSettings object.
         Input Arguments
         tc — Test case
         sltest.testmanager.TestCase object
         Output Arguments
         covSettings — Coverage settings
         sltest.testmanager.CoverageSettings object
Examples
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('API Test File');
         ts = createTestSuite(tf,'API Test Suite');
         tc = createTestCase(ts,'simulation','Coverage Test Case');
3-152
                                                                getCoverageSettings
See Also
sltest.plugins.coverage.CoverageMetrics | sltest.testmanager.CoverageSettings
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                            3-153
3   Methods
         getCoverageSettings
         Class: sltest.testmanager.TestFile
         Package: sltest.testmanager
         Syntax
         covSettings = getCoverageSettings(tf)
         Description
         covSettings = getCoverageSettings(tf) gets the coverage settings for a test file and returns
         an sltest.testmanager.CoverageSettings object.
         Input Arguments
         tf — Test file
         sltest.testmanager.TestFile object
         Output Arguments
         covSettings — Coverage settings
         object
Examples
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('API Test File');
         ts = createTestSuite(tf,'API Test Suite');
         tc = createTestCase(ts,'simulation','Coverage Test Case');
3-154
                                                                getCoverageSettings
cov = getCoverageSettings(tf);
cov.RecordCoverage = true;
See Also
sltest.plugins.coverage.CoverageMetrics | sltest.testmanager.CoverageSettings
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                            3-155
3   Methods
         getCoverageSettings
         Class: sltest.testmanager.TestSuite
         Package: sltest.testmanager
         Syntax
         covSettings = getCoverageSettings(ts)
         Description
         covSettings = getCoverageSettings(ts) gets coverage settings for a test suite and returns
         an sltest.testmanager.CoverageSettings object.
         Input Arguments
         ts — Test suite
         sltest.testmanager.TestSuite object
         Output Arguments
         covSettings — Coverage settings
         object
Examples
3-156
                                                                getCoverageSettings
cov.RecordCoverage = true;
See Also
sltest.plugins.coverage.CoverageMetrics | sltest.testmanager.CoverageSettings
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                            3-157
3   Methods
         getCustomCriteria
         Class: sltest.testmanager.TestCase
         Package: sltest.testmanager
         Syntax
         customCriteria = getCustomCriteria(tc)
         Description
         customCriteria = getCustomCriteria(tc) creates the custom criteria object
         customCriteria from the test case tc.
         Input Arguments
         tc — Test case
         sltest.testmanager.TestCase object
Test case to get the custom criteria from, specified as a sltest.testmanager.TestCase object.
         Output Arguments
         customCriteria — Test case custom criteria
         sltest.testmanager.CustomCriteria object
Examples
         See Also
         sltest.testmanager.TestIteration
         Topics
         “Process Test Results with Custom Scripts”
         “Custom Criteria Programmatic Interface Example”
         “Create and Run Test Cases with Scripts”
3-158
                       getCustomCriteria
Introduced in R2016b
                                 3-159
3   Methods
         getCustomCriteriaPlots
         Class: sltest.testmanager.TestCaseResult
         Package: sltest.testmanager
         Syntax
         figs = getCustomCriteriaPlots(result)
         Description
         figs = getCustomCriteriaPlots(result) returns figure handles of plots generated from the
         custom criteria of the test case associated with the results. Figures returned using this method are
         not visible. To see the plots, set the figure handle Visible property to 'on'.
         Input Arguments
         result — Test case result
         sltest.testmanager.TestCaseResult object
         Test case result to get custom criteria figure handles from, specified as a
         sltest.testmanager.TestCaseResult object.
         Output Arguments
         figs — Figures from test case custom criteria
         array of figure handles
Figures from test case custom criteria, returned as an array of figure handles.
Examples
3-160
                                                                   getCustomCriteriaPlots
See Also
sltest.testmanager.CustomCriteria | sltest.testmanager.Options |
sltest.testmanager.TestCaseResult
Topics
“Create, Store, and Open MATLAB Figures”
“Export Test Results”
Introduced in R2017a
                                                                                  3-161
3   Methods
         getCustomCriteriaPlots
         Class: sltest.testmanager.TestIterationResult
         Package: sltest.testmanager
         Syntax
         figs = getCustomCriteriaPlots(result)
         Description
         figs = getCustomCriteriaPlots(result) returns figure handles of plots from the custom
         criteria of the test case associated with the iteration results. Figures returned using this method are
         not visible. To see the plots, set the figure handle Visible property to 'on'.
         Input Arguments
         result — Test iteration result
         sltest.testmanager.TestIterationResult object
         Output Arguments
         figs — Figures from test case custom criteria
         array of figure handles
         Figures from test case custom criteria for the specified iteration, returned as an array of figure
         handles.
Examples
3-162
                                                                     getCustomCriteriaPlots
tcCriteria = getCustomCriteria(tc);
tcCriteria.Callback = 'a = [1,2,3];
f= figure; plot(a);';
tcCriteria.Enabled = true;
% Specify iterations
vars = 32 : 0.5 : 34;
for k = 1 : length(vars)
% Get the custom criteria plot figure handles from first iteration
figs = tir(1).getCustomCriteriaPlots;
See Also
getIterationResults | sltest.testmanager.CustomCriteria |
sltest.testmanager.Options | sltest.testmanager.TestIterationResult
Topics
“Create, Store, and Open MATLAB Figures”
“Export Test Results”
Introduced in R2017a
                                                                                    3-163
3   Methods
         getCustomCriteriaResult
         Class: sltest.testmanager.TestCaseResult
         Package: sltest.testmanager
         Syntax
         ccResult = getCustomCriteriaResult(tcResult)
         Description
         ccResult = getCustomCriteriaResult(tcResult) creates the custom criteria result object
         ccResult from test case result tcResult.
         Input Arguments
         tcResult — Test case result
         sltest.testmanager.TestCaseResult object
Test case result to get the custom criteria result from, specified as a TestCaseResult object.
         Output Arguments
         ccResult — Custom criteria result
         sltest.testmanager.CustomCriteriaResult object
Custom criteria result of the test case result, returned as an CustomCriteriaResult object.
Examples
         Create a test case result object from the test case result set tcResultSet.
         tcResult = getTestCaseResults(tcResultSet);
         Get the custom criteria from the test case result tcResult.
         ccResult = getCustomCriteriaResult(tcResult);
         See Also
         sltest.testmanager.TestIteration
         Topics
         “Process Test Results with Custom Scripts”
         “Custom Criteria Programmatic Interface Example”
         “Create and Run Test Cases with Scripts”
3-164
                       getCustomCriteriaResult
Introduced in R2016b
                                       3-165
3   Methods
         getCustomCriteriaResult
         Class: sltest.testmanager.TestIterationResult
         Package: sltest.testmanager
         Syntax
         ccResult = getCustomCriteriaResult(tiResult)
         Description
         ccResult = getCustomCriteriaResult(tiResult) creates the custom criteria result object
         ccResult from test iteration result tiResult.
         Input Arguments
         tiResult — Test iteration result
         sltest.testmanager.TestIterationResult object
         Test iteration result to get the custom criteria result from, specified as a TestIterationResult
         object.
         Output Arguments
         ccResult — Custom criteria result
         sltest.testmanager.CustomCriteriaResult object
Custom criteria result of the test case result, returned as an CustomCriteriaResult object.
Examples
Create a test case result object from the test case result set tcResultSet.
tcResult = getTestCaseResults(tcResultSet);
Get the iteration result from the test case result tcResult.
iterResult = getIterationResults(tcResult);
Get the custom criteria from the test case result tcResult.
ccResult = getCustomCriteriaResult(iterResult);
         See Also
         sltest.testmanager.TestIteration
3-166
                                                   getCustomCriteriaResult
Topics
“Process Test Results with Custom Scripts”
“Custom Criteria Programmatic Interface Example”
“Create and Run Test Cases with Scripts”
Introduced in R2016b
                                                                   3-167
3   Methods
         getEquivalenceCriteria
         Class: sltest.testmanager.TestCase
         Package: sltest.testmanager
         Syntax
         eq = getEquivalenceCriteria(tc)
         Description
         eq = getEquivalenceCriteria(tc) gets the equivalence criteria set from the test case. The
         function returns an equivalence criteria object, sltest.testmanager.EquivalenceCriteria.
         This function can be used only if the test type is an equivalence test case.
         Input Arguments
         tc — Test case
         sltest.testmanager.TestCase object
         Output Arguments
         eq — Equivalence criteria
         sltest.testmanager.EquivalenceCriteria object
Examples
3-168
                                                          getEquivalenceCriteria
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                                         3-169
3   Methods
         getInputs
         Class: sltest.testmanager.TestCase
         Package: sltest.testmanager
         Syntax
         inputs = getInputs(tc)
         inputs = getInputs(tc,simulationIndex)
         Description
         inputs = getInputs(tc) gets the input sets in a test case and returns them as an array of test
         input objects, sltest.testmanager.TestInput.
         inputs = getInputs(tc,simulationIndex) gets the input sets in a test case and returns them
         as an array of test input objects, sltest.testmanager.TestInput. If the test case is an
         equivalence test case, then specify the simulation index.
         Input Arguments
         tc — Test case
         sltest.testmanager.TestCase object
         Simulation number that the parameter sets apply to, specified as 1 or 2. This setting applies to the
         simulation test case where there are two simulations. For baseline and simulation test cases, the
         default simulation index is 1.
         Output Arguments
         inputs — Test input
         sltest.testmanager.TestInput object array
         Test inputs that belong to the test case, returned as an array of sltest.testmanager.TestInput
         objects.
Examples
3-170
                                                                        getInputs
ans =
    Sheet: 'Acceleration'
    Range: ''
ans =
    Sheet: 'Braking'
    Range: ''
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                                          3-171
3   Methods
         getIterationResults
         Class: sltest.testmanager.TestCaseResult
         Package: sltest.testmanager
         Syntax
         iterArray = getIterationResults(result)
         Description
         iterArray = getIterationResults(result) returns the test iteration results that are children
         of the test case result.
         Input Arguments
         result — Test case result
         sltest.testmanager.TestCaseResult object
         Output Arguments
         iterArray — Iteration result
         sltest.testmanager.TestIterationResult object array
Examples
3-172
                                                          getIterationResults
See Also
sltest.testmanager.TestIterationResult
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                     3-173
3   Methods
         getIterations
         Class: sltest.testmanager.TestCase
         Package: sltest.testmanager
         Syntax
         iterArray = getIterations(tc)
         iterArray = getIterations(tc,iterName)
         Description
         iterArray = getIterations(tc) get one or more test iteration objects that belong to the test
         case.
         iterArray = getIterations(tc,iterName) get one or more test iteration objects with the
         specified name that belong to the test case.
         Input Arguments
         tc — Test case to get iteration from
         sltest.testmanager.TestCase object
         Test case that you want to get the iteration from, specified as a sltest.testmanager.TestCase
         object.
         Output Arguments
         iterArray — Test iterations
         sltest.testmanager.TestIteration object array
Examples
3-174
                                                                  getIterations
ts = getTestSuites(tf);
tc = createTestCase(ts,'simulation','Simulation Iterations');
% Get iterations
iters = getIterations(tc);
See Also
sltest.testmanager.TestIteration
Topics
“Test Iterations”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                       3-175
3   Methods
         getLoggedSignals
         Class: sltest.testmanager.LoggedSignalSet
         Package: sltest.testmanager
         Syntax
         objs = getLoggedSignals(lgset)
         Description
         objs = getLoggedSignals(lgset) returns a vector of the
         sltest.testmanager.LoggedSignal objects contained in an
         sltest.testmanager.LoggedSignalSet object.
         Input Arguments
         lgset — Logged signal set
         sltest.testmanager.LoggedSignalSet object
Examples
         % Open model
         sldemo_absbrake
         Select the Vehicle Speed block and enter gcb. Use the returned path to create a
         Simulink.BlockPath object.
         % Add signals to set
         bPath = Simulink.BlockPath('sldemo_absbrake/Vehicle speed');
         sig1 = mylgset.addLoggedSignal(bPath,1);
         sig2 = mylgset.addLoggedSignal(bPath,2);
setProperty(tc,'Model','sldemo_absbrake');
3-176
                                           getLoggedSignals
% Remove signal
remove(sig2);
See Also
gcb
Topics
“Create and Run Test Cases with Scripts”
“Capture Simulation Data in a Test Case”
Introduced in R2019a
                                                    3-177
3   Methods
         getLoggedSignalSets
         Class: sltest.testmanager.TestCase
         Package: sltest.testmanager
         Syntax
         objs = getLoggedSignalSets(tc)
         objs = getLoggedSignalSets(tc,'SimulationIndex',Value)
         Description
         objs = getLoggedSignalSets(tc) creates and returns a vector of the
         sltest.testmanager.LoggedSignalSet objects that are stored in a test case object.
         Input Arguments
         tc — Test case
         sltest.testmanager.TestCase object
         When the test case is an equivalence test, this index specifies the simulation that contains the signal
         set.
         Example: obj = getLoggedSignalSets(tc_equiv,'SimulationIndex',2);
Examples
         % Open model
         sldemo_absbrake
3-178
                                                                getLoggedSignalSets
See Also
sltest.testmanager.EquivalenceCriteria | sltest.testmanager.LoggedSignalSet
Topics
“Create and Run Test Cases with Scripts”
“Capture Simulation Data in a Test Case”
Introduced in R2019a
                                                                            3-179
3   Methods
         getOptions
         Class: sltest.testmanager.TestCase
         Package: sltest.testmanager
         Syntax
         opt = getOptions(tc)
         Description
         opt = getOptions(tc) returns the test file options object sltest.testmanager.Options
         associated with the test case tc.
         Input Arguments
         tc — Test case
         sltest.testmanager.TestCase object
Test case to get test file options from, specified as an sltest.testmanager.TestCase object.
         Output Arguments
         opt — Test file options
         sltest.testmanager.Options object
Examples
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('API Test File');
         ts = createTestSuite(tf,'API Test Suite');
         tc = createTestCase(ts,'baseline','Baseline API Test Case');
         See Also
         getOptions (TestFile) | getOptions (TestSuite) | sltest.testmanager.Options
         Topics
         “Create, Store, and Open MATLAB Figures”
         “Export Test Results”
3-180
                       getOptions
Introduced in R2017a
                          3-181
3   Methods
         getOptions
         Class: sltest.testmanager.TestFile
         Package: sltest.testmanager
         Syntax
         opt = getOptions(tf)
         Description
         opt = getOptions(tf) returns the test file options object sltest.testmanager.Options
         associated with the test file tf.
         Input Arguments
         tf — Test file
         sltest.testmanager.TestFile object
         Output Arguments
         opt — Test file options
         sltest.testmanager.Options object
Examples
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('API Test File');
         ts = createTestSuite(tf,'API Test Suite');
         tc = createTestCase(ts,'baseline','Baseline API Test Case');
         % Set the title for the report and specify to save figures
         opt.Title = 'ABC Co. Test Results';
         opt.SaveFigures = true;
         See Also
         sltest.testmanager.Options | sltest.testmanager.TestFile
3-182
                                           getOptions
Topics
“Create, Store, and Open MATLAB Figures”
“Export Test Results”
Introduced in R2017a
                                              3-183
3   Methods
         getOptions
         Class: sltest.testmanager.TestSuite
         Package: sltest.testmanager
         Syntax
         opt = getOptions(ts)
         Description
         opt = getOptions(ts) returns the test file options object sltest.testmanager.Options
         associated with the test suite ts.
         Input Arguments
         ts — Test suite
         sltest.testmanager.TestSuite object
Test suite to get test file options from, specified as an sltest.testmanager.TestSuite object.
         Output Arguments
         opt — Test file options
         sltest.testmanager.Options object
Examples
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('API Test File');
         ts = createTestSuite(tf,'API Test Suite');
         tc = createTestCase(ts,'baseline','Baseline API Test Case');
         See Also
         sltest.testmanager.Options | sltest.testmanager.TestSuite
         Topics
         “Create, Store, and Open MATLAB Figures”
         “Export Test Results”
3-184
                       getOptions
Introduced in R2017a
                          3-185
3   Methods
         getInputRuns
         Class: sltest.testmanager.TestCaseResult, sltest.testmanager.TestIterationResult
         Package: sltest.testmanager
         Syntax
         runArray = getInputRuns(result)
         Description
         runArray = getInputRuns(result) gets the simulation inputs from the test result.
         Input Arguments
         result — Result
         sltest.testmanager.TestCaseResult object | sltest.testmanager.TestiterationResult
         object
         Output Arguments
         runArray — Simulation run input results
         Simulink.sdi.Run object
         Examples
         Get Simulation Run Inputs from Test Case
         % Create test file and get test suite and test case objects
         tf = sltest.testmanager.TestFile('Input Run Test File');
         ts = getTestSuites(tf);
         tc = getTestCases(ts);
         % Add the model as the system under test, specify to save input runs
         setProperty(tc,'Model','sltestExcelExample',...
             'SaveInputRunInTestResult',true);
3-186
                                                                       getInputRuns
             'simulinktestdemos','sltestExampleInputs.xlsx');
input = addInput(tc,input_path,'Sheets',["Acceleration","Braking"]);
See Also
Simulink.sdi.Run | getOutputRuns
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2017a
                                                                            3-187
3   Methods
         getOutputRuns
         Class: sltest.testmanager.TestCaseResult
         Package: sltest.testmanager
         Syntax
         runArray = getOutputRuns(result)
         Description
         runArray = getOutputRuns(result) gets the test case simulation output results that are direct
         children of the test case results object.
         Input Arguments
         result — Test case result
         sltest.testmanager.TestCaseResult object
         Output Arguments
         runArray — Simulation output results
         Simulink.sdi.Run object
Examples
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('API Test File');
         ts = createTestSuite(tf,'API Test Suite');
         tc = createTestCase(ts,'baseline','Baseline API Test Case');
3-188
                                                                 getOutputRuns
% Run the test case and return an object with results data
resultsObj = run(tc);
See Also
Simulink.sdi.Run
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015a
                                                                       3-189
3   Methods
         getOutputRuns
         Class: sltest.testmanager.TestIterationResult
         Package: sltest.testmanager
         Syntax
         runArray = getOutputRuns(resultObj)
         Description
         runArray = getOutputRuns(resultObj) gets the test iteration simulation output results that
         are direct children of the test iteration results object.
         Input Arguments
         resultObj — Test iteration result
         object
         Output Arguments
         runArray — Simulation output results
         object
         See Also
         sltest.testmanager.TestIterationResult
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2016a
3-190
                                                                                    getParameterOverrides
getParameterOverrides
Class: sltest.testmanager.ParameterSet
Package: sltest.testmanager
Syntax
ovrs = getParameterOverrides(ps)
Description
ovrs = getParameterOverrides(ps) gets the parameter overrides in a parameter set and
returns them as an array of parameter override objects,
sltest.testmanager.ParameterOverride.
Input Arguments
ps — Parameter set
sltest.testmanager.ParameterSet object
Parameter set that you want to get the override from, specified as a
sltest.testmanager.ParameterSet object.
Output Arguments
ovrs — Parameter overrides
sltest.testmanager.ParameterOverride object array
Parameter overrides that are in the parameter set object, returned as an array of
sltest.testmanager.ParameterOverride objects.
Examples
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('API Test File');
ts = createTestSuite(tf,'API Test Suite');
tc = createTestCase(ts,'baseline','Baseline API Test Case');
                                                                                                  3-191
3   Methods
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015b
3-192
                                                                                      getParameterSets
getParameterSets
Class: sltest.testmanager.TestCase
Package: sltest.testmanager
Syntax
psets = getParameterSets(tc)
psets = getParameterSets(tc,simulationIndex)
Description
psets = getParameterSets(tc) gets the parameter sets in a test case and returns them as an
array of parameter set objects, sltest.testmanager.ParameterSet.
Input Arguments
tc — Test case
sltest.testmanager.TestCase object
Simulation number that the parameter sets apply to, specified as an integer, 1 or 2. This setting
applies to the simulation test case where there are two simulations. For baseline and simulation test
cases, the default simulation index is 1.
Output Arguments
psets — Parameter set
sltest.testmanager.ParameterSet object array
Examples
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('API Test File');
                                                                                                3-193
3   Methods
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015b
3-194
                                                                                           getProperty
getProperty
Class: sltest.testmanager.TestCase
Package: sltest.testmanager
Syntax
val = getProperty(tc,propertyName)
val = getProperty( ___ ,simulationIndex)
Description
val = getProperty(tc,propertyName) gets a test case property.
val = getProperty( ___ ,simulationIndex) gets a test case property. If the test case is an
equivalence test case, then specify the simulation index.
Input Arguments
tc — Test case
sltest.testmanager.TestCase object
Test case to get test setting property from, specified as an sltest.testmanager.TestCase object.
Test suite property names, specified as a character vector. The properties are set using
thesetProperty method. The available properties are:
                                                                                               3-195
3   Methods
         • 'PostloadCallback' — character vector evaluated after the system under test loads and
           PostLoadFcn callback completes
         • 'PreStartRealTimeApplicationCallback' — character vector evaluated before the real-
           time application is started on target computer
         • 'CleanupCallback' — character vector evaluated after simulation completes and model
           callbacks execute
         • 'UseSignalBuilderGroups' — use signal builder groups for test input
         • 'SignalBuilderGroup' — signal builder group name to use
         • 'OverrideModelOutputSettings' — override model output settings
         • 'SaveOutput' — save simulation output
         • 'SaveState' — save model states during simulation
         • 'SaveFinalState' — save final state of simulation
         • 'SignalLogging' — log signals
         • 'DSMLogging' — log data store
         • 'ConfigsetOverrideSetting' — value to determine override of configuration set
         • 'ConfigsetName' — configuration set override name
         • 'ConfigsetFileLocation' — path to a MAT-file that contains a configuration set object
         • 'ConfigsetVarName' — name of the variable in ConfigsetFileLocation that is a
           configuration set
         • 'IterationScript' — character vector evaluated for test case iteration script
         • 'SimulationIndex' — determines which simulation a property applies to, applicable to the
           equivalence test case type
         • 'FastRestart' — indicates if test iterations run using fast restart mode
         • 'SaveBaselineRunInTestResult' — enable saving the baseline run used in the test case,
           saved in the test result
         • 'LoadAppFrom' — location to load real-time application from
         • 'TargetComputer' — target computer name
         • 'TargetApplication' — target application name
         Simulation number that the property applies to, specified as an integer, 1 or 2. This setting applies to
         the simulation test case where there are two simulations. For baseline and simulation test cases, the
         simulation index is 1.
         Output Arguments
         val — Property content
         character vector | logical | scalar
The content of the test case property, returned as a character vector, logical, or scalar value.
Examples
3-196
                                                               getProperty
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('API Test File');
ts = createTestSuite(tf,'API Test Suite');
tc = createTestCase(ts,'baseline','Baseline API Test Case');
See Also
setProperty
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                                   3-197
3   Methods
         getProperty
         Class: sltest.testmanager.TestFile
         Package: sltest.testmanager
         Syntax
         val = getProperty(tf,propertyName)
         Description
         val = getProperty(tf,propertyName) gets a test file property.
         Input Arguments
         tf — Test file
         sltest.testmanager.TestFile object
         Output Arguments
         val — Property content
         character vector
Examples
3-198
                                              getProperty
See Also
setProperty
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                  3-199
3   Methods
         getProperty
         Class: sltest.testmanager.TestSuite
         Package: sltest.testmanager
         Syntax
         val = getProperty(ts,propertyName)
         Description
         val = getProperty(ts,propertyName) gets a test suite property.
         Input Arguments
         ts — Test suite
         sltest.testmanager.TestSuite object
Test suite object to get the property from, specified as an sltest.testmanager.TestSuite object.
         Test suite property names, specified as a character vector. The available properties are
         'SetupCallback' and 'CleanupCallback'.
         Output Arguments
         val — Property content
         character vector
Examples
3-200
                                              getProperty
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                  3-201
3   Methods
         getSetupPlots
         Class: sltest.testmanager.TestFileResult
         Package: sltest.testmanager
         Syntax
         figs = getSetupPlots(result)
         Description
         figs = getSetupPlots(result) returns figure handles of plots from the setup callbacks of the
         test file associated with the results. Figures returned using this method are not visible. To see the
         plots, set the figure handle Visible property to 'on'.
         Input Arguments
         result — Test file result
         sltest.testmanager.TestFileResult object
         Test file results to get setup plot figure handles from, specified as a
         sltest.testmanager.TestFileResult object
         Output Arguments
         figs — Figures from test file setup callbacks
         array of figure handles
Figures from test file setup callbacks, returned as an array of figure handles.
Examples
3-202
                                                                           getSetupPlots
opt.SaveFigures = true;
See Also
setProperty | sltest.testmanager.Options | sltest.testmanager.TestFile |
sltest.testmanager.TestFileResult
Topics
“Create, Store, and Open MATLAB Figures”
“Export Test Results”
Introduced in R2017a
                                                                                 3-203
3   Methods
         getSetupPlots
         Class: sltest.testmanager.TestSuiteResult
         Package: sltest.testmanager
         Syntax
         figs = getSetupPlots(result)
         Description
         figs = getSetupPlots(result) returns figure handles of plots generated from the setup
         callbacks of the test suite associated with the results. Figures returned using this method are not
         visible. To see the plots, set the figure handle Visible property to 'on'.
         Input Arguments
         result — Test suite results
         sltest.testmanager.TestSuiteResult object
         Test suite results to get setup plot figure handles from, specified as a
         sltest.testmanager.TestSuiteResult object.
         Output Arguments
         figs — Figures from test suite setup callbacks
         array of figure handles
Figures from test suite setup callbacks, returned as an array of figure handles.
Examples
3-204
                                                                    getSetupPlots
opt.SaveFigures = true;
See Also
setProperty (Test Suite) | sltest.testmanager.Options |
sltest.testmanager.TestSuite | sltest.testmanager.TestSuiteResult
Topics
“Create, Store, and Open MATLAB Figures”
“Export Test Results”
Introduced in R2017a
                                                                          3-205
3   Methods
         getSignalCriteria
         Class: sltest.testmanager.BaselineCriteria
         Package: sltest.testmanager
         Syntax
         sigCriteria = getSignalCriteria(bc)
         Description
         sigCriteria = getSignalCriteria(bc) gets the list of the signal criteria in a baseline criteria
         set and returns them as an array of signal criteria objects,
         sltest.testmanager.SignalCriteria.
         Input Arguments
         bc — Baseline criteria
         sltest.testmanager.BaselineCriteria object
         Baseline criteria that you want to get signal criteria from, specified as a
         sltest.testmanager.BaselineCriteria object.
         Output Arguments
         sigCriteria — Signal criteria object
         object array
         Signal criteria that are in the baseline criteria object, returned as an array of
         sltest.testmanager.SignalCriteria objects.
Examples
         In this example, a signal data set is capture for the baseline criteria, and the absolute tolerance is
         changed from 0 to 9.
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('API Test File');
         ts = createTestSuite(tf,'API Test Suite');
         tc = createTestCase(ts,'baseline','Baseline API Test Case');
3-206
                                                                  getSignalCriteria
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                                           3-207
3   Methods
         getSignalCriteria
         Class: sltest.testmanager.EquivalenceCriteria
         Package: sltest.testmanager
         Syntax
         sigCriteria = getSignalCriteria(eq)
         Description
         sigCriteria = getSignalCriteria(eq) gets the list of the signal criteria in an equivalence
         criteria set and returns them as an array of signal criteria objects,
         sltest.testmanager.SignalCriteria.
         Input Arguments
         eq — Equivalence criteria
         sltest.testmanager.EquivalenceCriteria object
         Output Arguments
         sigCriteria — Signal criteria object
         object array
         Signal criteria that are in the equivalence criteria object, returned as an array of
         sltest.testmanager.SignalCriteria objects.
Examples
         % Create the test file, test suite, and test case structure
         tf = sltest.testmanager.TestFile('API Test File');
         ts = createTestSuite(tf,'API Test Suite');
         tc = createTestCase(ts,'equivalence','Equivalence Test Case');
3-208
                                                                          getSignalCriteria
setProperty(tc,'Model','sldemo_absbrake','SimulationIndex',2);
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                                                   3-209
3   Methods
         getSimulationPlots
         Class: sltest.testmanager.TestCaseResult
         Package: sltest.testmanager
         Syntax
         figs = getSimulationPlots(result)
         figs = getSimulationPlots(result,index)
         Description
         figs = getSimulationPlots(result) returns figure handles of plots generated from the
         callbacks of the test case associated with the results. Figures returned using this method are not
         visible. To see the plots, set the figure handle Visible property to 'on'.
         Input Arguments
         result — Test case result
         sltest.testmanager.TestCaseResult object
         Test case results to get simulation plot figure handles from, specified as an
         sltest.testmanager.TestCaseResult object.
         Output Arguments
         figs — Figures from test case callbacks
         array of figure handles
Examples
3-210
                                                                          getSimulationPlots
See Also
setProperty | sltest.testmanager.Options | sltest.testmanager.TestCaseResult
Topics
“Create, Store, and Open MATLAB Figures”
“Export Test Results”
Introduced in R2017a
                                                                                     3-211
3   Methods
         getTestCaseByName
         Class: sltest.testmanager.TestFile
         Package: sltest.testmanager
         Syntax
         tc = getTestCaseByName(tf,name)
         Description
         tc = getTestCaseByName(tf,name) returns a test case object with the specified name.
         Input Arguments
         tf — Test file
         sltest.testmanager.TestFile object
Test file containing the test cases to get, specified as an sltest.testmanager.TestFile object.
         Name of the test case with the test file object, specified as a character vector. If the name does not
         match a test case, then the function returns an empty test case object.
         Output Arguments
         tc — Test case
         sltest.testmanager.TestCase object
         Test case, returned as an sltest.testmanager.TestCase object. If the name does not match a
         test case, then the function returns an empty test case object.
Examples
         See Also
         getTestCases | sltest.testmanager.TestFile
Introduced in R2020b
3-212
                                                                                      getTestCaseByName
getTestCaseByName
Class: sltest.testmanager.TestSuite
Package: sltest.testmanager
Syntax
tc = getTestCaseByName(ts,name)
Description
tc = getTestCaseByName(ts,name) returns a test case with the specified name.
Input Arguments
ts — Test suite
sltest.testmanager.TestSuite object
Test suite with the test case you want to get, specified as an sltest.testmanager.TestSuite
object.
The name of the test case within a test suite object, specified as a character vector. If the name does
not match a test case, then the function returns an empty test case object.
Output Arguments
tc — Test case
sltest.testmanager.TestCase object
Test case, returned as an sltest.testmanager.TestCase object. If the name does not match a
test case, then the function returns an empty test case object.
Examples
                                                                                                  3-213
3   Methods
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015b
3-214
                                                                                        getIterationResults
getIterationResults
Class: sltest.testmanager.TestIteration
Package: sltest.testmanager
Syntax
ti_result = getTestIterationResults(ti)
Description
ti_result = getTestIterationResults(ti) returns the test iteration results history for the
specified test iteration, ti. The test iteration history includes the results for all runs of the test
iteration in the Test Manager.
Input Arguments
ti — Test iteration
sltest.testmanager.TestIteration object
Output Arguments
ti_result — Test iteration result
array of sltest.testmanager.TestIterationResult objects
See Also
getTestIteration
Introduced in R2019b
                                                                                                   3-215
3   Methods
         getSimulationPlots
         Class: sltest.testmanager.TestIterationResult
         Package: sltest.testmanager
         Syntax
         figs = getSimulationPlots(result)
         figs = getSimulationPlots(result,index)
         Description
         figs = getSimulationPlots(result) returns figure handles of plots generated from the
         callbacks of the test iteration associated with the results. Figures returned using this method are not
         visible. To see the plots, set the figure handle Visible property to 'on'.
         Input Arguments
         result — Test iteration result
         sltest.testmanager.TestIterationResult object
         Test case iteration result to get callback figure handles from, specified as an
         sltest.testmanager.TestIterationResult object or a simulation index of the result.
         Output Arguments
         figs — Figures from test case callbacks
         array of figure handles
Figures from test case callbacks for the specified iteration, returned as an array of figure handles.
Examples
3-216
                                                                    getSimulationPlots
% Define iterations
vars = 32 : 0.5 : 34;
for k = 1 : length(vars)
% Get the callback plot figure handles from the first iteration
figs = tir(1).getSimulationPlots;
See Also
getIterationResults | setProperty (TestCase) | sltest.testmanager.Options |
sltest.testmanager.TestIterationResult
Topics
“Create, Store, and Open MATLAB Figures”
“Export Test Results”
Introduced in R2017a
                                                                               3-217
3   Methods
         getTestCaseResults
         Class: sltest.testmanager.ResultSet
         Package: sltest.testmanager
         Syntax
         testCaseResultArray = getTestCaseResults(result)
         Description
         testCaseResultArray = getTestCaseResults(result) gets the test case results that are
         direct children of the results set object.
         Input Arguments
         result — Results set
         sltest.testmanager.ResultSet object
Results set to get test case results from, specified as a sltest.testmanager.ResultSet object.
         Output Arguments
         testCaseResultArray — Test case results
         sltest.testmanager.TestCaseResult object array
Examples
         Use the function sltest.testmanager.run to return a result set that contains test file, test suite,
         and test case results.
3-218
                                                    getTestCaseResults
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015a
                                                               3-219
3   Methods
         getTestCaseResults
         Class: sltest.testmanager.TestSuiteResult
         Package: sltest.testmanager
         Syntax
         testCaseResultArray = getTestCaseResults(result)
         Description
         testCaseResultArray = getTestCaseResults(result) gets the test case results that are
         direct children of the test suite results object.
         Input Arguments
         result — Test suite result
         sltest.testmanager.TestSuiteResult object
         Output Arguments
         testCaseResultArray — Test case results
         sltest.testmanager.TestCaseResult object array
Examples
         Use the functionsltest.testmanager.run to return a result set that contains test file, test suite,
         and test case results.
3-220
                                                                  getTestCaseResults
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015a
                                                                             3-221
3   Methods
         getTestCases
         Class: sltest.testmanager.TestFile
         Package: sltest.testmanager
         Syntax
         tcArray = getTestCases(tf)
         Description
         tcArray = getTestCases(tf) returns an array of test case objects in a test file. Only test cases
         that are direct children of the test file (that is, not within a test suite) are returned.
         Input Arguments
         tf — Test file
         sltest.testmanager.TestFile object
Test file containing the test cases to get, specified as an sltest.testmanager.TestFile object.
         Output Arguments
         tcArray — Test case array
         sltest.testmanager.TestCase objects
         Test cases at the top level of the test file, returned as an array of sltest.testmanager.TestCase
         objects.
Examples
         See Also
         getTestCaseByName | sltest.testmanager.TestFile
Introduced in R2020b
3-222
                                                                                              getTestCases
getTestCases
Class: sltest.testmanager.TestSuite
Package: sltest.testmanager
Syntax
tcArray = getTestCases(ts)
Description
tcArray = getTestCases(ts) returns an array of test case objects that are at the first level of
the specified test suite.
Input Arguments
ts — Test suite
sltest.testmanager.TestSuite object
Test suite with the test cases you want to get, specified as an sltest.testmanager.TestSuite
object.
Output Arguments
tcArray — Test case array
object array
Array of test cases at the first level of the specified test suite, returned as an array of
sltest.testmanager.TestCase objects.
Examples
See Also
Topics
“Create and Run Test Cases with Scripts”
                                                                                                   3-223
3   Methods
Introduced in R2015b
3-224
                                                                                       getTestSuiteByName
getTestSuiteByName
Class: sltest.testmanager.TestFile
Package: sltest.testmanager
Syntax
ts = getTestSuiteByName(tf,name)
Description
ts = getTestSuiteByName(tf,name) returns a test suite with the specified name.
Input Arguments
tf — Test file
sltest.testmanager.TestFile object
Test file that contains the test suite, specified as a sltest.testmanager.TestFile object.
The name of the test suite within the test file, specified as a character vector. If the name does not
match a test suite, then the function returns an empty test suite object.
Example: 'Test Suite 5'
Output Arguments
ts — Test suite object
object
Test suite, returned as an sltest.testmanager.TestSuite object. If the name does not match a
test suite, then the function returns an empty test suite object.
Examples
                                                                                                   3-225
3   Methods
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015b
3-226
                                                                                     getTestFileResults
getTestFileResults
Class: sltest.testmanager.ResultSet
Package: sltest.testmanager
Syntax
testFileResultArray = getTestFileResults(result)
Description
testFileResultArray = getTestFileResults(result) gets the test file results that are
direct children of the results set object.
Input Arguments
result — Results set
sltest.testmanager.ResultSet object
Results set to get test file results from, specified as a sltest.testmanager.ResultSet object.
Output Arguments
testFileResultArray — Test file results
sltest.testmanager.TestFileResult object array
Examples
Use the functionsltest.testmanager.run to return a result set that contains test file, test suite,
and test case results.
                                                                                               3-227
3   Methods
         See Also
         sltest.testmanager.ResultSet | sltest.testmanager.TestCaseResult |
         sltest.testmanager.TestSuiteResult
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2016a
3-228
                                                                                      getTestSuiteByName
getTestSuiteByName
Class: sltest.testmanager.TestSuite
Package: sltest.testmanager
Syntax
tsOut = getTestSuiteByName(tsIn,name)
Description
tsOut = getTestSuiteByName(tsIn,name) returns a test suite with the specified name.
Input Arguments
tsIn — Test suite
sltest.testmanager.TestSuite object
The name of the test suite within a test suite object, specified as a character vector. If the name does
not match a test suite, then the function returns an empty test suite object.
Output Arguments
tsOut — Test suite
sltest.testmanager.TestSuite object
Test suite, returned as an sltest.testmanager.TestSuite object. If the name does not match a
test suite, then the function returns an empty test suite object.
Examples
                                                                                                  3-229
3   Methods
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015b
3-230
                                                                                       getTestSuites
getTestSuites
Class: sltest.testmanager.TestFile
Package: sltest.testmanager
Syntax
tsArray = getTestSuites(tf)
Description
tsArray = getTestSuites(tf) returns an array of test suite objects that are at the first level of
the test file.
Input Arguments
tf — Test file
sltest.testmanager.TestFile object
Test file that contains the test suites, specified as a sltest.testmanager.TestFile object.
Output Arguments
tsArray — Test suite array
object array
Array of test suites at the first level of the test file, returned as an array of
sltest.testmanager.TestSuite objects.
Examples
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                                                              3-231
3   Methods
         getTestSuites
         Class: sltest.testmanager.TestSuite
         Package: sltest.testmanager
         Syntax
         tsArray = getTestSuites(ts)
         Description
         tsArray = getTestSuites(ts) returns an array of test suite objects that are at the first level of
         the specified test suite.
         Input Arguments
         ts — Test suite
         sltest.testmanager.TestSuite object
         Test suite that contains the test suite you want to get, specified as an
         sltest.testmanager.TestSuite object.
         Output Arguments
         tsArray — Test suite array
         object array
         Array of test suites at the first level of the specified test suite, returned as an array of
         sltest.testmanager.TestSuite objects.
Examples
3-232
                                           getTestSuites
% as a new object
tsNew = getTestSuites(ts1);
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                 3-233
3   Methods
         getTestSuiteResults
         Class: sltest.testmanager.ResultSet
         Package: sltest.testmanager
         Syntax
         testSuiteResultArray = getTestSuiteResults(result)
         Description
         testSuiteResultArray = getTestSuiteResults(result) gets the test suite results that are
         direct children of the results set object.
         Input Arguments
         result — Results set
         sltest.testmanager.ResultSet object
Results set to get test suite results from, specified as a sltest.testmanager.ResultSet object.
         Output Arguments
         testSuiteResultArray — Test suite results
         sltest.testmanager.TestSuiteResult object array
Examples
         Use the functionsltest.testmanager.run to return a result set that contains test file, test suite,
         and test case results.
3-234
                                                    getTestSuiteResults
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015a
                                                                3-235
3   Methods
         getTestSuiteResults
         Class: sltest.testmanager.TestFileResult
         Package: sltest.testmanager
         Syntax
         testSuiteResultArray = getTestSuiteResults(result)
         Description
         testSuiteResultArray = getTestSuiteResults(result) gets the test suite results that are
         direct children of the test file results object.
         Input Arguments
         result — Test file results
         sltest.testmanager.TestFileResult object
         Output Arguments
         testSuiteResultArray — Test suite results
         sltest.testmanager.TestSuiteResult object array
Examples
         Use the functionsltest.testmanager.run to return a result set that contains test file, test suite,
         and test case results.
3-236
                                                                   getTestSuiteResults
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                               3-237
3   Methods
         getTestSuiteResults
         Class: sltest.testmanager.TestSuiteResult
         Package: sltest.testmanager
         Syntax
         testSuiteResultArray = getTestSuiteResults(result)
         Description
         testSuiteResultArray = getTestSuiteResults(result) gets the test suite results that are
         direct children of the test suite results object.
         Input Arguments
         resultObj — Test suite results
         sltest.testmanager.TestSuiteResult object
         Output Arguments
         testSuiteResultArray — Test suite results
         sltest.testmanager.TestSuiteResult object array
Examples
         Use the functionsltest.testmanager.run to return a result set that contains test file, test suite,
         and test case results.
3-238
                                                                     getTestSuiteResults
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015a
                                                                                 3-239
3   Methods
         getVerifyRuns
         Class: sltest.testmanager.TestCaseResult
         Package: sltest.testmanager
         Syntax
         dataset = getVerifyRuns(result)
         Description
         dataset = getVerifyRuns(result) gets the verify statement dataset from a test case result.
         Verify statements are constructed in the Test Sequence or Test Assessment blocks in the system
         under test.
         Input Arguments
         result — Test case result
         sltest.testmanager.TestCaseResult object
         Output Arguments
         dataset — Verify statement dataset
         Simulink.sdi.Run object array
Examples
3-240
                                                                 getVerifyRuns
See Also
Simulink.sdi.Run
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                       3-241
3   Methods
         getVerifyRuns
         Class: sltest.testmanager.TestIterationResult
         Package: sltest.testmanager
         Syntax
         dataset = getVerifyRuns(result)
         Description
         dataset = getVerifyRuns(result) gets the verify statement dataset from a test iteration result.
         Verify statements are made in the Test Sequence or Test Assessment blocks in the system under test.
         Input Arguments
         result — Test iteration result
         sltest.testmanager.TestIterationResult object
         Output Arguments
         dataset — Verify statement dataset
         Simulink.sdi.Run object
         See Also
         Simulink.sdi.Run
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2016a
3-242
                                                                                      layoutReport
layoutReport
Class: sltest.testmanager.TestResultReport
Package: sltest.testmanager
Syntax
layoutReport(obj)
Description
layoutReport(obj) incorporates the report parts into one document. The report is divided into
three main parts: title page, table of contents, and the main body.
• addTitlePage
• addReportTOC
• addReportBody
Input Arguments
obj — Test report object
sltest.testmanager.TestResultReport object
See Also
sltest.testmanager.TestResultReport
Topics
“Export Test Results”
“Create and Run Test Cases with Scripts”
Introduced in R2016a
                                                                                           3-243
3   Methods
         map
         Class: sltest.testmanager.TestInput
         Package: sltest.testmanager
         Syntax
         map(input,Name,Value)
         Description
         map(input,Name,Value) maps the test input data input to the system under test.
         Input Arguments
         input — Test input
         sltest.testmanager.TestInput object
         Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
         Value is the corresponding value. Name must appear inside quotes. You can specify several name and
         value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
         Example: 'Mode',4,'CustomFunction','mapfcn'
         Mapping mode, specified as the comma-separated pair consisting of 'mode' and an integer
         corresponding to the desired mapping mode:
         • 0 — Block name
         • 1 — Block path
         • 2 — Signal name
         • 3 — Port order (index)
         • 4 — Custom
         For more information on mapping modes, see “Map Root Inport Signal Data”.
         Example: 'Mode',2
3-244
                                                                                             map
Name of function used for custom mapping, specified as the comma-separated pair consisting of
'customFunction' and a character vector. This argument is optional and valid only when mode is
set to 4.
Example: 'CustomFunction','mapfcn'
Option to compile or not compile the model when performing input mapping, specified as the comma-
separated pair consisting of 'CompileModel' and false or true.
Example: 'CompileModel',false
Examples
This example maps data from a Microsoft Excel spreadsheet to a test case.
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                                                           3-245
3   Methods
         plot
         Package: Simulink.SimulationData
         Syntax
         plot(simOutObj)
         runObj = plot(simOutObj)
         Description
         plot(simOutObj) plots the simulation output data in the simulation output object, simOutObj, in
         the Simulation Data Inspector and opens the Simulation Data Inspector so you can view the plotted
         simulation output data. You can use the plot function to plot simulation results stored in these
         simulation output objects:
         • Simulink.SimulationOutput
         • Simulink.SimulationData.DataStoreMemory
         • Simulink.SimulationData.Parameter
         • Simulink.SimulationData.Signal
         • Simulink.SimulationData.State
         • Stateflow.SimulationData.Data
         • Stateflow.SimulationData.State
         • sltest.Assessment
         These simulation output objects also have plot functions that plot the data in and then open the
         Simulation Data Inspector:
         • Simulink.SimulationData.Dataset
         • Simulink.SimulationData.DatasetRef
         When a simulation output object contains fewer than eight signals to plot, the Simulation Data
         Inspector layout changes to 1-by-n, where n is the number of signals to plot, and plots one signal on
         each subplot. When the simulation output object contains more than eight signals to plot, the
         Simulation Data Inspector layout changes to 1-by-1 and plots the first signal in the simulation output
         object.
3-246
                                                                                                  plot
Examples
The ex_vdp_simout_plot model used in this example is configured to log signals, outputs, and
states and return all logged data in a single simulation output. The single simulation output is a
Simulink.SimulationOutput object that contains one or more types of other simulation output
objects, depending on the kinds of data you log. This example shows how to access each type of
logged data and use the plot function to plot the data in the Simulation Data Inspector. To generate
the SimulationOutput object containing all the logged data, simulate the model.
open_system('ex_vdp_simout_plot.slx')
out = sim('ex_vdp_simout_plot.slx');
You can pass the single simulation output, stored in a Simulink.SimulationOutput object, to the
plot function to view the data in the Simulation Data Inspector. When you plot data in a
SimulationOutput object that corresponds to a run in the Simulation Data Inspector, data in the
object that also logs to the Simulation Data Inspector is plotted. The model logs data using the
Dataset format, so all logged data streams to the Simulation Data Inspector.
When you use the plot function to plot the data, the Simulation Data Inspector updates to a 1-by-8
layout and plots one signal on each subplot.
plot(out)
When you plot the data for a single signal, the Simulation Data Inspector always imports the data for
the signal to a new run. Use the get function for the SimulationOutput object to access the signal
logging Dataset object, logsout.
logsout = get(out,'logsout');
Then, use the get function for the Dataset object to access the data for the first element.
sig1 = get(logsout,1);
When you plot the data for the signal, the Simulation Data Inspector imports the signal to a new run,
updates the layout to 1-by-1, and plots the signal.
plot(sig1)
Input Arguments
simOutObj — Simulation output object containing simulation data to plot
Simulink.SimulationOutput | Simulink.SimulationData.DataStoreMemory |
Simulink.SimulationData.Parameter | Simulink.SimulationData.Signal |
Simulink.SimulationData.State | sltest.Assessment |
Stateflow.SimulationData.Data | Stateflow.SimulationData.State
Simulation output object containing data you want to plot and view in the Simulation Data Inspector.
This plot function supports these simulation output objects:
                                                                                               3-247
3   Methods
         • Simulink.SimulationOutput
         • Simulink.SimulationData.DataStoreMemory
         • Simulink.SimulationData.Parameter
         • Simulink.SimulationData.Signal
         • Simulink.SimulationData.State
         • Stateflow.SimulationData.Data
         • Stateflow.SimulationData.State
         • sltest.Assessment
Example: plot(out)
         Output Arguments
         runObj — Run that corresponds to plotted data
         Simulink.sdi.Run object
         See Also
         plot
         Topics
         “View Data in the Simulation Data Inspector”
Introduced in R2019b
3-248
                                                                                     plotOneSignalToFile
plotOneSignalToFile
Class: sltest.testmanager.TestResultReport
Package: sltest.testmanager
Syntax
plotOneSignalToFile(obj,filePath,onesig,isComparison)
Description
plotOneSignalToFile(obj,filePath,onesig,isComparison) saves a signal plot to a PNG
image file. If the signal plot is a comparison, then the baseline signal, the difference, and the
tolerance are plotted in the same plot.
Input Arguments
obj — Test report object
sltest.testmanager.TestResultReport object
File path and name of the image you want to save, specified as a character vector.
                                                                                                 3-249
3   Methods
         Flag to indicate whether the signal is from a comparison run or not, specified as a Boolean, true or
         false.
         See Also
         sltest.testmanager.TestResultReport
         Topics
         “Export Test Results”
         “Create and Run Test Cases with Scripts”
Introduced in R2016a
3-250
                                                                                              remove
remove
Class: sltest.testmanager.BaselineCriteria
Package: sltest.testmanager
Syntax
remove(bc)
Description
remove(bc) removes the baseline criteria from a test case. The baseline criteria object is empty
after a call to this function.
Input Arguments
bc — Baseline criteria
sltest.testmanager.BaselineCriteria object
Baseline criteria that you want to remove from a test case, specified as a
sltest.testmanager.BaselineCriteria object.
Examples
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('API Test File');
ts = createTestSuite(tf,'API Test Suite');
tc = createTestCase(ts,'baseline','Baseline API Test Case');
See Also
Topics
“Create and Run Test Cases with Scripts”
                                                                                              3-251
3   Methods
Introduced in R2015b
3-252
                                                                                             remove
remove
Class: sltest.testmanager.EquivalenceCriteria
Package: sltest.testmanager
Syntax
remove(eq)
Description
remove(eq) removes the equivalence criteria from a test case. The equivalence criteria object is
empty after a call to this function.
Input Arguments
eq — Equivalence criteria
sltest.testmanager.EquivalenceCriteria object
Equivalence criteria that you want to remove from a test case, specified as a
sltest.testmanager.EquivalenceCriteria object.
Examples
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('API Test File');
ts = createTestSuite(tf,'API Test Suite');
tc = createTestCase(ts,'equivalence','Equivalence Test Case');
                                                                                              3-253
3   Methods
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015b
3-254
                                                                                     remove
remove
Class: sltest.testmanager.LoggedSignal
Package: sltest.testmanager
Syntax
remove(obj)
Description
remove(obj) removes an sltest.testmanager.LoggedSignal object from an
sltest.testmanager.LoggedSignalSet object and invalidates the LoggedSignal object.
Input Arguments
obj — Logged signal
sltest.testmanager.LoggedSignal object
Examples
% Open model
sldemo_absbrake
Select the Vehicle Speed block and enter gcb. Use the returned path to create a
Simulink.BlockPath object.
% Add signals to set
bPath = Simulink.BlockPath('sldemo_absbrake/Vehicle speed');
sig1 = lgset.addLoggedSignal(bPath,1);
sig2 = lgset.addLoggedSignal(bPath,2);
setProperty(tc,'Model','sldemo_absbrake');
% Remove signal
                                                                                     3-255
3   Methods
remove(sig2);
         See Also
         gcb
         Topics
         “Create and Run Test Cases with Scripts”
         “Capture Simulation Data in a Test Case”
Introduced in R2019a
3-256
                                                                               remove
remove
Class: sltest.testmanager.LoggedSignalSet
Package: sltest.testmanager
Syntax
remove(lgset)
Description
remove(lgset) removes an sltest.testmanager.LoggedSignalSet object from an
sltest.testmanager.TestCase object and invalidates its child signal objects.
Input Arguments
lgset — Logged signal set
sltest.testmanager.LoggedSignalSet object
Examples
% Open model
sldemo_absbrake
See Also
sltest.testmanager.TestCase
Topics
“Create and Run Test Cases with Scripts”
“Capture Simulation Data in a Test Case”
                                                                               3-257
3   Methods
Introduced in R2019a
3-258
                                                                                         remove
remove
Class: sltest.testmanager.ParameterOverride
Package: sltest.testmanager
Syntax
remove(po)
Description
remove(po) removes the parameter override from the parameter set. The parameter override object
is empty after a call to this function.
Input Arguments
po — Parameter override
sltest.testmanager.ParameterOverride object
Parameter override that you want to remove from a parameter set, specified as a
sltest.testmanager.ParameterOverride object.
Examples
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('API Test File');
ts = createTestSuite(tf,'API Test Suite');
tc = createTestCase(ts,'baseline','Baseline API Test Case');
                                                                                         3-259
3   Methods
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015b
3-260
                                                                                           remove
remove
Class: sltest.testmanager.ParameterSet
Package: sltest.testmanager
Syntax
remove(ps)
Description
remove(ps) removes the parameter set from a test case. The parameter set object is empty after a
call to this function.
Input Arguments
ps — Parameter set
sltest.testmanager.ParameterSet object
Parameter set that you want to remove from a test case, specified as a
sltest.testmanager.ParameterSet object.
Examples
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('API Test File');
ts = createTestSuite(tf,'API Test Suite');
tc = createTestCase(ts,'baseline','Baseline API Test Case');
                                                                                            3-261
3   Methods
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015b
3-262
                                                                                                 remove
remove
Class: sltest.testmanager.SignalCriteria
Package: sltest.testmanager
Syntax
remove(sc)
Description
remove(sc) removes signal criteria from the baseline or equivalence criteria set. The signal criteria
object is empty after a call to this function.
Input Arguments
sc — Signal criteria
sltest.testmanager.SignalCriteria object
Signal criteria that you want to remove from a baseline or equivalence criteria set, specified as a
sltest.testmanager.SignalCriteria object.
Examples
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('API Test File');
ts = createTestSuite(tf,'API Test Suite');
tc = createTestCase(ts,'baseline','Baseline API Test Case');
                                                                                                  3-263
3   Methods
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015b
3-264
                                                                                               remove
remove
Class: sltest.testmanager.TestCase
Package: sltest.testmanager
Syntax
remove(tc)
Description
remove(tc) removes the test case. The test case object is empty after a call to this function.
Parameter overrides, baseline criteria, or equivalence criteria associated with the test case become
invalid.
Input Arguments
tc — Test case
sltest.testmanager.TestCase object
Examples
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                                                                3-265
3   Methods
         remove
         Class: sltest.testmanager.TestInput
         Package: sltest.testmanager
         Syntax
         remove
         Description
         remove removes the test input from a test case. The test input object is empty after a call to this
         function.
         Input Arguments
         input — Test input
         sltest.testmanager.TestInput object
The test input that you want to remove, specified as a sltest.testmanager.TestInput object.
Examples
         % Map the input signals by block name for the first two inputs
         map(input(1),0);
         map(input(2),0);
3-266
                                           remove
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                           3-267
3   Methods
         remove
         Class: sltest.testmanager.TestSuite
         Package: sltest.testmanager
         Syntax
         remove(ts)
         Description
         remove(ts) removes the test suite. The test suite object is empty after a call to this function.
         Input Arguments
         ts — Test suite
         sltest.testmanager.TestSuite object
Examples
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015b
3-268
                                                                                   run
run
Class: sltest.testmanager.TestCase
Package: sltest.testmanager
Syntax
resultObj = run(tc)
Description
resultObj = run(tc) runs the test case and returns a results set object.
Input Arguments
tc — Test case
sltest.testmanager.TestCase object
Output Arguments
resultObj — Results set object
object
Examples
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('API Test File');
ts = createTestSuite(tf,'API Test Suite');
tc = createTestCase(ts,'simulation','Coverage Test Case');
                                                                                 3-269
3   Methods
         % Run the test case and return an object with results data
         ro = run(tc);
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015b
3-270
                                                                                                 run
run
Class: sltest.testmanager.TestFile
Package: sltest.testmanager
Syntax
resultObj = run(tf)
Description
resultObj = run(tf) runs the enabled test cases in the test file and returns a results set object.
Input Arguments
tf — Test file
sltest.testmanager.TestFile object
Test file with the test cases you want to run, specified as an sltest.testmanager.TestFile
object.
Output Arguments
resultObj — Results set object
sltest.testmanager.ResultSet object
Examples
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('My Test File');
ts = createTestSuite(tf,'My Test Suite');
tc = createTestCase(ts,'simulation','Simulation Test Case');
                                                                                              3-271
3   Methods
         % Run the test file and return an object with results data
         ro = run(tf);
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015b
3-272
                                                                                                run
run
Class: sltest.testmanager.TestSuite
Package: sltest.testmanager
Syntax
resultObj = run(ts)
Description
resultObj = run(ts) runs the enabled test cases in the test suite and returns a results set object.
Input Arguments
ts — Test suite
sltest.testmanager.TestSuite object
Test suite with the test cases you want to run, specified as an sltest.testmanager.TestSuite
object.
Output Arguments
resultObj — Result set
sltest.testmanager.ResultSet object
Examples
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('My Test File');
ts = createTestSuite(tf,'My Test Suite');
tc = createTestCase(ts,'simulation','Simulation Test Case');
                                                                                             3-273
3   Methods
         % Run the test suite and return an object with results data
         ro = run(ts);
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015b
3-274
                                                                                    saveToFile
saveToFile
Class: sltest.testmanager.TestFile
Package: sltest.testmanager
Syntax
saveToFile(tf)
saveToFile(tf,filePath)
Description
saveToFile(tf) saves the changes to the test file.
Input Arguments
tf — Test file
sltest.testmanager.TestFile object
The file path and name to save the test file at, specified as a character vector.
Example: 'C:\MATLAB\New Test File.mldatx'
Examples
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('C:\MATLAB\My Test File.mldatx');
ts = createTestSuite(tf,'My Test Suite');
tc = createTestCase(ts,'simulation','Simulation Test Case');
                                                                                      3-275
3   Methods
         See Also
         Topics
         “Create and Run Test Cases with Scripts”
Introduced in R2015b
3-276
                                                                                       setModelParam
setModelParam
Class: sltest.testmanager.TestIteration
Package: sltest.testmanager
Syntax
setModelParam(obj,modelObject,paramName,value)
setModelParam(obj,modelObject,paramName,value,'SimulationIndex',sim)
Description
setModelParam(obj,modelObject,paramName,value) sets a model parameter for the test
iteration object.
setModelParam(obj,modelObject,paramName,value,'SimulationIndex',sim) sets a
model parameter for the specified simulation in an equivalence test.
Input Arguments
obj — Test iteration to set model parameter for
sltest.testmanager.TestIteration object
Test iteration that you want to set the model parameter for, specified as a
sltest.testmanager.TestIteration object.
Model or block parameter name, specified as the comma-separated pair consisting of the parameter
name, specified as a character vector, and the value, specified in the format determined by the
parameter type. Case is ignored for parameter names. Value character vectors are case sensitive.
Values are often character vectors, but they can also be numeric, arrays, and other types. Many block
parameter values are specified as character vectors, but two exceptions are these parameters:
Position, specified as a value vector, and UserData, which can be any data type.
For more information on parameter name and value pairs, see set_param.
Example: 'Solver','ode15s'
Data Types: char
                                                                                               3-277
3   Methods
Examples
setModelParam(obj,[sltest_bdroot '/Mu'],'Gain','1000')
         See Also
         set_param | sltest.testmanager.TestIteration
         Topics
         “Test Iterations”
         “Create and Run Test Cases with Scripts”
Introduced in R2016a
3-278
                                                                                             setProperty
setProperty
Class: sltest.testmanager.TestCase
Package: sltest.testmanager
Syntax
setProperty(tc,Name,Value)
Description
setProperty(tc,Name,Value) sets a test case property.
Input Arguments
tc — Test case
sltest.testmanager.TestCase object
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
Value is the corresponding value. Name must appear inside quotes. You can specify several name and
value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Example: 'StopTime',100
The model name in the System Under Test section, specified as a character vector.
Example: 'sldemo_absbrake'
The simulation mode of the model or harness, specified as a character vector. To return to the default
model settings, specify an empty character vector, ''.
Example: 'SimulationMode','Rapid Accelerator'
Override SIL/PIL simulation mode of model blocks to Normal simulation mode, specified as a logical.
If this property is true, the associated check box in the Simulation Settings Overrides section of the
Test Manager is selected.
                                                                                                 3-279
3   Methods
Indicate if the test case overrides the model start time, specified as true or false.
Indicate if the test case overrides the model stop time, specified as true or false.
Indicate if the test case overrides the model initial state, specified as true or false.
Name of a test harness to use in the System Under Test section, specified as a character vector.
         Indicate if the test case overrides the model and uses a different Signal Builder group in the Inputs
         section, specified as true or false.
         Signal Builder group name, specified as a character vector. To return to the default model settings,
         specify an empty character vector, ''.
3-280
                                                                                               setProperty
Indicate if the test case overrides the model settings under the Outputs section, specified as true or
false.
Indicate if the test case overrides saving model output, specified as true or false.
Indicate if the test case is set to save output state values, specified as true or false.
Indicate if the test case is set to log signals marked for logging in the model, specified as true or
false.
Indicate if the test case is set to log Data Store variables, specified as true or false.
Indicate if the test case is set to store final state values, specified as true or false.
Simulation number that the property applies to, specified as an integer, 1 or 2. This setting applies to
the simulation test case.
• 1 — No override
• 2 — Use a named configuration set in the model
• 3 — Use a configuration set specified in a file
                                                                                                   3-281
3   Methods
File name and path of the configuration set, specified as a character vector.
         Test-case level cleanup callback script, specified as a character vector. The function deletes any
         existing callback script and replaces it with the specified character vector.
         Example: 'clear a % clear value from workspace'
         Character vector evaluated before the real-time application is started on the target computer,
         specified as a character vector. For more information on real-time testing, see “Test Models in Real
         Time”.
         Iteration script evaluated to create test case iterations, specified as a character vector. For more
         information about test iteration scripts, see “Test Iterations”.
Indicate if the test iterations run using fast restart mode, specified as true or false.
         Indicate if the test case saves the baseline used in the test result after test execution, specified as
         true or false.
Enable saving external input run used in test result, specified as true or false.
3-282
                                                                                              setProperty
Enable stopping the simulation at the final time value of the input, specified as true or false.
Location from which to load the application, specified as an integer. This property is available only in
real-time test cases.
• 1 — Model
• 2 — Target application
• 3 — Target computer
For more information on real-time testing, see “Test Models in Real Time”.
Name of the target computer, specified as a character vector. This property is available only in real-
time test cases. For more information on real-time testing, see “Test Models in Real Time”.
Name and path of the target application, specified as a character vector. This property is available
only in real-time test cases. For more information on real-time testing, see “Test Models in Real
Time”.
Examples
% Create the test file, test suite, and test case structure
tf = sltest.testmanager.TestFile('API Test File');
ts = createTestSuite(tf,'API Test Suite');
tc = createTestCase(ts,'baseline','Baseline API Test Case');
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                                                                   3-283
3   Methods
         setProperty
         Class: sltest.testmanager.TestFile
         Package: sltest.testmanager
         Syntax
         setProperty(tf,Name,Value)
         Description
         setProperty(tf,Name,Value) sets a test file property.
         Input Arguments
         tf — Test file
         sltest.testmanager.TestFile object
         Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
         Value is the corresponding value. Name must appear inside quotes. You can specify several name and
         value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
         Example: 'SetupCallback','a = 300; % set nominal value'
         Test-file level setup callback script, specified as a character vector. The function replaces any existing
         callback script with this value.
         Example: 'a = 300; % set nominal value'
         Test-file level cleanup callback script, specified as a character vector. The function replaces any
         existing callback script with this value.
         Example: 'clear a % clear value from workspace'
Examples
3-284
                                                                   setProperty
See Also
getProperty
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                                       3-285
3   Methods
         setProperty
         Class: sltest.testmanager.TestSuite
         Package: sltest.testmanager
         Syntax
         setProperty(ts,Name,Value)
         Description
         setProperty(ts,Name,Value) sets a test suite property.
         Input Arguments
         ts — Test suite
         sltest.testmanager.TestSuite object
         Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
         Value is the corresponding value. Name must appear inside quotes. You can specify several name and
         value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
         Example: 'SetupCallback','a = 300; % set nominal value'
         Test-suite level setup callback script, specified as a character vector. The function deletes any existing
         callback script and replaces it with the specified character vector.
         Example: 'a = 300; % set nominal value'
         Test-suite level cleanup callback script, specified as a character vector. The function deletes any
         existing callback script and replaces it with the specified character vector.
         Example: 'clear a % clear value from workspace'
Examples
3-286
                                                                   setProperty
See Also
Topics
“Create and Run Test Cases with Scripts”
Introduced in R2015b
                                                                       3-287
3   Methods
         setTestParam
         Class: sltest.testmanager.TestIteration
         Package: sltest.testmanager
         Syntax
         setTestParam(obj,Name,Value)
         Description
         setTestParam(obj,Name,Value) sets the test iteration parameter with additional options
         specified by one or more Name,Value pair arguments.
         Input Arguments
         obj — Test iteration object
         object
         Test iteration object that you want to apply the test parameter to, specified as a
         sltest.testmanager.TestIteration object.
         Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and
         Value is the corresponding value. Name must appear inside quotes. You can specify several name and
         value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
         Parameter set name, specified as the comma-separated pair consisting of 'ParameterSet' and a
         character vector. Parameter set overrides are setup in the Parameter Overrides section of the test
         case.
         Example: 'ParameterSet','Param Set 1'
         Baseline criteria dataset name, specified as the comma-separated pair consisting of 'Baseline' and
         a character vector. Baseline criteria datasets are setup in the Baseline Criteria section of the test
         case. It is available only for baseline test cases.
         Example: 'Baseline','BaselineSet_High'
         External input name, specified as the comma-separated pair consisting of 'ExternalInput' and a
         character vector. External input overrides are setup in the Inputs section of the test case. You can
3-288
                                                                                         setTestParam
Configuration setting name, specified as the comma-separated pair consisting of 'ConfigSet' and a
character vector. Configuration setting overrides are setup in the Configuration Settings
Overrides section of the test case.
Example: 'ConfigSet','Solver 3'
Signal Editor scenario input name, specified as the comma-separated pair consisting of
'SignalEditorScenario' and a character vector. Signal Editor scenario overrides are set up in
the test case Inputs section.
Example: 'SignalEditorScenario','Acceleration'
Signal Builder group input name, specified as the comma-separated pair consisting of
'SignalBuilderGroup' and a character vector. Signal Builder group overrides are set up in the
test case Inputs section.
Example: 'SignalBuilderGroup','Acceleration'
Pre-load callback script, specified as the comma-separated pair consisting of 'PreLoadFcn' and a
character vector. The pre-load callback script is setup in the Callbacks section of the test case.
Post-load callback script, specified as the comma-separated pair consisting of 'PostLoadFcn' and a
character vector. The post-load callback script is setup in the Callbacks section of the test case.
Pre-start real-time application callback script, specified as the comma-separated pair consisting of
'PreStartRealTimeApplicationFcn' and a character vector. The pre-start real-time application
callback script is setup in the Callbacks section of the test case.
                                                                                               3-289
3   Methods
         Cleanup callback script, specified as the comma-separated pair consisting of 'CleanupFcn' and a
         character vector. The cleanup callback script is setup in the Callbacks section of the test case.
         Description — Description
         current test case setting (default) | character vector
         Test description text, specified as the comma-separated pair consisting of 'Description' and a
         character vector. The Description is setup in the Description section of the test case.
         Example: 'Description','Test the autopilot controller for wind gusts'
Examples
         setTestParam(obj,'Description',...
            'Test the autopilot controller for wind gusts');
         See Also
         sltest.testmanager.TestIteration
         Topics
         “Test Iterations”
         “Create and Run Test Cases with Scripts”
Introduced in R2016a
3-290
                                                                                               setVariable
setVariable
Class: sltest.testmanager.TestIteration
Package: sltest.testmanager
Syntax
setVariable(obj,'Name',varName,'Source',srcName,'Value',value)
Description
setVariable(obj,'Name',varName,'Source',srcName,'Value',value) sets a model
variable override for the test iteration. Specify the sltest.testmanager.TestIteration object,
and then specify the variable name, source, and override value. The method overrides the variable in
the test iteration and does not permanently change the model variable.
Input Arguments
obj — Test iteration object
object
The test iteration you want to apply the override to, specified as a
sltest.testmanager.TestIteration object.
The source of the variable to override, specified as a character vector. For non-real-time test cases,
the possible sources can be 'base workspace', 'model workspace', 'mask workspace', or
the name of a data dictionary, such as 'data.sldd' or model workspace name.
For real-time test cases, the possible sources are model element paths, which, if the source is a model
parameter, might be an empty character vector.
Examples
                                                                                                  3-291
3   Methods
setVariable(obj,'Name','g','Source','base workspace','Value',33);
         See Also
         sltest.testmanager.TestIteration
         Topics
         “Test Iterations”
         “Create and Run Test Cases with Scripts”
Introduced in R2016a
3-292
         4
Blocks
4     Blocks
               Observer Port
               Wirelessly link signals to use with verification
               Library:             Simulink Test
               Description
               Include the Observer Port block within an Observer model to map signals from a system model to an
               Observer model. The Observer Port block can only be used within a model that is linked to an
               Observer Reference block.
               Ports
               Output
               Mapped signal that flows through the Observer Port into the Observer model.
               Data Types: double | single | Boolean | base integer | fixed point | enumerated | non-
               virtual bus
               Extended Capabilities
               C/C++ Code Generation
               Generate C and C++ code using Simulink® Coder™.
               See Also
               Topics
               “Access Model Data Wirelessly by Using Observers”
               Observer Reference
Introduced in R2019a
4-2
                                                                                   Observer Reference
Observer Reference
Create and contain an Observer model
Library:            Simulink Test
Description
The Observer Reference block references a separate model called the Observer model, which houses
your verification subsystem. Connect the Observer Reference block to Simulink models without signal
lines to wirelessly debug and test the design of the system.
Ports
The Observer Reference block does not have inports or outports. Signals are mapped to the Observer
Model through the Observer Port block.
Parameters
Observer Model name — File name of Observer model
'' (default) | character vector
Path to the Observer model. The file name must be a valid MATLAB identifier. The extension, for
example, .slx, is optional.
Extended Capabilities
C/C++ Code Generation
Generate C and C++ code using Simulink® Coder™.
See Also
Topics
“Access Model Data Wirelessly by Using Observers”
Observer Port
Introduced in R2019a
                                                                                                  4-3
4     Blocks
               Test Assessment
               Assess simulation testing scenarios, function calls, and assessments
               Library:            Simulink Test
               Description
               Define test assessments in a tabular series of steps. Like the Test Sequence block, the Test
               Assessment block uses MATLAB as the action language.
               Double-click the Test Assessment block to open the Test Sequence Editor. By default, the Test
               Assessment block contains a test step Run, configured as a When decomposition sequence. To change
               the transition type to a standard transition, right-click the top-level step and clear When
               decomposition. For more information, see “Test Sequence Editor”.
               Ports
               Ports correspond to inputs and outputs defined in the Test Sequence Editor Symbols pane.
               Parameters
               For a description of block parameters, see Subsystem, Atomic Subsystem, CodeReuse Subsystem.
               Extended Capabilities
               C/C++ Code Generation
               Generate C and C++ code using Simulink® Coder™.
               See Also
               “Test Sequence Editor” | “Test Sequence and Assessment Syntax”
               Topics
               “Assess Model Simulation Using verify Statements”
               “Actions and Transitions”
               “Signal Generation Functions”
Introduced in R2016a
4-4
                                                                                          Test Sequence
Test Sequence
Create simulation testing scenarios, function calls, and assessments
Library:            Simulink Test
Description
Define a test sequence using a tabular series of steps. Like the Test Assessment block, the Test
Sequence block uses MATLAB as the action language.
Ports
Ports correspond to inputs and outputs defined in the Test Sequence Editor Symbols pane.
Parameters
For a description of block parameters, see Subsystem, Atomic Subsystem, CodeReuse Subsystem.
Extended Capabilities
C/C++ Code Generation
Generate C and C++ code using Simulink® Coder™.
See Also
“Test Sequence Editor” | “Test Sequence and Assessment Syntax”
Topics
“Assess Model Simulation Using verify Statements”
“Actions and Transitions”
“Signal Generation Functions”
Introduced in R2015a
                                                                                                   4-5
4     Blocks
               Sequence Viewer
               Display messages, events, states, transitions, and functions between blocks during simulation
               Library:           Simulink / Messages & Events
                                  Simulink Test
                                  SimEvents
                                  Stateflow
               Description
               The Sequence Viewer block displays messages, events, states, transitions, and functions between
               certain blocks during simulation. The blocks that you can display are called lifeline blocks and
               include:
               • Subsystems
               • Referenced models
               • Blocks that contain messages, such as Stateflow charts
               • Blocks that call functions or generate events, such as Function Caller, Function-Call Generator,
                 and MATLAB Function blocks
               • Blocks that contain functions, such as Function-Call Subsystem and Simulink Function blocks
               To see states, transitions, and events for lifeline blocks in a referenced model, you must have a
               Sequence Viewer block in the referenced model. Without a Sequence Viewer block in the referenced
               model, you can see only messages and functions for lifeline blocks in the referenced model.
               Parameters
               Time Precision for Variable Step — Digits for time increment precision
               3 (default) | scalar
               Number of digits for time increment precision. When using a variable step solver, change this
               parameter to adjust the time precision for the sequence viewer. By default the block supports 3 digits
               of precision.
               Suppose the block displays two events that occur at times 0.1215 and 0.1219. Displaying these two
               events precisely requires 4 digits of precision. If the precision is 3, then the block displays two events
               at time 0.121.
               Programmatic Use
               Block Parameter: VariableStepTimePrecision
               Type: character vector
               Values: '3' | scalar
               Default: '3'
4-6
                                                                                        Sequence Viewer
For example, if History is 5 and there are 10 events in your simulation, then the block displays 6
events, including the last event and the five events prior the last event. Earlier events are not
displayed. The time ruler is greyed to indicate the time between the beginning of the simulation and
the time of the first displayed event.
Each send, receive, drop, or function call event is counted as one event, even if they occur at the
same simulation time.
Programmatic Use
Block Parameter: History
Type: character vector
Values: '1000' | scalar
Default: '1000'
Block Characteristics
Data Types                Boolean | bus | double | enumerated | fixed point | integer |
                          single
Direct Feedthrough        no
Multidimensional          yes
Signals
Variable-Size Signals     no
Zero-Crossing             no
Detection
Extended Capabilities
C/C++ Code Generation
Generate C and C++ code using Simulink® Coder™.
This block can be used for visualizing message transitions during simulation, but is not included in
the generated code.
This block displays messages during simulation when used in subsystems that generate HDL code,
but it is not included in the hardware implementation.
See Also
“Use the Sequence Viewer Block to Visualize Messages, Events, and Entities” (SimEvents)
Introduced in R2015b
                                                                                                      4-7
                     5
Language Operators
5     Language Operators
            after
            Elapsed time since beginning of test step
            Syntax
            after(n,timeunits)
            Description
            after(n,timeunits) returns true if the amount of time (n) in timeunits has elapsed since the
            beginning of the current test step. You must include the timeunits.
            • sec — seconds
            • msec — milliseconds
            • usec — microseconds
            Examples
            Specify Time Elapsed After Specified Time
            Specify 20 seconds as the time that has elapsed since the beginning of the test step. This statement
            returns true only after 20 seconds has passed.
after(20,sec)
            Tips
            after statements can be used in the Test Sequence and Test Assessment blocks and in Stateflow
            charts.
            See Also
            before | duration | et | t
            Topics
            “Test Sequence and Assessment Syntax”
            “Test Sequence Basics”
            “Programmatically Create a Test Sequence”
            “Signal Generation Functions”
Introduced in R2015a
5-2
                                                                                                 assert
assert
Evaluate logical expression
Syntax
assert(expression)
assert(expression,errmsg)
Description
assert(expression) evaluates a logical expression. Logical expressions evaluate to true or
false. If the assert statement evaluates to false, simulation stops and returns an error.
assert(expression,errmsg) returns the specified error message string (errmsg) for the failed
assert statement. If you run the test in the Test Manager, the error message appears in the
simulation log. If you run the test outside the Test Manager, the message appears in the Diagnostic
Viewer.
Examples
If either h or k are not 0, this assert statement fails and simulation stops.
Tips
• assert statements can be used in the Test Sequence and Test Assessment blocks and in Stateflow
  charts. assert in Model Reference blocks works in Normal mode, but not in Rapid Accelerator
  mode simulations.
• When comparing floating-point data in assert statements, consider the precision limitations
  associated with floating-point numbers. If you need to use floating-point data, define a tolerance
  for the assessment. See “Floating-Point Numbers”. For example, instead of assert(x == 5),
  assert x within a tolerance of 0.001:
See Also
verify
Topics
“Test Sequence and Assessment Syntax”
“Test Sequence Basics”
“Programmatically Create a Test Sequence”
“Signal Generation Functions”
                                                                                                   5-3
5     Language Operators
Introduced in R2015a
5-4
                                                                                                before
before
Elapsed time until specified time in test step
Syntax
before(n,timeunits)
Description
before(n,timeunits) returns true until the amount of time (n) in timeunits has elapsed since
the beginning of the current test step. You must include the timeunits.
• sec — seconds
• msec — milliseconds
• usec — microseconds
Examples
Specify Time Elapsed Until Specified Time
Specify 20 seconds as the time that has elapsed since the beginning of the test step. This statement
returns true until 20 seconds has passed.
before(20,sec)
Tips
before statements can be used in the Test Sequence and Test Assessment blocks and in Stateflow
charts.
See Also
after | duration | et | t
Topics
“Test Sequence and Assessment Syntax”
“Test Sequence Basics”
“Programmatically Create a Test Sequence”
“Signal Generation Functions”
Introduced in R2015a
                                                                                                  5-5
5     Language Operators
            duration
            Elapsed time since beginning of test step
            Syntax
            elapsed_time = duration(condition,timeunits)
            Description
            elapsed_time = duration(condition,timeunits) returns the elapsed time in timeunits for
            which the condition has been true. The condition is a logical expression. The elapsed_time is reset
            when the test step is re-entered or when the condition is no longer true. If you omit timeunits, the
            elapsed time defaults to seconds.
            • sec — seconds
            • msec — milliseconds
            • usec — microseconds
            Examples
            Specify Time Elapsed For a Duration
Specify the duration after 100 msec from the time when x greater than 50 last became true.
            Tips
            • duration statements can be used in the Test Sequence and Test Assessment blocks and in
              Stateflow charts.
            • In Stateflow charts, duration statements can be associated only with a single state. You cannot
              use a duration on a transition that has more than one source state connected using a junction.
            See Also
            after | before | et | t
            Topics
            “Test Sequence and Assessment Syntax”
            “Test Sequence Basics”
            “Programmatically Create a Test Sequence”
            “Signal Generation Functions”
Introduced in R2015a
5-6
                                                                                                   et
et
Elapsed time of test step
Syntax
et(timeunits)
Description
et(timeunits) returns the elapsed time of the test sequence step in timeunits. If you omit
timeunits, the elapsed time defaults to seconds. et is an alias for elapsed and both are valid.
• sec — seconds
• msec — milliseconds
• usec — microseconds
Examples
Specify Elapsed Step Time in Milliseconds
et(msec)
Tips
et statements can be used in the Test Sequence and Test Assessment blocks and in Stateflow charts.
See Also
after | before | duration | t
Topics
“Test Sequence and Assessment Syntax”
“Test Sequence Basics”
“Programmatically Create a Test Sequence”
“Signal Generation Functions”
Introduced in R2017a
                                                                                                  5-7
5     Language Operators
            hasChanged
            Detect data change in test step
            Syntax
            hasChanged(u)
            Description
            hasChanged(u) returns true if the value of u changes since the beginning of the test step.
            Otherwise, hasChanged returns false.
            Examples
            Detect Value Change
Detect if x has changed value. This statement returns true if x has changed.
hasChanged(x)
            For a bus with two signals, signal_1 and signal_2, and data as the name of the input to the test
            sequence, detect when the value of signal_2 has changed.
hasChanged(data.signal2)
            Tips
            hasChanged statements can be used in the Test Sequence and Test Assessment blocks and in
            Stateflow charts.
            See Also
            hasChangedTo | hasChangedFrom
            Topics
            “Test Sequence and Assessment Syntax”
            “Test Sequence Basics”
            “Programmatically Create a Test Sequence”
            “Signal Generation Functions”
Introduced in R2015a
5-8
                                                                                     hasChangedFrom
hasChangedFrom
Detect data change from specified value in test step
Syntax
hasChangedFrom(u,A)
Description
hasChangedFrom(u,A) returns true if the value of u changes from the value A. Otherwise,
hasChangedFrom returns false.
Examples
Detect Value Change From Specified Value
Detect if x has changed from a value of 15. This statement returns true when x had a value of 15 in
the previous time step and has a value not equal to 15 in the current time step.
hasChangedFrom(x,15)
Tips
hasChangedFrom statements can be used in the Test Sequence and Test Assessment blocks and in
Stateflow charts.
See Also
hasChanged | hasChangedTo
Topics
“Test Sequence and Assessment Syntax”
“Test Sequence Basics”
“Programmatically Create a Test Sequence”
“Signal Generation Functions”
Introduced in R2015a
                                                                                                 5-9
5   Language Operators
          hasChangedTo
          Detect data change to specified value in test step
          Syntax
          hasChangedTo(u,B)
          Description
          hasChangedTo(u,B) returns true if the value of u changes to the value B. Otherwise,
          hasChangedTo returns false.
          Examples
          Detect Value Change To Specified Value
          Detect if x has changed to a value of 10. This statement returns true when x did not have value of 10
          in the previous time step and has a value of 10 in the current time step.
hasChangedTo(x,10)
          Tips
          hasChangedTo statements can be used in the Test Sequence and Test Assessment blocks and in
          Stateflow charts.
          See Also
          hasChanged | hasChangedFrom
          Topics
          “Test Sequence and Assessment Syntax”
          “Test Sequence Basics”
          “Programmatically Create a Test Sequence”
          “Signal Generation Functions”
Introduced in R2015a
5-10
                                                                                              heaviside
heaviside
Heaviside step test signal
Syntax
heaviside(x)
Description
heaviside(x) creates a Heaviside step signal. Heaviside signals are also called unit step signals
and are discontinuous functions. They return 0 for x < 0 and 1 for x > 0.
To specify when to generate a Heaviside step signal within a test step, use this operator with the
elapsed time (et) operator.
Examples
Create a Heaviside Signal
heaviside(et-10)
Tips
heaviside signal generation statements can be used in the Test Sequence and Test Assessment
blocks and in Stateflow charts.
See Also
ramp | sawtooth | square | triangle
Topics
“Test Sequence and Assessment Syntax”
“Test Sequence Basics”
                                                                                                     5-11
5   Language Operators
Introduced in R2015a
5-12
                                                                                               latch
latch
Save value of an expression
Syntax
latch(x)
Description
latch(x) saves the value of x when the test step is entered and returns that value of x. The
latch(x) statement reevaluates the next time the step is entered. You can use latch statements in
Test Sequence and Test Assessment blocks.
Examples
Use latch to Save a Value
latch_val = latch(torque)
See Also
Topics
“Test Sequence and Assessment Syntax”
“Test Sequence Basics”
“Programmatically Create a Test Sequence”
Introduced in R2015a
                                                                                               5-13
5   Language Operators
          ramp
          Ramp signal for test signal generation
          Syntax
          ramp(x)
          Description
          ramp(x) creates a ramp signal wave with a slope of 1 and returns the value of the ramp at time x.
          To specify when to generate a ramp signal within a test step, use this operator with the elapsed time
          (et) operator.
Note ramp(et) returns the elapsed time of the test step and is the same as et.
          Examples
          Create a Ramp Signal
Create a ramp signal that increases one unit every 3 seconds in the test step.
ramp(et/3)
          Tips
          ramp signal generation statements can be used in the Test Sequence and Test Assessment blocks and
          in Stateflow charts.
          See Also
          heaviside | sawtooth | square | triangle
          Topics
          “Test Sequence and Assessment Syntax”
5-14
                                            ramp
Introduced in R2015a
                                            5-15
5   Language Operators
          sawtooth
          Sawtooth wave test signal
          Syntax
          sawtooth(x)
          Description
          sawtooth(x) creates a sawtooth wave with a period of 1 and range -1 to 1. In the interval 0 <= x <
          1, square(x) increases. The difference between triangle waves and sawtooth waves is that a triangle
          wave has equal rise and fall times.
          To specify the number of sawtooth wave cycles within a test step, use this operator with the elapsed
          time (et) operator.
          Examples
          Create a Sawtooth Wave
          Tips
          sawtooth signal generation statements can be used in the Test Sequence and Test Assessment
          blocks and in Stateflow charts.
          See Also
          heaviside | ramp | square | triangle
5-16
                                            sawtooth
Topics
“Test Sequence and Assessment Syntax”
“Test Sequence Basics”
“Programmatically Create a Test Sequence”
“Signal Generation Functions”
Introduced in R2015a
                                               5-17
5   Language Operators
          square
          Square wave test signal
          Syntax
          square(x)
          Description
          square(x) creates a square wave with a period of 1 and range -1 to 1. In the interval 0 <= x < 1,
          square(x) returns 1 for 0 <= x < 0.5 and -1 for 0.5 <= x < 1.
          To specify the number of square wave cycles within a test step, use this operator with the elapsed
          time (et) operator.
          Examples
          Create a Square Wave
square(et/10)
          Tips
          square signal generation statements can be used in the Test Sequence and Test Assessment blocks
          and in Stateflow charts.
          See Also
          heaviside | ramp | sawtooth | triangle
5-18
                                            square
Topics
“Test Sequence and Assessment Syntax”
“Test Sequence Basics”
“Programmatically Create a Test Sequence”
“Signal Generation Functions”
Introduced in R2015a
                                             5-19
5   Language Operators
          t
          Elapsed time of simulation
          Syntax
          t(timeunits)
          Description
          t(timeunits) returns the simulation time in timeunits. If you omit timeunits, the elapsed time
          defaults to seconds. t is an alias for getSimulationTime and both are valid.
          • sec — seconds
          • msec — milliseconds
          • usec — microseconds
          Examples
          Obtain Simulation Time in Milliseconds
t(msec)
          Tips
          Elapsed simulation time ( t) statements can be used in the Test Sequence and Test Assessment blocks
          and in Stateflow charts.
          See Also
          after | before | duration | et
          Topics
          “Test Sequence and Assessment Syntax”
          “Test Sequence Basics”
          “Programmatically Create a Test Sequence”
          “Signal Generation Functions”
Introduced in R2015a
5-20
                                                                                                triangle
triangle
Triangle wave test signal
Syntax
triangle(x)
Description
triangle(x) creates a triangle wave with a period of 1 and range -1 to 1. In the interval 0 <= x <
0.5, triangle(x) increases. The difference between triangle waves and sawtooth waves is that a
triangle wave has equal rise and fall times.
To specify the number of triangle wave cycles within a test step, use this operator with the elapsed
time (et) operator.
Examples
Create a Triangle Wave
Tips
triangle signal generation statements can be used in the Test Sequence and Test Assessment
blocks and in Stateflow charts.
See Also
heaviside | ramp | sawtooth | square
                                                                                                  5-21
5   Language Operators
          Topics
          “Test Sequence and Assessment Syntax”
          “Test Sequence Basics”
          “Programmatically Create a Test Sequence”
          “Signal Generation Functions”
Introduced in R2015a
5-22
                                                                                                    verify
verify
Assess logical expression
Syntax
verify(expression)
verify(expression,errorMessage)
verify(expression,identifier,errorMessage)
Description
verify(expression) evaluates a scalar logical expression to true or false.
verify(expression,errorMessage) returns the specified error message string for the failed
verify statement. If you run the test in the Test Manager, the error message appears in the
simulation log. If you run the test outside the Test Manager, the message appears in the Diagnostic
Viewer.
Examples
If this verify statement fails, it returns an error message that lists the values of x, y, and z.
The result of this verify statement is prefaced by the label, TestReq1:bothGreater and, if the
test fails, the error message.
                                                                                                    5-23
5   Language Operators
The second step in the Scenario1 state of this Stateflow chart verifies that the target equals 60.
          Tips
          • You can use verify statements in Test Sequence and Test Assessment blocks and in Stateflow
            charts. A Stateflow license is required to use a chart. verify statements in charts are supported
            in the same locations, execution modes, and for the same code generation targets as the Test
            Sequence block.
          • You cannot use verify statements in:
             • Test Sequence blocks that use continuous-time updating. Test Sequence block data can depend
               on factors such as the solver step time. Continuous-time updating can cause differences in
               when block data and verify statements update, which can lead to unexpected verify
               statement results. If your model uses continuous time and you use verify statements in a Test
               Sequence or Test Assessment block, consider explicitly setting a discrete block sample time.
             • Moore, Mealy, Discrete Event, or continuous charts
             • Charts that use C as the action language
             • Bind actions in a chart
             • Transition or condition actions in a chart
             • MATLAB functions, graphical functions, or truth tables in a chart
             • MATLAB Function or Truth Table blocks
             • Rapid Accelerator mode simulations
5-24
                                                                                                 verify
   • Code generation targets other than Simulink Real-Time and HDL Verifier™
   • Standalone Stateflow charts
• If you use parallel test execution to run your tests, then you cannot use the Highlight in Model
  button for in the Test Manager to verify results.
• You cannot use verify as a condition immediately after when in a When decomposition because
  verify statements do not produce output. You can, however, use verify statements as actions in
  When decomposition steps. See “Assess a Model by Using When Decomposition”.
• When comparing floating-point data in verify statements, consider the precision limitations
  associated with floating-point numbers. If you need to use floating-point data, define a tolerance
  for the verification. For example, instead of verify(x == 5), verify x within a tolerance of
  0.001:
See Also
assert
Topics
“Assess Model Simulation Using verify Statements”
“Verify Multiple Conditions at a Time”
“Test Sequence and Assessment Syntax”
“Test Sequence Basics”
“Programmatically Create a Test Sequence”
“Signal Generation Functions”
Introduced in R2016a
5-25