ViewVC Help
View File | Revision Log | Show Annotations | Download File | View Changeset | Root Listing
root/public/ibx/trunk/testsuite/Test18.pas
Revision: 315
Committed: Thu Feb 25 11:56:36 2021 UTC (3 years, 6 months ago) by tony
Content type: text/x-pascal
File size: 7129 byte(s)
Log Message:
Updated for IBX 4 release

File Contents

# User Rev Content
1 tony 315 unit Test18;
2    
3     {$mode objfpc}{$H+}
4    
5     {Test 18: Cached Updates}
6    
7     { Description
8     }
9    
10     interface
11    
12     uses
13     Classes, SysUtils, TestApplication, IBXTestBase, Db, IB, IBCustomDataSet;
14    
15     const
16     aTestID = '18';
17     aTestTitle = 'Cached Updates';
18    
19     type
20    
21     { TTest18 }
22    
23     TTest18 = class(TIBXTestBase)
24     private
25     FIBDataset: TIBDataSet;
26     procedure HandleUpdateRecord(DataSet: TDataSet; UpdateKind: TUpdateKind;
27     var UpdateAction: TIBUpdateAction);
28     procedure HandleUpdateError(DataSet: TDataSet; E: EDatabaseError;
29     UpdateKind: TUpdateKind; var TheUpdateAction: TIBUpdateAction);
30     procedure DoTest(aUnidirectional: boolean);
31     protected
32     procedure CreateObjects(Application: TTestApplication); override;
33     function GetTestID: AnsiString; override;
34     function GetTestTitle: AnsiString; override;
35     procedure InitTest; override;
36     public
37     procedure RunTest(CharSet: AnsiString; SQLDialect: integer); override;
38     end;
39    
40    
41     implementation
42    
43     { TTest18 }
44    
45     procedure TTest18.HandleUpdateRecord(DataSet: TDataSet;
46     UpdateKind: TUpdateKind; var UpdateAction: TIBUpdateAction);
47     begin
48     writeln(Outfile,'Update Record Called for ',UpdateKind);
49     PrintDatasetRow(DataSet);
50     UpdateAction := uaApply;
51     end;
52    
53     procedure TTest18.HandleUpdateError(DataSet: TDataSet; E: EDatabaseError;
54     UpdateKind: TUpdateKind; var TheUpdateAction: TIBUpdateAction);
55     begin
56     writeln(Outfile,'Update Error raised: ',E.Message);
57     TheUpdateAction := uaFail;
58     end;
59    
60     procedure TTest18.DoTest(aUnidirectional: boolean);
61     var lastkey: integer;
62     begin
63     with FIBDataSet do
64     begin
65     Unidirectional := aUnidirectional;
66     Active := true;
67     writeln(Outfile,'Unidirectional caching = ',aUnidirectional);
68     writeln(OutFile,'Simple Append i.e. caching of inserted records and cancel');
69     if aUnidirectional then Insert else Append;
70     FieldByName('PlainText').AsString := 'This is a test';
71     Post;
72     if aUnidirectional then Insert else Append;
73     FieldByName('PlainText').AsString := 'This is another test';
74     Post;
75     PrintDataSet(FIBDataSet);
76     writeln(Outfile,'Cancel Updates');
77     CancelUpdates;
78     PrintDataSet(FIBDataSet);
79     writeln(Outfile,'Now reopen and show empty');
80     Active := false;
81     Active := true;
82     PrintDataSet(FIBDataSet);
83    
84     writeln(Outfile);
85     writeln(OutFile,'Simple Append i.e. caching of inserted records and apply updates');
86     if aUnidirectional then Insert else Append;
87     FieldByName('PlainText').AsString := 'This is a test';
88     Post;
89     if aUnidirectional then Insert else Append;
90     FieldByName('PlainText').AsString := 'This is another test';
91     Post;
92     if aUnidirectional then Insert else Append;
93     FieldByName('PlainText').AsString := 'And another';
94     Post;
95     PrintDataSet(FIBDataSet);
96     writeln(Outfile,'Apply Updates');
97     ApplyUpdates;
98     PrintDataSet(FIBDataSet);
99     writeln(Outfile,'Now reopen and show still there');
100     Active := false;
101     Active := true;
102     PrintDataSet(FIBDataSet);
103    
104     writeln(OutFile);
105     writeln(OutFile,'Update of First and Last records and cancel');
106     First;
107     Edit;
108     FieldByName('PlainText').AsString := 'This is an updated test';
109     Post;
110     Last;
111     Edit;
112     FieldByName('PlainText').AsString := 'This is another updated test';
113     Post;
114     PrintDataSet(FIBDataSet);
115     writeln(Outfile,'Cancel Updates');
116     CancelUpdates;
117     PrintDataSet(FIBDataSet);
118     writeln(Outfile,'Now reopen and show no change');
119     Active := false;
120     Active := true;
121     PrintDataSet(FIBDataSet);
122    
123     writeln(OutFile);
124     writeln(OutFile,'Update of First and Last records and apply');
125     First;
126     Edit;
127     FieldByName('PlainText').AsString := 'This is an updated test';
128     Post;
129     Last;
130     Edit;
131     FieldByName('PlainText').AsString := 'This is another updated test';
132     Post;
133     PrintDataSet(FIBDataSet);
134     writeln(Outfile,'Apply Updates');
135     ApplyUpdates;
136     PrintDataSet(FIBDataSet);
137     writeln(Outfile,'Now reopen and show still there');
138     Active := false;
139     Active := true;
140     PrintDataSet(FIBDataSet);
141    
142     writeln(OutFile);
143     writeln(OutFile,'Update of First and Last records and implicitly apply');
144     DataSetCloseAction := dcSaveChanges;
145     First;
146     Edit;
147     FieldByName('PlainText').AsString := 'This is an updated test (implicit apply updates)';
148     Active := false;
149     Active := true;
150     PrintDataSet(FIBDataSet);
151    
152     writeln(OutFile);
153     writeln(OutFile,'Delete First and Last records and Cancel');
154     First;
155     Delete;
156     Last;
157     Delete;
158     PrintDataSet(FIBDataSet);
159     writeln(Outfile,'Cancel Updates');
160     CancelUpdates;
161     PrintDataSet(FIBDataSet);
162     writeln(Outfile,'Now reopen and show no change');
163     Active := false;
164     Active := true;
165     PrintDataSet(FIBDataSet);
166    
167     writeln(OutFile);
168     writeln(OutFile,'Delete First and Last records and Apply');
169     First;
170     Delete;
171     Last;
172     Delete;
173     PrintDataSet(FIBDataSet);
174     writeln(Outfile,'Apply Updates');
175     ApplyUpdates;
176     PrintDataSet(FIBDataSet);
177     writeln(Outfile,'Now reopen and show no change');
178     Active := false;
179     Active := true;
180     PrintDataSet(FIBDataSet);
181    
182     writeln(OutFile);
183     writeln(OutFile, 'Test Error Handling');
184     First;
185     lastkey := FieldByName('KEYFIELD').AsInteger;
186     Append;
187     FieldByName('KEYFIELD').AsInteger := lastkey;
188     Post;
189     PrintDataSet(FIBDataSet);
190     try
191     ApplyUpdates;
192     except on E: Exception do
193     writeln(OutFile,'Exception caught: ',E.Message);
194     end;
195     CancelUpdates;
196     end;
197     end;
198    
199     procedure TTest18.CreateObjects(Application: TTestApplication);
200     begin
201     inherited CreateObjects(Application);
202     FIBDataSet := TIBDataSet.Create(Application);
203     with FIBDataSet do
204     begin
205     Name := 'IBTestData';
206     Database := IBDatabase;
207     Transaction := IBTransaction;
208     SelectSQL.Add('Select * From IBDataSetTest');
209     InsertSQL.Add('Insert into IBDataSetTest(KeyField,PlainText) Values (:KeyField,:PlainText)');
210     ModifySQL.Add('Update IBDataSetTest Set KeyField = :KeyField, PlainText = :PlainText Where KeyField = :Old_KeyField');
211     DeleteSQL.Add('Delete from IBDataSetTest Where KeyField = :old_KeyField');
212     RefreshSQL.Add('Select * from IBDataSetTest Where KeyField = :KeyField');
213     GeneratorField.Field := 'KeyField';
214     GeneratorField.Generator := 'AGENERATOR';
215     GeneratorField.Increment := 1;
216     CachedUpdates := true;
217     OnUpdateRecord := @HandleUpdateRecord;
218     OnUpdateError := @HandleUpdateError;
219     end;
220     end;
221    
222     function TTest18.GetTestID: AnsiString;
223     begin
224     Result := aTestID;
225     end;
226    
227     function TTest18.GetTestTitle: AnsiString;
228     begin
229     Result := aTestTitle;
230     end;
231    
232     procedure TTest18.InitTest;
233     begin
234     IBDatabase.DatabaseName := Owner.GetNewDatabaseName;
235     IBDatabase.CreateIfNotExists := true;
236     ReadWriteTransaction;
237     end;
238    
239     procedure TTest18.RunTest(CharSet: AnsiString; SQLDialect: integer);
240     begin
241     IBDatabase.CreateDatabase;
242     try
243     IBTransaction.Active := true;
244     DoTest(false);
245     // DoTest(true); {See https://bugs.freepascal.org/view.php?id=37900}
246     finally
247     IBDatabase.DropDatabase;
248     end;
249     end;
250    
251     initialization
252     RegisterTest(TTest18);
253    
254     end.
255