gambas-source-code/main/lib/test/gb.test/.src/TestSuite/TestSuite.class
Christof Thalhofer 97e67b9481 gb.test use dot instead of colon in TAP output
[GB.TEST]
* OPT: Use dot instead of colon in TAP output for testmodule.testmethod
2021-03-06 14:14:58 +01:00

137 lines
3.6 KiB
Text

' Gambas class file
''' The TestSuite class represents a suite of different testcases to be run.
Property Read Tests As TestCase[]
Private $Tests As New TestCase[]
'' Runs all tests contained within the collection and collects the result in the Track parameter.
Public Sub Run()
Dim oTest As TestCase
Dim CurrentTestModule, LastTestModule As Class
Dim CurrentAction As String
Assert $Tests
$Tests.Sort()
Test.Plan($Tests.Count)
For Each oTest In $Tests
CurrentTestModule = oTest.TestModule
If LastTestModule Then
If LastTestModule <> CurrentTestModule Then
CurrentAction = LastTestModule.Name & ":TeardownTestModule"
StopTestModule(LastTestModule)
CurrentAction = CurrentTestModule.Name & ":SetupTestModule"
StartTestModule(CurrentTestModule)
Endif
Else
'Test.Note("-------------------- " & CurrentTestModule.Name)
CurrentAction = CurrentTestModule.Name & ":SetupTestModule"
StartTestModule(CurrentTestModule)
Endif
Test._Print(Null) 'better readability for humans
Test._Subtest(Subst$("&1.&2", oTest.TestModule.Name, oTest.Name))
'Debug oTest.Name
oTest.Run()
If Not Test._Finished Then Test._Finish()
LastTestModule = CurrentTestModule
Next
If LastTestModule Then
CurrentAction = LastTestModule.Name & ":TeardownTestModule"
StopTestModule(LastTestModule)
Endif
Catch
If Error.Where Begins "Test.BailOut." Then Quit 1
Test.BailOut("Test stopped with error \"" & Error.Text & "\" caused by " & CurrentAction & " in " & Error.Where & ".")
End Sub
Private Sub StartTestModule(TestModule As Class)
If TestModule.Symbols.Exist("_Setup", gb.IgnoreCase) Then
Test._InSetup = True
Object.Call(TestModule, "_Setup")
Test._InSetup = False
Endif
End
Private Sub StopTestModule(TestModule As Class)
If TestModule.Symbols.Exist("_Teardown", gb.IgnoreCase) Then
Test._InSetup = True
Object.Call(TestModule, "_Teardown")
Test._InSetup = False
Endif
End
'' Create a new test case and add it to the suite.
Public Function AddTestCase(sName As String, TestModule As Class)
Dim test As TestCase
Assert sName <> Null
Assert TestModule
test = New TestCase(sName, TestModule)
Assert $Tests
If Not $Tests.Exist(test) Then
$Tests.Add(test)
Endif
End
Static Public Function GetTestsFromTestModule(TestModule As Class) As String[]
Dim sSymbol As String
Dim NoTestSymbols As String[] = ["_Setup", "_SetupEach", "_Teardown", "_TeardownEach", "Plan"]
Dim asTests As New String[]
Assert TestModule
For Each sSymbol In TestModule.Symbols
If Not NoTestSymbols.Exist(sSymbol, gb.IgnoreCase) And If InStr(sSymbol, "_") = 0 Then
asTests.Add(sSymbol)
Endif
Next
Return asTests
End
'' Create all test cases that are contained in the specified testmodule and add them to the suite.
Public Function AddAllTestCases(TestModule As Class)
Dim asTests As String[]
Dim i As Integer
Dim NameProcedure As String
Assert TestModule
asTests = GetTestsFromTestModule(TestModule)
asTests.Sort
'Assert asTests.Count > 0 Error "Failed: No tests in " & TestModule.Name
If asTests.Count = 0 Then
Assert.Todo("No tests in " & TestModule.Name)
Endif
For i = 0 To asTests.Count - 1
NameProcedure = CStr(asTests[i])
AddTestCase(NameProcedure, TestModule)
Next
End
Private Function Tests_Read() As TestCase[]
Return $Tests
End