-
-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathSempare.Template.Tester.dpr
110 lines (105 loc) · 6.17 KB
/
Sempare.Template.Tester.dpr
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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
(*%*************************************************************************************************
* ___ *
* / __| ___ _ __ _ __ __ _ _ _ ___ *
* \__ \ / -_) | ' \ | '_ \ / _` | | '_| / -_) *
* |___/ \___| |_|_|_| | .__/ \__,_| |_| \___| *
* |_| *
****************************************************************************************************
* *
* Sempare Template Engine *
* *
* *
* https://github.com/sempare/sempare-delphi-template-engine *
****************************************************************************************************
* *
* Copyright (c) 2019-2024 Sempare Limited *
* *
* Contact: [email protected] *
* *
* Licensed under the Apache Version 2.0 or the Sempare Commercial License *
* You may not use this file except in compliance with one of these Licenses. *
* You may obtain a copy of the Licenses at *
* *
* https://www.apache.org/licenses/LICENSE-2.0 *
* https://github.com/sempare/sempare-delphi-template-engine/blob/master/docs/commercial.license.md *
* *
* Unless required by applicable law or agreed to in writing, software *
* distributed under the Licenses 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. *
* *
*************************************************************************************************%*)
program Sempare.Template.Tester;
{$IFNDEF TESTINSIGHT}
{$APPTYPE CONSOLE}
{$ENDIF}{$STRONGLINKTYPES ON}
uses
System.SysUtils,
{$IFDEF TESTINSIGHT}
TestInsight.DUnitX,
{$ENDIF }
DUnitX.Loggers.Console,
DUnitX.Loggers.Xml.JUnit,
DUnitX.TestFramework,
Sempare.Template.TestIf in 'tests\Sempare.Template.TestIf.pas',
Sempare.Template.TestContext in 'tests\Sempare.Template.TestContext.pas',
Sempare.Template.TestNewLineOption in 'tests\Sempare.Template.TestNewLineOption.pas',
Sempare.Template.TestCall in 'tests\Sempare.Template.TestCall.pas',
Sempare.Template.TestArr in 'tests\Sempare.Template.TestArr.pas',
Sempare.Template.TestDictionary in 'tests\Sempare.Template.TestDictionary.pas',
Sempare.Template.TestJson in 'tests\Sempare.Template.TestJson.pas',
Sempare.Template.TestAssign in 'tests\Sempare.Template.TestAssign.pas',
Sempare.Template.TestExpr in 'tests\Sempare.Template.TestExpr.pas',
Sempare.Template.TestInclude in 'tests\Sempare.Template.TestInclude.pas',
Sempare.Template.TestDeref in 'tests\Sempare.Template.TestDeref.pas',
Sempare.Template.TestFor in 'tests\Sempare.Template.TestFor.pas',
Sempare.Template.Test in 'tests\Sempare.Template.Test.pas',
Sempare.Template.TestStackFrame in 'tests\Sempare.Template.TestStackFrame.pas',
Sempare.Template.TestLexer in 'tests\Sempare.Template.TestLexer.pas',
Sempare.Template.TestFunctions in 'tests\Sempare.Template.TestFunctions.pas',
Sempare.Template.TestVirtualMethods in 'tests\Sempare.Template.TestVirtualMethods.pas',
Sempare.Template.TestMap in 'tests\Sempare.Template.TestMap.pas';
var
runner: ITestRunner;
results: IRunResults;
logger: ITestLogger;
nunitLogger: ITestLogger;
begin
ReportMemoryLeaksOnShutdown := true;
{$IFDEF TESTINSIGHT}
TestInsight.DUnitX.RunRegisteredTests;
exit;
{$ENDIF}
try
//Check command line options, will exit if invalid
TDUnitX.CheckCommandLine;
//Create the test runner
runner := TDUnitX.CreateRunner;
//Tell the runner to use RTTI to find Fixtures
runner.UseRTTI := True;
//tell the runner how we will log things
//Log to the console window
logger := TDUnitXConsoleLogger.Create(true);
runner.AddLogger(logger);
//Generate an NUnit compatible XML File
nunitLogger := TDUnitXXMLJUnitFileLogger.Create(TDUnitX.Options.XMLOutputFile);
runner.AddLogger(nunitLogger);
runner.FailsOnNoAsserts := False; //When true, Assertions must be made during tests;
//Run tests
results := runner.Execute;
if not results.AllPassed then
System.ExitCode := EXIT_ERRORS;
{$IFNDEF CI}
//We don't want this happening when running under CI.
if TDUnitX.Options.ExitBehavior = TDUnitXExitBehavior.Pause then
begin
System.Write('Done.. press <Enter> key to quit.');
System.Readln;
end;
{$ENDIF}
except
on E: Exception do
System.Writeln(E.ClassName, ': ', E.Message);
end;
end.