12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658 |
- {
- This file is part of the Free Component Library (FCL)
- Copyright (c) 2004 by Dean Zobec, Michael Van Canneyt
- Port to Free Pascal of the JUnit framework.
- See the file COPYING.FPC, included in this distribution,
- for details about the copyright.
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
- **********************************************************************}
- unit fpcunit;
- {$mode objfpc}
- {$h+}
- interface
- { Uncomment this define to remove the DUnit compatibility interface. }
- {$DEFINE DUnit}
- uses
- SysUtils
- ,Classes
- ;
- { This lets us use a single include file for both the Interface and
- Implementation sections. }
- {$define read_interface}
- {$undef read_implementation}
- type
- EAssertionFailedError = class(Exception)
- constructor Create; overload;
- constructor Create(const msg :string); overload;
- end;
- EIgnoredTest = class(EAssertionFailedError);
- TTestStep = (stSetUp, stRunTest, stTearDown, stNothing);
- TRunMethod = procedure of object;
- TTestResult = class;
- TTestSuite = class;
- {$M+}
- { TTest }
- TTest = class(TObject)
- private
- protected
- FLastStep: TTestStep;
- function GetTestName: string; virtual;
- function GetTestSuiteName: string; virtual;
- function GetEnableIgnores: boolean; virtual;
- procedure SetTestSuiteName(const aName: string); virtual; abstract;
- procedure SetEnableIgnores(Value: boolean); virtual; abstract;
- public
- function CountTestCases: integer; virtual;
- Function GetChildTestCount : Integer; virtual;
- Function GetChildTest(AIndex : Integer) : TTest; virtual;
- function FindChildTest(const AName: String): TTest;
- Function FindTest(Const AName : String) : TTest;
- procedure Run(AResult: TTestResult); virtual;
- procedure Ignore(const AMessage: string);
- published
- property TestName: string read GetTestName;
- property TestSuiteName: string read GetTestSuiteName write SetTestSuiteName;
- property LastStep: TTestStep read FLastStep;
- property EnableIgnores: boolean read GetEnableIgnores write SetEnableIgnores;
- end;
- {$M-}
- { TAssert }
- TAssert = class(TTest)
- protected
- Class var AssertCount : Integer;
- public
- class procedure Fail(const AMessage: string; AErrorAddrs: Pointer = nil);
- class procedure Fail(const AFmt: string; Args : Array of const; AErrorAddrs: Pointer = nil);
- class procedure FailEquals(const expected, actual: string; const ErrorMsg: string = ''; AErrorAddrs: Pointer = nil);
- class procedure FailNotEquals(const expected, actual: string; const ErrorMsg: string = ''; AErrorAddrs: Pointer = nil);
- class procedure AssertTrue(const AMessage: string; ACondition: boolean; AErrorAddrs: Pointer = nil); overload;
- class procedure AssertTrue(ACondition: boolean); overload;
- class procedure AssertFalse(const AMessage: string; ACondition: boolean; AErrorAddrs: Pointer = nil); overload;
- class procedure AssertFalse(ACondition: boolean); overload;
- class procedure AssertEquals(const AMessage: string; Expected, Actual: string); overload;
- class procedure AssertEquals(Expected, Actual: string); overload;
- class procedure AssertEquals(const AMessage: string; Expected, Actual: UnicodeString); overload;
- class procedure AssertEquals(Expected, Actual: UnicodeString); overload;
- class procedure AssertEquals(const AMessage: string; Expected, Actual: integer); overload;
- class procedure AssertEquals(Expected, Actual: integer); overload;
- class procedure AssertEquals(const AMessage: string; Expected, Actual: int64); overload;
- class procedure AssertEquals(Expected, Actual: int64); overload;
- class procedure AssertEquals(const AMessage: string; Expected, Actual: QWord); overload;
- class procedure AssertEquals(Expected, Actual: QWord); overload;
- class procedure AssertEquals(const AMessage: string; Expected, Actual: currency); overload;
- class procedure AssertEquals(Expected, Actual: currency); overload;
- class procedure AssertEquals(const AMessage: string; Expected, Actual, Delta: double); overload;
- class procedure AssertEquals(Expected, Actual, Delta: double); overload;
- class procedure AssertEquals(const AMessage: string; Expected, Actual: boolean); overload;
- class procedure AssertEquals(Expected, Actual: boolean); overload;
- class procedure AssertEquals(const AMessage: string; Expected, Actual: char); overload;
- class procedure AssertEquals(Expected, Actual: char); overload;
- class procedure AssertEquals(const AMessage: string; Expected, Actual: TClass); overload;
- class procedure AssertEquals(Expected, Actual: TClass); overload;
- class procedure AssertSame(const AMessage: string; Expected, Actual: TObject); overload;
- class procedure AssertSame(Expected, Actual: TObject); overload;
- class procedure AssertSame(const AMessage: string; Expected, Actual: Pointer); overload;
- class procedure AssertSame(Expected, Actual: Pointer); overload;
- class procedure AssertNotSame(const AMessage: string; Expected, Actual: TObject); overload;
- class procedure AssertNotSame(Expected, Actual: TObject); overload;
- class procedure AssertNotSame(const AMessage: string; Expected, Actual: Pointer); overload;
- class procedure AssertNotSame(Expected, Actual: Pointer); overload;
- class procedure AssertNotNull(const AMessage: string; AObject: TObject); overload;
- class procedure AssertNotNull(AObject: TObject); overload;
- class procedure AssertNotNullIntf(const AMessage: string; AInterface: IInterface); overload;
- class procedure AssertNotNullIntf(AInterface: IInterface); overload;
- class procedure AssertNotNull(const AMessage: string; APointer: Pointer); overload;
- class procedure AssertNotNull(APointer: Pointer); overload;
- class procedure AssertNull(const AMessage: string; AObject: TObject); overload;
- class procedure AssertNull(AObject: TObject); overload;
- class procedure AssertNullIntf(const AMessage: string; AInterface: IInterface); overload;
- class procedure AssertNullIntf(AInterface: IInterface); overload;
- class procedure AssertNull(const AMessage: string; APointer: Pointer); overload;
- class procedure AssertNull(APointer: Pointer); overload;
- class procedure AssertNotNull(const AMessage, AString: string); overload;
- class procedure AssertNotNull(const AString: string); overload;
- class procedure AssertException(const AMessage: string; AExceptionClass: ExceptClass; AMethod: TRunMethod;AExceptionMessage : String = ''; AExceptionContext : Integer = 0; AErrorAddr : Pointer = Nil); overload;
- class procedure AssertException(AExceptionClass: ExceptClass; AMethod: TRunMethod;AExceptionMessage : String = ''; AExceptionContext : Integer = 0); overload;
- {$IFDEF DUnit}
- {$I DUnitCompatibleInterface.inc}
- {$ENDIF DUnit}
- end;
- TTestFailure = class(TObject)
- private
- FTestName: string;
- FTestSuiteName: string;
- FLineNumber: longint;
- FFailedMethodName: string;
- FRaisedExceptionClass: TClass;
- FRaisedExceptionMessage: string;
- FSourceUnitName: string;
- FThrownExceptionAddress: Pointer;
- FTestLastStep: TTestStep;
- function GetAsString: string;
- function GetExceptionMessage: string;
- function GetIsFailure: boolean;
- function GetIsIgnoredTest: boolean;
- function GetExceptionClassName: string;
- function GetLocationInfo: string;
- procedure SetTestLastStep(const Value: TTestStep);
- public
- constructor CreateFailure(ATest: TTest; E: Exception; LastStep: TTestStep; ThrownExceptionAddrs: pointer = nil);
- property ExceptionClass: TClass read FRaisedExceptionClass;
- published
- property AsString: string read GetAsString;
- property IsFailure: boolean read GetIsFailure;
- property IsIgnoredTest: boolean read GetIsIgnoredTest;
- property ExceptionMessage: string read GetExceptionMessage;
- property ExceptionClassName: string read GetExceptionClassName;
- property SourceUnitName: string read FSourceUnitName write FSourceUnitName;
- property LineNumber: longint read FLineNumber write FLineNumber;
- property LocationInfo: string read GetLocationInfo;
- property FailedMethodName: string read FFailedMethodName write FFailedMethodName;
- property TestLastStep: TTestStep read FTestLastStep write SetTestLastStep;
- end;
- ITestListener = interface
- ['{0CE9D3AE-882A-D811-9401-ADEB5E4C7FC1}']
- procedure AddFailure(ATest: TTest; AFailure: TTestFailure);
- procedure AddError(ATest: TTest; AError: TTestFailure);
- procedure StartTest(ATest: TTest);
- procedure EndTest(ATest: TTest);
- procedure StartTestSuite(ATestSuite: TTestSuite);
- procedure EndTestSuite(ATestSuite: TTestSuite);
- end;
- { TTestCase }
- TTestCase = class(TAssert)
- private
- FName: string;
- FTestSuiteName: string;
- FEnableIgnores: boolean;
- FExpectedExceptionFailMessage : String;
- FExpectedException : TClass;
- FExpectedExceptionMessage: String;
- FExpectedExceptionContext: Integer;
- FExpectedExceptionCaller : Pointer;
- protected
- function CreateResult: TTestResult; virtual;
- procedure SetUp; virtual;
- procedure TearDown; virtual;
- procedure RunTest; virtual;
- function GetTestName: string; override;
- function GetTestSuiteName: string; override;
- function GetEnableIgnores: boolean; override;
- procedure SetTestSuiteName(const aName: string); override;
- procedure SetTestName(const Value: string); virtual;
- procedure SetEnableIgnores(Value: boolean); override;
- procedure RunBare; virtual;
- Class function SingleInstanceForSuite : Boolean; virtual;
- Public
- Class Var CheckAssertCalled : Boolean;
- public
- constructor Create; virtual;
- constructor CreateWith(const ATestName: string; const ATestSuiteName: string); virtual;
- constructor CreateWithName(const AName: string); virtual;
- procedure ExpectException(AExceptionClass: TClass; AExceptionMessage: string=''; AExceptionHelpContext: Integer=0);
- procedure ExpectException(const Msg: String; AExceptionClass: TClass; AExceptionMessage: string=''; AExceptionHelpContext: Integer=0);
- function CountTestCases: integer; override;
- function CreateResultAndRun: TTestResult; virtual;
- procedure Run(AResult: TTestResult); override;
- function AsString: string;
- property TestSuiteName: string read GetTestSuiteName write SetTestSuiteName;
- Property ExpectedExceptionFailMessage : String Read FExpectedExceptionFailMessage;
- Property ExpectedException : TClass Read FExpectedException;
- Property ExpectedExceptionMessage : String Read FExpectedExceptionMessage;
- Property ExpectedExceptionContext: Integer Read FExpectedExceptionContext;
- published
- property TestName: string read GetTestName write SetTestName;
- end;
- TTestCaseClass = class of TTestCase;
- { TTestSuite }
- TTestSuite = class(TTest)
- private
- FOwnsTests: Boolean;
- FTests: TFPList;
- FName: string;
- FTestSuiteName: string;
- FEnableIgnores: boolean;
- procedure SetOwnsTests(AValue: Boolean);
- protected
- Procedure SetOwnTestOnTests(AValue: Boolean);
- Function DoAddTest(ATest : TTest) : Integer;
- function GetTestName: string; override;
- function GetTestSuiteName: string; override;
- function GetEnableIgnores: boolean; override;
- procedure SetTestSuiteName(const aName: string); override;
- procedure SetTestName(const Value: string); virtual;
- procedure SetEnableIgnores(Value: boolean); override;
- property OwnsTests : Boolean Read FOwnsTests Write SetOwnsTests;
- public
- constructor Create(AClass: TClass; AName: string); reintroduce; overload; virtual;
- constructor Create(AClass: TClass); reintroduce; overload; virtual;
- constructor Create(AClassArray: Array of TClass); reintroduce; overload; virtual;
- constructor Create(AName: string); reintroduce; overload; virtual;
- constructor Create; reintroduce; overload; virtual;
- destructor Destroy; override;
- function CountTestCases: integer; override;
- Function GetChildTestCount : Integer; override;
- Function GetChildTest(AIndex : Integer) : TTest; override;
- procedure Run(AResult: TTestResult); override;
- procedure RunTest(ATest: TTest; AResult: TTestResult); virtual;
- procedure AddTest(ATest: TTest); overload; virtual;
- procedure AddTestSuiteFromClass(ATestClass: TClass); virtual;
- class function Warning(const aMessage: string): TTestCase;
- property Test[Index: integer]: TTest read GetChildTest; default;
- Property ChildTestCount : Integer Read GetChildTestCount;
- property TestSuiteName: string read GetTestSuiteName write SetTestSuiteName;
- property TestName: string read GetTestName write SetTestName;
- // Only for backwards compatibility. Use Test and ChildTestCount.
- property Tests: TFPList read FTests; deprecated;
- end;
-
- TProtect = procedure(aTest: TTest; aResult: TTestResult);
- { TTestResult }
- TTestResult = class(TObject)
- protected
- FRunTests: integer;
- FFailures: TFPList;
- FIgnoredTests: TFPList;
- FErrors: TFPList;
- FListeners: TFPList;
- FSkippedTests: TFPList;
- FStartingTime: TDateTime;
- function GetNumErrors: integer;
- function GetNumFailures: integer;
- function GetNumIgnoredTests: integer;
- function GetNumSkipped: integer;
- public
- constructor Create; virtual;
- destructor Destroy; override;
- procedure ClearErrorLists;
- procedure StartTest(ATest: TTest);
- procedure AddFailure(ATest: TTest; E: EAssertionFailedError; aFailureList: TFPList; AThrownExceptionAdrs: Pointer);
- procedure AddError(ATest: TTest; E: Exception; AThrownExceptionAdrs: Pointer);
- procedure EndTest(ATest: TTest);
- procedure AddListener(AListener: ITestListener);
- procedure RemoveListener(AListener: ITestListener);
- procedure Run(ATestCase: TTestCase);
- procedure RunProtected(ATestCase: TTest; protect: TProtect);
- function WasSuccessful: boolean;
- function SkipTest(ATestCase: TTestCase): boolean;
- procedure AddToSkipList(ATestCase: TTestCase);
- procedure RemoveFromSkipList(ATestCase: TTestCase);
- procedure StartTestSuite(ATestSuite: TTestSuite);
- procedure EndTestSuite(ATestSuite: TTestSuite);
- published
- property Listeners: TFPList read FListeners;
- property Failures: TFPList read FFailures;
- property IgnoredTests: TFPList read FIgnoredTests;
- property Errors: TFPList read FErrors;
- property RunTests: integer read FRunTests;
- property NumberOfErrors: integer read GetNumErrors;
- property NumberOfFailures: integer read GetNumFailures;
- property NumberOfIgnoredTests: integer read GetNumIgnoredTests;
- property NumberOfSkippedTests: integer read GetNumSkipped;
- property StartingTime: TDateTime read FStartingTime;
- end;
- function ComparisonMsg(const aExpected: string; const aActual: string; const aCheckEqual: boolean=true): string; overload;
- function ComparisonMsg(const aExpected: UnicodeString; const aActual: UnicodeString; const aCheckEqual: boolean=true): Unicodestring; overload;
- function ComparisonMsg(const aMsg: string; const aExpected: string; const aActual: string; const aCheckEqual: boolean=true): string; overload;
- // Made public for 3rd party developers extending TTestCase with new AssertXXX methods
- function CallerAddr: Pointer;
-
- Resourcestring
- SCompare = ' expected: <%s> but was: <%s>';
- SCompareNotEqual = ' expected: not equal to <%s> but was: <%s>';
- SExpectedNotSame = 'expected not same';
- SExceptionCompare = 'Exception %s expected but %s was raised';
- SExceptionMessageCompare = 'Exception raised but exception property Message differs: ';
- SExceptionHelpContextCompare = 'Exception raised but exception property HelpContext differs: ';
- SMethodNotFound = 'Method <%s> not found';
- SNoValidInheritance = ' does not inherit from TTestCase';
- SNoValidTests = 'No valid tests found in ';
- SNoException = 'no exception';
- SAssertNotCalled = 'Assert not called during test.';
-
- implementation
- uses
- testutils;
- Const
- sExpectedButWasFmt = 'Expected:' + LineEnding + '"%s"' + LineEnding + 'But was:' + LineEnding + '"%s"';
- sExpectedButWasAndMessageFmt = '%s' + LineEnding + sExpectedButWasFmt;
- { This lets us use a single include file for both the Interface and
- Implementation sections. }
- {$undef read_interface}
- {$define read_implementation}
- function CallerAddr: Pointer;
- Var
- address: CodePointer;
- nframes: sizeint;
- begin
- nframes:=CaptureBacktrace(2,1,@address);
- if nframes=1 then
- result:=address
- else
- result:=nil;
- end;
- function AddrsToStr(Addrs: Pointer): string;
- begin
- if PtrUInt(Addrs) > 0 then
- Result := '$'+Format('%p', [Addrs])
- else
- Result := 'n/a';
- end;
- function PointerToLocationInfo(Addrs: Pointer): string;
- begin
- Result := BackTraceStrFunc(Addrs);
- if Trim(Result) = '' then
- Result := AddrsToStr(Addrs) + ' <no map file>';
- end;
- // Get the ClassName of C
- function GetN(C : TClass) : string;
- begin
- if C=Nil then
- Result:='<NIL>'
- else
- Result:=C.ClassName;
- end;
- type
- TTestWarning = class(TTestCase)
- private
- FMessage: String;
- protected
- procedure RunTest; override;
- end;
- procedure TTestWarning.RunTest;
- begin
- Fail(FMessage);
- end;
- function ComparisonMsg(const aExpected: string; const aActual: string; const aCheckEqual: boolean=true): string;
- // aCheckEqual=false gives the error message if the test does *not* expect the results to be the same.
- begin
- if aCheckEqual then
- Result := format(SCompare, [aExpected, aActual])
- else {check unequal requires opposite error message}
- Result := format(SCompareNotEqual, [aExpected, aActual]);
- end;
- function ComparisonMsg(const aExpected: Unicodestring; const aActual: Unicodestring; const aCheckEqual: boolean=true): Unicodestring;
- // aCheckEqual=false gives the error message if the test does *not* expect the results to be the same.
- begin
- if aCheckEqual then
- Result := unicodeformat(SCompare, [aExpected, aActual])
- else {check unequal requires opposite error message}
- Result := unicodeformat(SCompareNotEqual, [aExpected, aActual]);
- end;
- function ComparisonMsg(const aMsg: string; const aExpected: string; const aActual: string; const aCheckEqual: boolean): string;
- begin
- Result := '"' + aMsg + '"' + ComparisonMsg(aExpected, aActual, aCheckEqual);
- end;
- constructor EAssertionFailedError.Create;
- begin
- inherited Create('');
- end;
- constructor EAssertionFailedError.Create(const msg: string);
- begin
- inherited Create(msg);
- end;
- constructor TTestFailure.CreateFailure(ATest: TTest; E: Exception; LastStep: TTestStep; ThrownExceptionAddrs: pointer);
- begin
- inherited Create;
- FTestName := ATest.GetTestName;
- FTestSuiteName := ATest.GetTestSuiteName;
- FRaisedExceptionClass := E.ClassType;
- FRaisedExceptionMessage := E.Message;
- FThrownExceptionAddress := ThrownExceptionAddrs;
- FTestLastStep := LastStep;
- end;
- function TTestFailure.GetAsString: string;
- var
- s: string;
- begin
- if FTestSuiteName <> '' then
- s := FTestSuiteName + '.'
- else
- s := '';
- Result := s + FTestName + ': ' + FRaisedExceptionMessage;
- end;
- function TTestFailure.GetExceptionClassName: string;
- begin
- if Assigned(FRaisedExceptionClass) then
- Result := FRaisedExceptionClass.ClassName
- else
- Result := '<NIL>'
- end;
- function TTestFailure.GetLocationInfo: string;
- begin
- Result := PointerToLocationInfo(FThrownExceptionAddress);
- end;
- function TTestFailure.GetExceptionMessage: string;
- begin
- Result := FRaisedExceptionMessage;
- if TestLastStep = stSetUp then
- Result := '[SETUP] ' + Result
- else if TestLastStep = stTearDown then
- Result := '[TEARDOWN] ' + Result;
- end;
- function TTestFailure.GetIsFailure: boolean;
- begin
- Result := FRaisedExceptionClass.InheritsFrom(EAssertionFailedError);
- end;
- function TTestFailure.GetIsIgnoredTest: boolean;
- begin
- Result := FRaisedExceptionClass.InheritsFrom(EIgnoredTest);
- end;
- procedure TTestFailure.SetTestLastStep(const Value: TTestStep);
- begin
- FTestLastStep := Value;
- end;
- { TTest}
- function TTest.GetTestName: string;
- begin
- Result := 'TTest';
- end;
- function TTest.GetTestSuiteName: string;
- begin
- Result := 'TTest';
- end;
- function TTest.CountTestCases: integer;
- begin
- Result := 0;
- end;
- function TTest.GetChildTestCount: Integer;
- begin
- Result:=0;
- end;
- function TTest.GetChildTest(AIndex: Integer): TTest;
- begin
- Result:=Nil;
- end;
- function TTest.FindChildTest(const AName: String): TTest;
- Var
- I : Integer;
- begin
- Result:=Nil;
- I:=GetChildTestCount-1;
- While (Result=Nil) and (I>=0) do
- begin
- Result:=GetChildTest(I);
- if CompareText(Result.TestName,AName)<>0 then
- Result:=Nil;
- Dec(I);
- end;
- end;
- function TTest.FindTest(const AName: String): TTest;
- Var
- S : String;
- I,P : Integer;
- begin
- Result:=Nil;
- S:=AName;
- if S='' then exit;
- P:=Pos('.',S);
- If (P=0) then
- P:=Length(S)+1;
- Result:=FindChildTest(Copy(S,1,P-1));
- if (Result<>Nil) then
- begin
- Delete(S,1,P);
- If (S<>'') then
- Result:=Result.FindTest(S);
- end
- else
- begin
- P:=GetChildTestCount;
- I:=0;
- While (Result=Nil) and (I<P) do
- begin
- Result:=GetChildTest(I).FindTest(Aname);
- Inc(I);
- end;
- end;
- end;
- function TTest.GetEnableIgnores: boolean;
- begin
- Result := True;
- end;
- procedure TTest.Run(AResult: TTestResult);
- begin
- { do nothing }
- end;
- procedure TTest.Ignore(const AMessage: string);
- begin
- if EnableIgnores then raise EIgnoredTest.Create(AMessage);
- end;
- { TAssert }
- class procedure TAssert.Fail(const AMessage: string; AErrorAddrs: Pointer);
- begin
- Inc(AssertCount);
- if AErrorAddrs = nil then
- raise EAssertionFailedError.Create(AMessage) at CallerAddr
- else
- raise EAssertionFailedError.Create(AMessage) at AErrorAddrs;
- end;
- class procedure TAssert.Fail(const AFmt: string; Args: array of const; AErrorAddrs: Pointer = nil);
- begin
- Inc(AssertCount);
- if AErrorAddrs = nil then
- raise EAssertionFailedError.CreateFmt(AFmt,Args) at CallerAddr
- else
- raise EAssertionFailedError.CreateFmt(AFmt,Args) at AErrorAddrs;
- end;
- class procedure TAssert.FailEquals(const expected, actual: string; const ErrorMsg: string; AErrorAddrs: Pointer);
- begin
- Fail(EqualsErrorMessage(expected, actual, ErrorMsg), AErrorAddrs);
- end;
- class procedure TAssert.FailNotEquals(const expected, actual: string; const ErrorMsg: string; AErrorAddrs: Pointer);
- begin
- Fail(NotEqualsErrorMessage(expected, actual, ErrorMsg), AErrorAddrs);
- end;
- class procedure TAssert.AssertTrue(const AMessage: string; ACondition: boolean; AErrorAddrs: Pointer = nil);
- begin
- if AErrorAddrs=Nil then
- AErrorAddrs:=CallerAddr;
- if (not ACondition) then
- Fail(AMessage,AErrorAddrs)
- else
- Inc(AssertCount); // Fail will increae AssertCount
- end;
- class procedure TAssert.AssertTrue(ACondition: boolean);
- begin
- AssertTrue('', ACondition,CallerAddr);
- end;
- class procedure TAssert.AssertFalse(const AMessage: string; ACondition: boolean; AErrorAddrs: Pointer = nil
- );
- begin
- if AErrorAddrs=Nil then
- AErrorAddrs:=CallerAddr;
- AssertTrue(AMessage, not ACondition,AErrorAddrs);
- end;
- class procedure TAssert.AssertFalse(ACondition: boolean);
- begin
- AssertFalse('', ACondition,CallerAddr);
- end;
- class procedure TAssert.AssertEquals(const AMessage: string; Expected, Actual: string);
- begin
- AssertTrue(ComparisonMsg(AMessage ,Expected, Actual), Expected=Actual,CallerAddr);
- end;
- class procedure TAssert.AssertEquals(Expected, Actual: string);
- begin
- AssertTrue(ComparisonMsg(Expected, Actual), Expected=Actual,CallerAddr);
- end;
- class procedure TAssert.AssertEquals(const AMessage: string; Expected, Actual: Unicodestring);
- begin
- AssertTrue(ComparisonMsg(AMessage ,Expected, Actual), Expected=Actual,CallerAddr);
- end;
- class procedure TAssert.AssertEquals(Expected, Actual: Unicodestring);
- begin
- AssertTrue(ComparisonMsg(Expected, Actual), Expected=Actual,CallerAddr);
- end;
- class procedure TAssert.AssertNotNull(const AString: string);
- begin
- AssertNotNull('', AString);
- end;
- class procedure TAssert.AssertEquals(const AMessage: string; Expected, Actual: integer);
- begin
- AssertTrue(ComparisonMsg(AMessage,IntToStr(Expected), IntToStr(Actual)), Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertEquals(Expected, Actual: integer);
- begin
- AssertTrue(ComparisonMsg(IntToStr(Expected), IntToStr(Actual)), Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertEquals(const AMessage: string; Expected, Actual: int64);
- begin
- AssertTrue(ComparisonMsg(AMessage,IntToStr(Expected), IntToStr(Actual)), Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertEquals(Expected, Actual: int64);
- begin
- AssertTrue(ComparisonMsg(IntToStr(Expected), IntToStr(Actual)), Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertEquals(const AMessage: string; Expected, Actual: QWord);
- begin
- AssertTrue(ComparisonMsg(AMessage,IntToStr(Expected), IntToStr(Actual)), Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertEquals(Expected, Actual: QWord);
- begin
- AssertTrue(ComparisonMsg(IntToStr(Expected), IntToStr(Actual)), Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertEquals(const AMessage: string; Expected, Actual: currency);
- begin
- AssertTrue(ComparisonMsg(AMessage,FloatToStr(Expected), FloatToStr(Actual)), Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertEquals(Expected, Actual: currency);
- begin
- AssertTrue(ComparisonMsg(FloatToStr(Expected), FloatToStr(Actual)), Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertEquals(const AMessage: string; Expected, Actual, Delta: double);
- begin
- AssertTrue(ComparisonMsg(AMessage,FloatToStr(Expected),FloatToStr(Actual)),
- (Abs(Expected - Actual) <= Delta),CallerAddr);
- end;
- class procedure TAssert.AssertEquals(Expected, Actual, Delta: double);
- begin
- AssertTrue(ComparisonMsg(FloatToStr(Expected),FloatToStr(Actual)),
- (Abs(Expected - Actual) <= Delta),CallerAddr);
- end;
- class procedure TAssert.AssertNotNull(const AMessage, AString: string);
- begin
- AssertTrue(AMessage, AString <> '',CallerAddr);
- end;
- class procedure TAssert.AssertEquals(const AMessage: string; Expected, Actual: boolean);
- begin
- AssertTrue(ComparisonMsg(AMessage,BoolToStr(Expected, true), BoolToStr(Actual, true)), Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertEquals(Expected, Actual: boolean);
- begin
- AssertTrue(ComparisonMsg(BoolToStr(Expected, true), BoolToStr(Actual, true)), Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertEquals(const AMessage: string; Expected, Actual: char);
- begin
- AssertTrue(ComparisonMsg(AMessage,Expected, Actual), Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertEquals(Expected, Actual: char);
- begin
- AssertTrue(ComparisonMsg(Expected, Actual), Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertEquals(const AMessage: string; Expected, Actual: TClass);
- begin
- AssertTrue(ComparisonMsg(AMessage,GetN(Expected), GetN(Actual)), Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertEquals(Expected, Actual: TClass);
- begin
- AssertTrue(ComparisonMsg(GetN(Expected), GetN(Actual)), Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertSame(const AMessage: string; Expected, Actual: TObject);
- begin
- AssertTrue(ComparisonMsg(AMessage,IntToStr(PtrInt(Expected)), IntToStr(PtrInt(Actual))), Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertSame(Expected, Actual: TObject);
- begin
- AssertTrue(ComparisonMsg(IntToStr(PtrInt(Expected)), IntToStr(PtrInt(Actual))), Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertSame(const AMessage: string; Expected, Actual: Pointer);
- begin
- AssertTrue(ComparisonMsg(AMessage,IntToStr(PtrInt(Expected)), IntToStr(PtrInt(Actual))), Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertSame(Expected, Actual: Pointer);
- begin
- AssertTrue(ComparisonMsg(IntToStr(PtrInt(Expected)), IntToStr(PtrInt(Actual))), Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertNotSame(const AMessage: string; Expected, Actual: TObject);
- begin
- AssertFalse('"' + aMessage + '"' + SExpectedNotSame, Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertNotSame(Expected, Actual: TObject);
- begin
- AssertFalse(SExpectedNotSame, Expected = Actual);
- end;
- class procedure TAssert.AssertNotSame(const AMessage: string; Expected, Actual: Pointer);
- begin
- AssertFalse('"' + aMessage + '"' + SExpectedNotSame, Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertNotSame(Expected, Actual: Pointer);
- begin
- AssertFalse(SExpectedNotSame, Expected = Actual,CallerAddr);
- end;
- class procedure TAssert.AssertNotNull(const AMessage: string; AObject: TObject);
- begin
- AssertTrue(AMessage, (AObject <> nil),CallerAddr);
- end;
- class procedure TAssert.AssertNotNull(AObject: TObject);
- begin
- AssertTrue('',(AObject <> nil),CallerAddr);
- end;
- class procedure TAssert.AssertNotNullIntf(const AMessage: string; AInterface: IInterface);
- begin
- AssertTrue(AMessage, (AInterface <> nil),CallerAddr);
- end;
- class procedure TAssert.AssertNotNullIntf(AInterface: IInterface);
- begin
- AssertTrue('', (AInterface <> nil),CallerAddr);
- end;
- class procedure TAssert.AssertNotNull(const AMessage: string; APointer: Pointer);
- begin
- AssertTrue(AMessage, (APointer <> nil),callerAddr);
- end;
- class procedure TAssert.AssertNotNull(APointer: Pointer);
- begin
- AssertTrue('', (APointer <> nil),callerAddr);
- end;
- class procedure TAssert.AssertNull(const AMessage: string; AObject: TObject);
- begin
- AssertTrue(AMessage, (AObject = nil),CallerAddr);
- end;
- class procedure TAssert.AssertNull(AObject: TObject);
- begin
- AssertTrue('',(AObject = nil),CallerAddr);
- end;
- class procedure TAssert.AssertNullIntf(const AMessage: string; AInterface: IInterface);
- begin
- AssertTrue(AMessage, (AInterface = nil),CallerAddr);
- end;
- class procedure TAssert.AssertNullIntf(AInterface: IInterface);
- begin
- AssertTrue('', (AInterface = nil),CallerAddr);
- end;
- class procedure TAssert.AssertNull(const AMessage: string; APointer: Pointer);
- begin
- AssertTrue(AMessage, (APointer = nil),CallerAddr);
- end;
- class procedure TAssert.AssertNull(APointer: Pointer);
- begin
- AssertTrue('', (APointer = nil),CallerAddr);
- end;
- class procedure TAssert.AssertException(const AMessage: string; AExceptionClass: ExceptClass;
- AMethod: TRunMethod;AExceptionMessage : String = ''; AExceptionContext : Integer = 0; AErrorAddr : Pointer = Nil);
- Function MisMatch (AClassName : String) : String;
- begin
- Result:=Format(SExceptionCompare,[AExceptionClass.ClassName, AClassName])
- end;
- var
- FailMsg : string;
- begin
- If AErrorAddr=Nil then
- AErrorAddr:=CallerAddr;
- FailMsg:='';
- try
- AMethod;
- FailMsg:=MisMatch(SNoException);
- except
- on E: Exception do
- begin
- if Not E.ClassType.InheritsFrom(AExceptionClass) then
- FailMsg:=MisMatch(E.ClassName)
- else if not (AExceptionClass.ClassName = E.ClassName) then
- FailMsg:=MisMatch(E.ClassName)
- else if (AExceptionMessage<>'') and (AExceptionMessage<>E.Message) then
- FailMsg:=ComparisonMsg(SExceptionMessageCompare,AExceptionMessage,E.Message)
- else if (AExceptionContext<>0) and (AExceptionContext<>E.HelpContext) then
- FailMsg:=ComparisonMsg(SExceptionHelpContextCompare,IntToStr(AExceptionContext),IntToStr(E.HelpContext))
- end;
- end;
- AssertTrue(AMessage + ': '+FailMsg, FailMsg='', AErrorAddr);
- end;
- class procedure TAssert.AssertException(AExceptionClass: ExceptClass;
- AMethod: TRunMethod;AExceptionMessage : String = ''; AExceptionContext : Integer = 0);
- begin
- AssertException('', AExceptionClass, AMethod, AExceptionMessage, AExceptionContext, CallerAddr);
- end;
- { DUnit compatibility interface }
- {$IFDEF DUnit}
- {$I DUnitCompatibleInterface.inc}
- {$ENDIF DUnit}
- constructor TTestCase.Create;
- begin
- inherited Create;
- FEnableIgnores := True;
- end;
- constructor TTestCase.CreateWithName(const AName: string);
- begin
- Create;
- FName := AName;
- end;
- constructor TTestCase.CreateWith(const ATestName: string; const ATestSuiteName: string);
- begin
- Create;
- FName := ATestName;
- FTestSuiteName := ATestSuiteName;
- end;
- function TTestCase.AsString: string;
- begin
- Result := TestName + '(' + ClassName + ')';
- end;
- function TTestCase.CountTestCases: integer;
- begin
- Result := 1;
- end;
- function TTestCase.CreateResult: TTestResult;
- begin
- Result := TTestResult.Create;
- end;
- function TTestCase.GetTestName: string;
- begin
- Result := FName;
- end;
- function TTestCase.GetEnableIgnores: boolean;
- begin
- Result := FEnableIgnores;
- end;
- function TTestCase.GetTestSuiteName: string;
- begin
- Result := FTestSuiteName;
- end;
- procedure TTestCase.SetTestSuiteName(const aName: string);
- begin
- if FTestSuiteName <> aName then
- FTestSuiteName := aName;
- end;
- procedure TTestCase.SetTestName(const Value: string);
- begin
- FName := Value;
- end;
- procedure TTestCase.SetEnableIgnores(Value: boolean);
- begin
- FEnableIgnores := Value;
- end;
- function TTestCase.CreateResultAndRun: TTestResult;
- begin
- Result := CreateResult;
- Run(Result);
- end;
- procedure TTestCase.Run(AResult: TTestResult);
- begin
- (AResult).Run(Self);
- end;
- procedure TTestCase.RunBare;
- begin
- FLastStep := stSetUp;
- SetUp;
- try
- FLastStep := stRunTest;
- RunTest;
- FLastStep := stTearDown;
- finally
- TearDown;
- end;
- FLastStep := stNothing;
- end;
- class function TTestCase.SingleInstanceForSuite: Boolean;
- begin
- Result:=False;
- end;
- procedure TTestCase.RunTest;
- var
- m: TMethod;
- RunMethod: TRunMethod;
- pMethod : Pointer;
- FailMessage : String;
- begin
- AssertNotNull('name of the test not assigned', FName);
- pMethod := Self.MethodAddress(FName);
- if (Assigned(pMethod)) then
- begin
- m.Code := pMethod;
- m.Data := self;
- RunMethod := TRunMethod(m);
- ExpectException('',Nil,'',0);
- try
- AssertCount:=0;
- FailMessage:='';
- RunMethod;
- if (FExpectedException<>Nil) then
- FailMessage:=Format(SExceptionCompare, [FExpectedException.ClassName, SNoException]);
- if CheckAssertCalled and (AssertCount=0) then
- FailMessage:=SAssertNotCalled;
- except
- On E : Exception do
- begin
- if FExpectedException=Nil then
- Raise;
- If not (E is FExpectedException) then
- FailMessage:=Format(SExceptionCompare, [FExpectedException.ClassName, E.ClassName]);
- if (FExpectedExceptionMessage<>'') then
- if (FExpectedExceptionMessage<>E.Message) then
- FailMessage:=Format(SExceptionmessageCompare+SCompare, [FExpectedExceptionMessage,E.Message]);
- if (FExpectedExceptionContext<>0) then
- if (FExpectedExceptionContext<>E.HelpContext) then
- FailMessage:=Format(SExceptionHelpContextCompare+SCompare, [IntToStr(FExpectedExceptionContext),IntToStr(E.HelpContext)])
- end;
- end;
- if (FailMessage<>'') then
- begin
- if (FExpectedExceptionFailMessage<>'') then
- FailMessage:=' : '+FailMessage;
- Fail(FExpectedExceptionFailMessage+FailMessage,FExpectedExceptionCaller);
- end;
- end
- else
- begin
- Fail(format(SMethodNotFound, [FName]));
- end;
- end;
- procedure TTestCase.SetUp;
- begin
- { do nothing }
- end;
- procedure TTestCase.TearDown;
- begin
- { do nothing }
- end;
- Type
- { TTestItem }
- TTestItem = Class(TObject)
- private
- FName: String;
- FOwnsTest: Boolean;
- FTest: TTest;
- public
- Constructor Create(T : TTest);
- Destructor Destroy; override;
- Property Test : TTest Read FTest;
- Property TestName : String Read FName;
- Property OwnsTest : Boolean Read FOwnsTest Write FOwnstest;
- end;
- { TTestItem }
- constructor TTestItem.Create(T: TTest);
- begin
- FTest:=T;
- FName:=T.TestName;
- FOwnsTest:=True;
- end;
- destructor TTestItem.Destroy;
- begin
- if FOwnsTest then
- FreeAndNil(FTest);
- inherited Destroy;
- end;
- constructor TTestSuite.Create(AClass: TClass; AName: string);
- begin
- Create(AClass);
- FName := AName;
- end;
- constructor TTestSuite.Create(AClass: TClass);
- var
- ml: TStringList;
- i,j: integer;
- tc: TTestCaseClass;
- C : TTestCase;
- SN : String;
- begin
- TAssert.AssertNotNull(AClass);
- Create(AClass.ClassName);
- if AClass.InheritsFrom(TTestCase) then
- begin
- tc := TTestCaseClass(AClass);
- ml := TStringList.Create;
- try
- GetMethodList(AClass, ml);
- SN:=tc.ClassName;
- if tc.SingleInstanceForSuite then
- begin
- c:=tc.CreateWith('',SN);
- for i := 0 to ml.Count -1 do
- begin
- C.TestName:=ml[i];
- J:=DoAddTest(C);
- TTestItem(FTests[J]).OwnsTest:=(I=0);
- end;
- end
- else
- for i := 0 to ml.Count -1 do
- AddTest(tc.CreateWith(ml.Strings[i], SN));
- finally
- ml.Free;
- end;
- end
- else
- AddTest(Warning(AClass.ClassName + SNoValidInheritance));
- if FTests.Count = 0 then
- AddTest(Warning(SNoValidTests + AClass.ClassName));
- end;
- constructor TTestSuite.Create(AClassArray: array of TClass);
- var
- i: integer;
- begin
- Create;
- for i := Low(AClassArray) to High(AClassArray) do
- if Assigned(AClassArray[i]) then
- AddTest(TTestSuite.Create(AClassArray[i]));
- end;
- constructor TTestSuite.Create(AName: string);
- begin
- Create();
- FName := AName;
- end;
- constructor TTestSuite.Create;
- begin
- inherited Create;
- FTests := TFPList.Create;
- FOwnsTests:=True;
- FEnableIgnores := True;
- end;
- destructor TTestSuite.Destroy;
- begin
- FreeObjects(FTests);
- FTests.Free;
- inherited Destroy;
- end;
- function TTestSuite.GetChildTest(AIndex: integer): TTest;
- begin
- Result := TTestItem(FTests[AIndex]).Test;
- end;
- function TTestSuite.GetChildTestCount: Integer;
- begin
- Result:=FTests.Count;
- end;
- procedure TTestSuite.SetOwnsTests(AValue: Boolean);
- begin
- if FOwnsTests=AValue then Exit;
- FOwnsTests:=AValue;
- SetOwnTestOnTests(AValue);
- end;
- procedure TTestSuite.SetOwnTestOnTests(AValue: Boolean);
- Var
- I : Integer;
- begin
- For I:=0 to FTests.Count-1 do
- TTestItem(FTests[i]).OwnsTest:=AValue;
- end;
- function TTestSuite.DoAddTest(ATest: TTest): Integer;
- Var
- I : TTestItem;
- begin
- I:=TTestItem.Create(ATest);
- I.OwnsTest:=OwnsTests;
- Result:=FTests.Add(I);
- if ATest.TestSuiteName = '' then
- ATest.TestSuiteName := Self.TestName;
- ATest.EnableIgnores := Self.EnableIgnores;
- end;
- function TTestSuite.GetTestName: string;
- begin
- Result := FName;
- end;
- function TTestSuite.GetTestSuiteName: string;
- begin
- Result := FTestSuiteName;
- end;
- function TTestSuite.GetEnableIgnores: boolean;
- begin
- Result := FEnableIgnores;
- end;
- procedure TTestSuite.SetTestName(const Value: string);
- begin
- FName := Value;
- end;
- procedure TTestSuite.SetTestSuiteName(const aName: string);
- begin
- if FTestSuiteName <> aName then
- FTestSuiteName := aName;
- end;
- procedure TTestSuite.SetEnableIgnores(Value: boolean);
- var
- i: integer;
- begin
- if FEnableIgnores <> Value then
- begin
- FEnableIgnores := Value;
- for i := 0 to FTests.Count - 1 do
- TTestItem(FTests[i]).Test.EnableIgnores := Value;
- end
- end;
- function TTestSuite.CountTestCases: integer;
- var
- i: integer;
- begin
- Result := 0;
- for i := 0 to FTests.Count - 1 do
- begin
- Result := Result + TTestItem(FTests[i]).Test.CountTestCases;
- end;
- end;
- procedure TTestCase.ExpectException(const Msg: String;
- AExceptionClass: TClass; AExceptionMessage: string = '';
- AExceptionHelpContext: Integer =0 );
- begin
- FExpectedExceptionFailMessage:=Msg;
- FExpectedException:=AExceptionClass;
- FExpectedExceptionMessage:=AExceptionMessage;
- FExpectedExceptionContext:=AExceptionHelpContext;
- FExpectedExceptionCaller:=CallerAddr;
- end;
- procedure TTestCase.ExpectException(AExceptionClass: TClass;
- AExceptionMessage: string = ''; AExceptionHelpContext: Integer = 0);
- begin
- FExpectedExceptionFailMessage:='';
- FExpectedException:=AExceptionClass;
- FExpectedExceptionMessage:=AExceptionMessage;
- FExpectedExceptionContext:=AExceptionHelpContext;
- FExpectedExceptionCaller:=CallerAddr;
- end;
- procedure TTestSuite.Run(AResult: TTestResult);
- var
- i: integer;
- ti : TTestItem;
- begin
- if FTests.Count > 0 then
- AResult.StartTestSuite(self);
-
- for i := 0 to FTests.Count - 1 do
- begin
- ti:=TTestItem(FTests[i]);
- if Ti.Test.InheritsFrom(TTestCase) and TTestCase(Ti.Test).SingleInstanceForSuite then
- TTestCase(Ti.Test).SetTestName(Ti.TestName);
- RunTest(TI.Test, AResult);
- end;
- if FTests.Count > 0 then
- AResult.EndTestSuite(self);
- end;
- procedure TTestSuite.RunTest(ATest: TTest; AResult: TTestResult);
- begin
- ATest.Run(AResult);
- end;
- procedure TTestSuite.AddTest(ATest: TTest);
- begin
- DoAddTest(ATest);
- end;
- procedure TTestSuite.AddTestSuiteFromClass(ATestClass: TClass);
- begin
- AddTest(TTestSuite.Create(ATestClass));
- end;
- class function TTestSuite.Warning(const aMessage: string): TTestCase;
- var
- w: TTestWarning;
- begin
- w := TTestWarning.Create;
- w.FMessage := aMessage;
- Result := w;
- end;
- constructor TTestResult.Create;
- begin
- inherited Create;
- FFailures := TFPList.Create;
- FIgnoredTests := TFPList.Create;
- FErrors := TFPList.Create;
- FListeners := TFPList.Create;
- FSkippedTests := TFPList.Create;
- FStartingTime := Now;
- end;
- destructor TTestResult.Destroy;
- begin
- FreeObjects(FFailures);
- FFailures.Free;
- FreeObjects(FIgnoredTests);
- FIgnoredTests.Free;
- FreeObjects(FErrors);
- FErrors.Free;
- FListeners.Free;
- FSkippedTests.Free;
- end;
- procedure TTestResult.ClearErrorLists;
- begin
- FreeObjects(FFailures);
- FFailures.Clear;
- FreeObjects(FIgnoredTests);
- FIgnoredTests.Clear;
- FreeObjects(FErrors);
- FErrors.Clear;
- end;
- function TTestResult.GetNumErrors: integer;
- begin
- Result := FErrors.Count;
- end;
- function TTestResult.GetNumFailures: integer;
- begin
- Result := FFailures.Count;
- end;
- function TTestResult.GetNumIgnoredTests: integer;
- begin
- Result := FIgnoredTests.Count;
- end;
- function TTestResult.GetNumSkipped: integer;
- begin
- Result := FSkippedTests.Count;
- end;
- procedure TTestResult.AddListener(AListener: ITestListener);
- begin
- FListeners.Add(pointer(AListener));
- end;
- procedure TTestResult.RemoveListener(AListener: ITestListener);
- begin
- FListeners.Remove(pointer(AListener));
- end;
- procedure TTestResult.AddFailure(ATest: TTest; E: EAssertionFailedError; aFailureList: TFPList; AThrownExceptionAdrs: Pointer);
- var
- i: integer;
- f: TTestFailure;
- begin
- //lock mutex
- f := TTestFailure.CreateFailure(ATest, E, ATest.LastStep, AThrownExceptionAdrs);
- aFailureList.Add(f);
- for i := 0 to FListeners.Count - 1 do
- ITestListener(FListeners[i]).AddFailure(ATest, f);
- //unlock mutex
- end;
- procedure TTestResult.AddError(ATest: TTest; E: Exception; AThrownExceptionAdrs: Pointer);
- var
- i: integer;
- f: TTestFailure;
- begin
- //lock mutex
- f := TTestFailure.CreateFailure(ATest, E, ATest.LastStep, AThrownExceptionAdrs);
- FErrors.Add(f);
- for i := 0 to FListeners.Count - 1 do
- ITestListener(FListeners[i]).AddError(ATest, f);
- //unlock mutex
- end;
- procedure TTestResult.EndTest(ATest: TTest);
- var
- i: integer;
- begin
- for i := 0 to FListeners.Count - 1 do
- ITestListener(FListeners[i]).EndTest(ATest);
- end;
- procedure ProtectTest(aTest: TTest; aResult: TTestResult);
- begin
- TTestCase(aTest).RunBare;
- end;
- procedure TTestResult.Run(ATestCase: TTestCase);
- begin
- if not SkipTest(ATestCase) then
- begin
- StartTest(ATestCase);
- RunProtected(ATestCase, @ProtectTest);
- EndTest(ATestCase);
- end;
- end;
- procedure TTestResult.RunProtected(ATestCase: TTest; protect: TProtect);
- begin
- try
- protect(ATestCase, Self);
- except
- on E: EIgnoredTest do
- AddFailure(ATestCase, E, FIgnoredTests, ExceptAddr);
- on E: EAssertionFailedError do
- AddFailure(ATestCase, E, FFailures, ExceptAddr);
- on E: Exception do
- begin
- AddError(ATestCase, E, ExceptAddr);
- end;
- end;
- end;
- procedure TTestResult.StartTest(ATest: TTest);
- var
- count: integer;
- i: integer;
- begin
- count := ATest.CountTestCases;
- //lock mutex
- FRunTests := FRunTests + count;
- for i := 0 to FListeners.Count - 1 do
- ITestListener(FListeners[i]).StartTest(ATest);
- //unlock mutex
- end;
- function TTestResult.WasSuccessful: boolean;
- begin
- //lock mutex
- Result := (FErrors.Count = 0) and (FFailures.Count = 0);
- //unlock mutex
- end;
- function TTestResult.SkipTest(ATestCase: TTestCase): boolean;
- var
- i: integer;
- begin
- Result := false;
- if FSkippedTests.Count = 0 then
- begin
- result := false;
- Exit;
- end
- else
- for i := 0 to FSkippedTests.Count - 1 do
- begin
- if PtrUInt(FSkippedTests[i]) = PtrUInt(ATestCase) then
- begin
- Result := true;
- Exit;
- end;
- end;
- end;
- procedure TTestResult.AddToSkipList(ATestCase: TTestCase);
- begin
- FSkippedTests.Add(ATestCase);
- end;
- procedure TTestResult.RemoveFromSkipList(ATestCase: TTestCase);
- begin
- FSkippedTests.Remove(ATestCase);
- end;
- procedure TTestResult.StartTestSuite(ATestSuite: TTestSuite);
- var
- i: integer;
- begin
- for i := 0 to FListeners.Count - 1 do
- ITestListener(FListeners[i]).StartTestSuite(ATestSuite);
- end;
- procedure TTestResult.EndTestSuite(ATestSuite: TTestSuite);
- var
- i: integer;
- begin
- for i := 0 to FListeners.Count - 1 do
- ITestListener(FListeners[i]).EndTestSuite(ATestSuite);
- end;
- initialization
- TTestCase.CheckAssertCalled:=False;
- end.
|