svnclasses: implemented reading svn log output

git-svn-id: https://svn.code.sf.net/p/lazarus-ccr/svn@98 8e941d3f-bd1b-0410-a28a-d453659cc2b4
This commit is contained in:
vsnijders
2007-02-27 14:09:02 +00:00
parent aaa1e2cc6a
commit 0280be7f26
6 changed files with 421 additions and 298 deletions

View File

@ -6,11 +6,23 @@ interface
uses
Classes, SysUtils,
contnrs,
DOM, XMLRead;
type
TEntryKind = (ekUnknown, ekFile, ekDirectory);
TCommitAction = (caUnknown, caModify, caAdd, caDelete);
{ TSvnBase }
TSvnBase = class
private
procedure LoadFromXml(ADoc: TXMLDocument); virtual; abstract;
public
procedure LoadFromStream(s: TStream);
procedure LoadFromFile(FileName: string);
end;
{ TCommit }
@ -65,21 +77,114 @@ type
{ TSvnInfo }
TSvnInfo = class
TSvnInfo = class(TSvnBase)
private
FEntry: TEntry;
procedure LoadFromXml(ADoc: TXMLDocument);
procedure LoadFromXml(ADoc: TXMLDocument); override;
public
constructor Create;
destructor Destroy; override;
procedure Clear;
procedure LoadFromStream(s: TStream);
procedure LoadFromFile(FileName: string);
property Entry: TEntry read FEntry;
end;
{ TLogPath }
TLogPath = class
private
FAction: TCommitAction;
FCopyFromPath: string;
FCopyFromRevision: integer;
FPath: string;
procedure LoadFromNode(ANode: TDomElement);
public
property Action : TCommitAction read FAction write FAction;
property CopyFromRevision: integer read FCopyFromRevision write FCopyFromRevision;
property CopyFromPath: string read FCopyFromPath write FCopyFromPath;
property Path: string read FPath write FPath;
end;
{ TLogEntry }
TLogEntry = class
private
FAuthor: string;
FDate: string;
FLogPaths: TFPObjectList;
FMessage: string;
FRevision: integer;
function GetLogPath(index: integer): TLogPath;
function GetLogPathCount: integer;
procedure LoadFromNode(ANode: TDOMElement);
public
constructor Create;
destructor Destroy; override;
property Author: string read FAuthor write FAuthor;
property Date: string read FDate write FDate;
property Message: string read FMessage write FMessage;
property Path[index: integer] :TLogPath read GetLogPath;
property PathCount: integer read GetLogPathCount;
property Revision: integer read FRevision write FRevision;
end;
{ TSvnLog }
TSvnLog = class(TSvnBase)
private
FLogEntries: TFPObjectList;
function GetLogEntry(index: integer): TLogEntry;
function GetLogEntryCount: integer;
procedure LoadFromXml(ADoc: TXMLDocument); override;
public
constructor Create;
destructor Destroy; override;
procedure Clear;
property LogEntry[index: integer] :TLogEntry read GetLogEntry;
property LogEntryCount: integer read GetLogEntryCount;
end;
implementation
const
ActionStrings : array[TCommitAction] of char =
(' ','M','A','D');
function GetChildTextContent(ANode: TDomNode; const AName: string) : string;
var
ChildNode: TDOMNode;
begin
Result := '';
ChildNode := ANode.FindNode(AName);
if assigned(ChildNode) then
Result := ChildNode.TextContent;
end;
{ TSvnBase }
procedure TSvnBase.LoadFromStream(s: TStream);
var
ADoc: TXMLDocument;
begin
ReadXMLFile(ADoc, s);
try
LoadFromXml(ADoc);
finally
ADoc.Free;
end;
end;
procedure TSvnBase.LoadFromFile(FileName: string);
var
ADoc: TXMLDocument;
begin
ReadXMLFile(ADoc, FileName);
try
LoadFromXml(ADoc);
finally
ADoc.Free;
end;
end;
{ TSvnInfo }
procedure TSvnInfo.LoadFromXml(ADoc: TXMLDocument);
@ -105,30 +210,6 @@ begin
FEntry.Clear;
end;
procedure TSvnInfo.LoadFromStream(s: TStream);
var
ADoc: TXMLDocument;
begin
ReadXMLFile(ADoc, s);
try
LoadFromXml(ADoc);
finally
ADoc.Free;
end;
end;
procedure TSvnInfo.LoadFromFile(FileName: string);
var
ADoc: TXMLDocument;
begin
ReadXMLFile(ADoc, FileName);
try
LoadFromXml(ADoc);
finally
ADoc.Free;
end;
end;
{ TEntry }
procedure TEntry.LoadFromNode(ANode: TDomNode);
@ -186,21 +267,11 @@ end;
{ TRepository }
procedure TRepository.LoadFromNode(ANode: TDomNode);
var
RepositoryNode: TDomElement;
ChildNode: TDOMNode;
begin
if ANode=nil then exit;
if ANode.NodeType = ELEMENT_NODE then begin
RepositoryNode := TDomElement(ANode);
ChildNode := RepositoryNode.FindNode('root');
if assigned(ChildNode) then
FRoot := ChildNode.TextContent;
ChildNode := RepositoryNode.FindNode('uuid');
if assigned(ChildNode) then
FUUID := ChildNode.TextContent;
end;
FRoot := GetChildTextContent(ANode, 'root');
FUUID := GetChildTextContent(ANode, 'uuid');
end;
procedure TRepository.Clear;
@ -212,21 +283,13 @@ end;
{ TCommit }
procedure TCommit.LoadFromNode(ANode: TDomNode);
var
CommitNode: TDomElement;
ChildNode: TDOMNode;
begin
if ANode=nil then exit;
if ANode.NodeType = ELEMENT_NODE then begin
CommitNode := TDomElement(ANode);
FRevision := StrToIntDef(CommitNode.GetAttribute('revision'),0);
ChildNode := CommitNode.FindNode('author');
if assigned(ChildNode) then
FAuthor := ChildNode.TextContent;
ChildNode := CommitNode.FindNode('date');
if assigned(ChildNode) then
FDate := ChildNode.TextContent;
FRevision := StrToIntDef(TDomElement(ANode).GetAttribute('revision'),0);
FAuthor := GetChildTextContent(ANode, 'author');
FDate := GetChildTextContent(ANode, 'date');
end;
end;
@ -237,5 +300,124 @@ begin
FRevision := 0;
end;
{ TSvnLog }
function TSvnLog.GetLogEntry(index: integer): TLogEntry;
begin
Result := TLogEntry(FLogEntries[index]);
end;
function TSvnLog.GetLogEntryCount: integer;
begin
Result := FLogEntries.Count;
end;
procedure TSvnLog.LoadFromXml(ADoc: TXMLDocument);
var
LogEntryElement: TDomNode;
NewLogEntry: TLogEntry;
begin
Clear;
LogEntryElement := ADoc.FindNode('log').FirstChild;
while assigned(LogEntryElement) do begin
if (LogEntryElement.NodeType=ELEMENT_NODE)
and (LogEntryElement.NodeName='logentry') then
begin
NewLogEntry := TLogEntry.Create;
NewLogEntry.LoadFromNode(TDomElement(LogEntryElement));
FLogEntries.Add(NewLogEntry);
end;
LogEntryElement := LogEntryElement.NextSibling;
end;
end;
constructor TSvnLog.Create;
begin
inherited Create;
FLogEntries := TFPObjectList.Create(true);
end;
destructor TSvnLog.Destroy;
begin
FLogEntries.Free;
inherited Destroy;
end;
procedure TSvnLog.Clear;
begin
FLogEntries.Clear;
end;
{ TLogEntry }
function TLogEntry.GetLogPath(index: integer): TLogPath;
begin
Result := TLogPath(FLogPaths[index]);
end;
function TLogEntry.GetLogPathCount: integer;
begin
Result := FLogPaths.Count;
end;
procedure TLogEntry.LoadFromNode(ANode: TDOMElement);
var
PathsELement: TDomNode;
PathElement: TDomNode;
NewLogPath: TLogPath;
begin
FRevision := StrToIntDef(ANode.GetAttribute('revision'),0);
FAuthor := GetChildTextContent(ANode, 'author');
FDate := GetChildTextContent(ANode, 'date');
FMessage := GetChildTextContent(ANode, 'msg');
PathsElement := ANode.FindNode('paths');
if assigned(PathsELement) then begin
PathElement := PathsELement.FirstChild;
while assigned(PathElement) do begin
if (PathElement.NodeType=ELEMENT_NODE)
and (PathElement.NodeName='path') then
begin
NewLogPath := TLogPath.Create;
NewLogPath.LoadFromNode(TDomElement(PathElement));
FLogPaths.Add(NewLogPath);
end;
PathElement := PathElement.NextSibling;
end;
end;
end;
constructor TLogEntry.Create;
begin
inherited Create;
FLogPaths := TFPObjectList.Create(true);
end;
destructor TLogEntry.Destroy;
begin
FLogPaths.Free;
inherited Destroy;
end;
{ TLogPath }
procedure TLogPath.LoadFromNode(ANode: TDomElement);
var
ActionStr: string;
i: TCommitAction;
begin
FPath := ANode.TextContent;
FCopyFromRevision := StrToIntDef(ANode.GetAttribute('copyfrom-rev'),0);
FCopyFromPath := ANode.GetAttribute('copyfrom-path');
ActionStr := ANode.GetAttribute('action');
FAction := caUnknown;
for i := low(TCommitAction) to high(TCommitAction) do
if ActionStrings[i]=ActionStr then begin
FAction := i;
break;
end;
end;
end.

