forked from WEC-Sim/WEC-Sim
-
Notifications
You must be signed in to change notification settings - Fork 0
/
wecSimTest.m
96 lines (84 loc) · 3.57 KB
/
wecSimTest.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
function results = wecSimTest(options)
% wecSimTest runs WEC-Sim continuous integration testing suite.
%
% results = wecSimTest returns a matlab.unittest.TestResult object
%
% results = wecSimTest(..., NAME1, VALUE1, NAME2, VALUE2, ...) returns
% a matlab.unittest.TestResult object, depending on the values of the
% optional parameter name/value pairs. See Parameters below.
%
% Parameters
% ----------
% 'bemioTest' Run tests for BEMIO. Default is true.
%
% 'regressionTest' Run regression tests. These tests check if values
% have changed from a previous run. Default is true.
%
% 'passiveYawTest' Run passive yaw tests. Default is true.
%
% 'compilationTest' Run compilation tests. These tests do not check
% correctness of the results. Default is true.
%
% 'runFromSimTest' Run tests for execution of WECSim from Simulink.
% Default is true.
%
% 'rotationTest' Run rotation tests. Default is true.
%
% All tests run by default. If runtime is long, users may turn off the
% passive yaw test by calling the function as follows:
%
% results = wecSimTest('passiveYawTest', false)
%
% Users should also run the appropriate applications tests when
% creating a PR into the WEC-Sim repository.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Copyright 2014 the National Renewable Energy Laboratory and Sandia Corporation
%
% Licensed under the Apache License, Version 2.0 (the "License");
% you may not use this file except in compliance with the License.
% You may obtain a copy of the License at
%
% http://www.apache.org/licenses/LICENSE-2.0
%
% Unless required by applicable law or agreed to in writing, software
% distributed under the License is distributed on an "AS IS" BASIS,
% WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
% See the License for the specific language governing permissions and
% limitations under the License.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
arguments
options.bemioTest = true
options.regressionTest = true
options.passiveYawTest = true
options.compilationTest = true
options.runFromSimTest = true
options.rotationTest = true
end
import matlab.unittest.TestSuite
import matlab.unittest.Test
import matlab.unittest.TestRunner
import matlab.unittest.plugins.DiagnosticsRecordingPlugin
import matlab.unittest.plugins.CodeCoveragePlugin
suites = Test.empty();
if options.bemioTest
suites = [suites TestSuite.fromFile('tests/bemioTest.m')];
end
if options.regressionTest
suites = [suites TestSuite.fromFile('tests/regressionTest.m')];
end
if options.passiveYawTest
suites = [suites TestSuite.fromFile('tests/passiveYawTest.m')];
end
if options.runFromSimTest
suites = [suites TestSuite.fromFile('tests/runFromSimTest.m')];
end
if options.rotationTest
suites = [suites TestSuite.fromFile('tests/rotationTest.m')];
end
% Create TestRunner
runner = TestRunner.withTextOutput; % Contains TestRunProgressPlugin, DiagnosticsOutputPlugin
runner.addPlugin(DiagnosticsRecordingPlugin);
runner.addPlugin(CodeCoveragePlugin.forFolder('./source'));
% Run the tests
results = runner.run(suites);
end