09da14aa68
[GB.TEST] *NEW: plan selftests *NEW: forbid assertions in _Setup.. and _Teardown.. to ensure plan is always valid
136 lines
3.5 KiB
Text
136 lines
3.5 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
|
|
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") Then
|
|
Test._InSetup = True
|
|
Object.Call(TestModule, "_Setup")
|
|
Test._InSetup = False
|
|
Endif
|
|
|
|
End
|
|
|
|
Private Sub StopTestModule(TestModule As Class)
|
|
|
|
If TestModule.Symbols.Exist("_Teardown") 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
|