View File

@ -7,7 +7,7 @@
<Version Value="5"/>
<PathDelim Value="\"/>
<SearchPaths>
<UnitOutputDirectory Value="lib\$(TargetCPU)-$(TargetOS)\"/>
<UnitOutputDirectory Value="lib\$(TargetCPU)-$(TargetOS)"/>
</SearchPaths>
<CodeGeneration>
<Generate Value="Faster"/>
@ -22,7 +22,6 @@
<UnitName Value="svnclasses"/>
</Item1>
</Files>
<Type Value="RunAndDesignTime"/>
<RequiredPkgs Count="1">
<Item1>
<PackageName Value="FCL"/>
@ -30,7 +29,7 @@
</Item1>
</RequiredPkgs>
<UsageOptions>
<UnitPath Value="$(PkgOutDir)"/>
<UnitPath Value="$(PkgOutDir)\"/>
</UsageOptions>
<PublishOptions>
<Version Value="2"/>

View File

@ -7,14 +7,8 @@ unit svnpkg;
interface
uses
svnclasses, LazarusPackageIntf;
svnclasses;
implementation
procedure Register;
begin
end;
initialization
RegisterPackage('svnpkg', @Register);
end.

View File

@ -4,14 +4,13 @@
<PathDelim Value="\"/>
<Version Value="5"/>
<General>
<SessionStorage Value="InProjectDir"/>
<MainUnit Value="0"/>
<IconPath Value="./"/>
<TargetFileExt Value=".exe"/>
<ActiveEditorIndexAtStart Value="0"/>
</General>
<VersionInfo>
<ProjectVersion Value=""/>
<Language Value=""/>
<CharSet Value=""/>
</VersionInfo>
<PublishOptions>
<Version Value="2"/>
@ -30,238 +29,27 @@
<PackageName Value="svnpkg"/>
</Item1>
<Item2>
<PackageName Value="FPCUnitTestRunner"/>
<PackageName Value="LCL"/>
</Item2>
<Item3>
<PackageName Value="LCL"/>
<PackageName Value="FPCUnitTestRunner"/>
</Item3>
<Item4>
<PackageName Value="FCL"/>
</Item4>
</RequiredPackages>
<Units Count="12">
<Units Count="2">
<Unit0>
<Filename Value="fpcunitsvnpkg.lpr"/>
<IsPartOfProject Value="True"/>
<UnitName Value="fpcunitsvnpkg"/>
<UsageCount Value="20"/>
</Unit0>
<Unit1>
<Filename Value="testsvnclasses.pas"/>
<IsPartOfProject Value="True"/>
<UnitName Value="TestSvnClasses"/>
<CursorPos X="63" Y="60"/>
<TopLine Value="28"/>
<EditorIndex Value="0"/>
<UsageCount Value="20"/>
<Loaded Value="True"/>
</Unit1>
<Unit2>
<Filename Value="..\..\..\..\lazarus\components\fpcunit\guitestrunner.pas"/>
<UnitName Value="GuiTestRunner"/>
<CursorPos X="1" Y="48"/>
<TopLine Value="37"/>
<EditorIndex Value="1"/>
<UsageCount Value="10"/>
<Loaded Value="True"/>
</Unit2>
<Unit3>
<Filename Value="..\..\..\..\fpc\2.1\fcl\inc\fpcunit.pp"/>
<UnitName Value="fpcunit"/>
<CursorPos X="1" Y="446"/>
<TopLine Value="427"/>
<EditorIndex Value="9"/>
<UsageCount Value="10"/>
<Loaded Value="True"/>
</Unit3>
<Unit4>
<Filename Value="..\svnclasses.pas"/>
<UnitName Value="svnclasses"/>
<CursorPos X="72" Y="201"/>
<TopLine Value="190"/>
<EditorIndex Value="2"/>
<UsageCount Value="10"/>
<Loaded Value="True"/>
</Unit4>
<Unit5>
<Filename Value="info.xml"/>
<CursorPos X="78" Y="9"/>
<TopLine Value="1"/>
<EditorIndex Value="3"/>
<UsageCount Value="10"/>
<Loaded Value="True"/>
<SyntaxHighlighter Value="XML"/>
</Unit5>
<Unit6>
<Filename Value="..\..\..\..\fpc\2.1\fcl\xml\dom.pp"/>
<UnitName Value="DOM"/>
<CursorPos X="3" Y="1168"/>
<TopLine Value="1165"/>
<EditorIndex Value="4"/>
<UsageCount Value="10"/>
<Loaded Value="True"/>
</Unit6>
<Unit7>
<Filename Value="..\..\..\..\fpcbuild\2.0.4\fpcsrc\packages\extra\gtk2\gtk+\gtk\gtksocket.inc"/>
<CursorPos X="74" Y="77"/>
<TopLine Value="58"/>
<EditorIndex Value="5"/>
<UsageCount Value="10"/>
<Loaded Value="True"/>
</Unit7>
<Unit8>
<Filename Value="..\..\..\..\lazarus\lcl\interfaces\gtk2\gtk2extrah.inc"/>
<CursorPos X="47" Y="44"/>
<TopLine Value="25"/>
<EditorIndex Value="6"/>
<UsageCount Value="10"/>
<Loaded Value="True"/>
</Unit8>
<Unit9>
<Filename Value="..\..\..\..\fpcbuild\2.0.4\fpcsrc\packages\extra\gtk2\gtk+\gdk\gdkdrawable.inc"/>
<CursorPos X="94" Y="12"/>
<TopLine Value="1"/>
<EditorIndex Value="7"/>
<UsageCount Value="10"/>
<Loaded Value="True"/>
</Unit9>
<Unit10>
<Filename Value="..\..\..\..\lazarus\lcl\interfaces\win32\win32winapi.inc"/>
<CursorPos X="33" Y="3164"/>
<TopLine Value="3145"/>
<EditorIndex Value="8"/>
<UsageCount Value="10"/>
<Loaded Value="True"/>
</Unit10>
<Unit11>
<Filename Value="..\..\..\..\fpc\2.1\rtl\win\wininc\ascdef.inc"/>
<CursorPos X="10" Y="268"/>
<TopLine Value="249"/>
<UsageCount Value="10"/>
</Unit11>
</Units>
<JumpHistory Count="30" HistoryIndex="29">
<Position1>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="130" Column="13" TopLine="111"/>
</Position1>
<Position2>
<Filename Value="..\..\..\..\fpc\2.1\fcl\xml\dom.pp"/>
<Caret Line="217" Column="40" TopLine="198"/>
</Position2>
<Position3>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="134" Column="30" TopLine="111"/>
</Position3>
<Position4>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="131" Column="48" TopLine="112"/>
</Position4>
<Position5>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="130" Column="1" TopLine="112"/>
</Position5>
<Position6>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="83" Column="46" TopLine="72"/>
</Position6>
<Position7>
<Filename Value="..\..\..\..\fpcbuild\2.0.4\fpcsrc\packages\extra\gtk2\gtk+\gtk\gtksocket.inc"/>
<Caret Line="1" Column="1" TopLine="1"/>
</Position7>
<Position8>
<Filename Value="..\..\..\..\lazarus\lcl\interfaces\gtk2\gtk2extrah.inc"/>
<Caret Line="1" Column="1" TopLine="1"/>
</Position8>
<Position9>
<Filename Value="..\..\..\..\fpcbuild\2.0.4\fpcsrc\packages\extra\gtk2\gtk+\gdk\gdkdrawable.inc"/>
<Caret Line="1" Column="1" TopLine="1"/>
</Position9>
<Position10>
<Filename Value="..\..\..\..\lazarus\lcl\interfaces\win32\win32winapi.inc"/>
<Caret Line="1" Column="1" TopLine="1"/>
</Position10>
<Position11>
<Filename Value="..\..\..\..\lazarus\lcl\interfaces\win32\win32winapi.inc"/>
<Caret Line="3164" Column="33" TopLine="3145"/>
</Position11>
<Position12>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="89" Column="8" TopLine="72"/>
</Position12>
<Position13>
<Filename Value="..\..\..\..\lazarus\components\fpcunit\guitestrunner.pas"/>
<Caret Line="45" Column="36" TopLine="26"/>
</Position13>
<Position14>
<Filename Value="..\..\..\..\lazarus\components\fpcunit\guitestrunner.pas"/>
<Caret Line="47" Column="63" TopLine="28"/>
</Position14>
<Position15>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="55" Column="22" TopLine="36"/>
</Position15>
<Position16>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="103" Column="5" TopLine="60"/>
</Position16>
<Position17>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="33" Column="3" TopLine="31"/>
</Position17>
<Position18>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="17" Column="3" TopLine="15"/>
</Position18>
<Position19>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="185" Column="17" TopLine="25"/>
</Position19>
<Position20>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="174" Column="5" TopLine="131"/>
</Position20>
<Position21>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="182" Column="29" TopLine="156"/>
</Position21>
<Position22>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="60" Column="21" TopLine="36"/>
</Position22>
<Position23>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="173" Column="11" TopLine="154"/>
</Position23>
<Position24>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="188" Column="1" TopLine="145"/>
</Position24>
<Position25>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="194" Column="5" TopLine="162"/>
</Position25>
<Position26>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="33" Column="7" TopLine="14"/>
</Position26>
<Position27>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="38" Column="15" TopLine="33"/>
</Position27>
<Position28>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="187" Column="23" TopLine="170"/>
</Position28>
<Position29>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="218" Column="1" TopLine="175"/>
</Position29>
<Position30>
<Filename Value="..\svnclasses.pas"/>
<Caret Line="216" Column="10" TopLine="192"/>
</Position30>
</JumpHistory>
</ProjectOptions>
<CompilerOptions>
<Version Value="5"/>
@ -269,21 +57,13 @@
<CodeGeneration>
<Generate Value="Faster"/>
</CodeGeneration>
<Linking>
<Debugging>
<UseHeaptrc Value="True"/>
</Debugging>
</Linking>
<Other>
<CompilerPath Value="$(CompPath)"/>
</Other>
</CompilerOptions>
<Debugging>
<Exceptions Count="3">
<Item1>
<Name Value="ECodetoolError"/>
</Item1>
<Item2>
<Name Value="EFOpenError"/>
</Item2>
<Item3>
<Name Value="EAssertionFailedError"/>
</Item3>
</Exceptions>
</Debugging>
</CONFIG>

View File

@ -0,0 +1,67 @@
<?xml version="1.0"?>
<log>
<logentry revision="10660">
<author>vincents</author>
<date>2007-02-20T10:57:42.928052Z</date>
<paths>
<path action="M">/trunk/ide/Makefile</path>
<path action="A">/trunk/components/tachart/Makefile.fpc</path>
<path action="A">/trunk/components/tachart/tagraph.lrs</path>
<path action="M">/trunk/ide/lazarus.pp</path>
<path action="M">/trunk/components/Makefile</path>
<path action="M">/trunk/components/tachart/TAGraph.pas</path>
<path action="M">/trunk/ide/Makefile.fpc</path>
<path action="A">/trunk/components/tachart/Makefile</path>
<path action="M">/trunk/components/Makefile.fpc</path>
<path action="M">/trunk/components/tachart/tachartlazaruspkg.lpk</path>
<path action="M">/trunk/docs/xml/lcl/lclintf.xml</path>
</paths>
<msg>TAChart: added icon, added to make bigide</msg>
</logentry>
<logentry revision="10661">
<author>vincents</author>
<date>2007-02-20T11:24:55.592011Z</date>
<paths>
<path copyfrom-path="/trunk/components/tachart/TAGraph.pas" copyfrom-rev="10660" action="A">/trunk/components/tagraph.pas</path>
<path action="D">/trunk/components/tachart/TAGraph.pas</path>
</paths>
<msg>lowercase</msg>
</logentry>
<logentry revision="10662">
<author>vincents</author>
<date>2007-02-20T11:26:46.869961Z</date>
<paths>
<path action="D">/trunk/components/tagraph.pas</path>
<path copyfrom-path="/trunk/components/tagraph.pas" copyfrom-rev="10661" action="A">/trunk/components/tachart/tagraph.pas</path>
</paths>
<msg>tachart: fixed wrong move</msg>
</logentry>
<logentry revision="10663">
<author>vincents</author>
<date>2007-02-20T11:31:09.651670Z</date>
<paths>
<path action="D">/trunk/components/tachart/TAEngine.pas</path>
<path copyfrom-path="/trunk/components/tachart/TAEngine.pas" copyfrom-rev="10662" action="A">/trunk/components/tachart/taengine.pas</path>
<path action="M">/trunk/components/tachart/tachartlazaruspkg.lpk</path>
<path action="D">/trunk/components/tachart/TASeries.pas</path>
<path copyfrom-path="/trunk/components/tachart/TASeries.pas" copyfrom-rev="10662" action="A">/trunk/components/tachart/taseries.pas</path>
</paths>
<msg>tachart: user lowercase unit filenames</msg>
</logentry>
<logentry revision="10664">
<author>vincents</author>
<date>2007-02-20T21:57:51.761388Z</date>
<paths>
<path action="M">/trunk/lcl/interfaces/win32/win32callback.inc</path>
</paths>
<msg>win32 interface: fix showing contextmenu for listviews (bug 8331)</msg>
</logentry>
<logentry revision="10665">
<author>vincents</author>
<date>2007-02-20T23:18:34.679005Z</date>
<paths>
<path action="M">/trunk/lcl/interfaces/win32/win32winapi.inc</path>
</paths>
<msg>win32 interface: made LCLIntf.Rectangle and TCanvas.Rectangle compatible with Windows.Rectangle winapi function (bug 8342)</msg>
</logentry>
</log>

View File

@ -5,7 +5,7 @@ unit TestSvnClasses;
interface
uses
Classes, SysUtils, fpcunit, testutils, testregistry,
Classes, SysUtils, fpcunit, testregistry,
svnclasses;
type
@ -15,10 +15,15 @@ type
TTestSvnClasses= class(TTestCase)
private
function GetInfoFileName: string;
function GetLogFileName: string;
published
procedure TestHookUp;
procedure TestLoadInfo;
end;
procedure TestLoadLog;
procedure TestLoadSimpleLogPaths;
procedure TestLoadComplexLogPaths;
procedure TestLoadLogTwice;
end;
implementation
@ -27,12 +32,19 @@ begin
Result := ExtractFilePath(ParamStr(0)) + 'info.xml';
end;
procedure TTestSvnClasses.TestHookUp;
var
InfoFileName: string;
function TTestSvnClasses.GetLogFileName: string;
begin
InfoFileName := GetInfoFileName;
AssertTrue(InfoFileName + ' does not exist', FileExists(InfoFileName));
Result := ExtractFilePath(ParamStr(0)) + 'log.xml';
end;
procedure TTestSvnClasses.TestHookUp;
procedure CheckFile(const FileName: string);
begin
AssertTrue(FileName + ' does not exist', FileExists(FileName));
end;
begin
CheckFile(GetInfoFileName);
CheckFile(GetLogFileName);
end;
procedure TTestSvnClasses.TestLoadInfo;
@ -63,6 +75,95 @@ begin
end;
end;
procedure TTestSvnClasses.TestLoadLog;
var
SvnLog: TSvnLog;
LogEntry: TLogEntry;
begin
SvnLog := TSvnLog.Create;
try
SvnLog.LoadFromFile(GetLogFileName);
AssertEquals('Wrong number of log entries', 6, SvnLog.LogEntryCount);
LogEntry := SvnLog.LogEntry[0];
AssertEquals('Wrong log revision', 10660, LogEntry.Revision);
AssertEquals('Wrong log author', 'vincents', LogEntry.Author);
AssertEquals('Wrong log date',
'2007-02-20T10:57:42.928052Z', LogEntry.Date);
AssertEquals('Wrong log message',
'TAChart: added icon, added to make bigide', LogEntry.Message);
finally
SvnLog.Free;
end;
end;
procedure TTestSvnClasses.TestLoadSimpleLogPaths;
var
SvnLog: TSvnLog;
LogEntry: TLogEntry;
LogPath: TLogPath;
begin
SvnLog := TSvnLog.Create;
try
SvnLog.LoadFromFile(GetLogFileName);
AssertEquals('Wrong number of log entries', 6, SvnLog.LogEntryCount);
LogEntry := SvnLog.LogEntry[4];
AssertEquals('Wrong log revision', 10664, LogEntry.Revision);
AssertEquals('Wrong number of paths', 1, LogEntry.PathCount);
LogPath := LogEntry.Path[0];
AssertEquals('Wrong path',
'/trunk/lcl/interfaces/win32/win32callback.inc', LogPath.Path);
AssertEquals('Wrong commit action', ord(caModify), ord(LogPath.Action));
finally
SvnLog.Free;
end;
end;
procedure TTestSvnClasses.TestLoadComplexLogPaths;
var
SvnLog: TSvnLog;
LogEntry: TLogEntry;
procedure AssertLogPath(i: integer; action: TCommitAction;
const path, copyfrompath: string; copyfromrev: integer);
var
LogPath: TLogPath;
begin
LogPath := LogEntry.Path[i];
AssertEquals('Wrong commit action', ord(action), ord(LogPath.Action));
AssertEquals('Wrong path', path, LogPath.Path);
AssertEquals('Wrong copy from revision', copyfromrev, LogPath.CopyFromRevision);
AssertEquals('Wrong copy from path', copyfrompath, LogPath.CopyFromPath);
end;
begin
SvnLog := TSvnLog.Create;
try
SvnLog.LoadFromFile(GetLogFileName);
AssertEquals('Wrong number of log entries', 6, SvnLog.LogEntryCount);
LogEntry := SvnLog.LogEntry[3];
AssertEquals('Wrong log revision', 10663, LogEntry.Revision);
AssertEquals('Wrong number of paths', 5, LogEntry.PathCount);
AssertLogPath(0, caDelete, '/trunk/components/tachart/TAEngine.pas', '', 0);
AssertLogPath(1, caAdd, '/trunk/components/tachart/taengine.pas',
'/trunk/components/tachart/TAEngine.pas', 10662);
finally
SvnLog.Free;
end;
end;
procedure TTestSvnClasses.TestLoadLogTwice;
var
SvnLog: TSvnLog;
begin
SvnLog := TSvnLog.Create;
try
SvnLog.LoadFromFile(GetLogFileName);
SvnLog.LoadFromFile(GetLogFileName);
AssertEquals('Wrong number of log entries', 6, SvnLog.LogEntryCount);
finally
SvnLog.Free;
end;
end;
initialization
RegisterTest(TTestSvnClasses);