blob: 2e776d21b7d52daf583ac3f85c7f903265537022 [file] [log] [blame]
Jens Geyer01640402013-09-25 21:12:21 +02001(*
2 * Licensed to the Apache Software Foundation (ASF) under one
3 * or more contributor license agreements. See the NOTICE file
4 * distributed with this work for additional information
5 * regarding copyright ownership. The ASF licenses this file
6 * to you under the Apache License, Version 2.0 (the
7 * "License"); you may not use this file except in compliance
8 * with the License. You may obtain a copy of the License at
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing,
13 * software distributed under the License is distributed on an
14 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15 * KIND, either express or implied. See the License for the
16 * specific language governing permissions and limitations
17 * under the License.
18 *)
19
20unit TestServerEvents;
21
22interface
23
24uses
25 SysUtils,
26 Thrift,
27 Thrift.Protocol,
28 Thrift.Transport,
29 Thrift.Server,
30 Thrift.Console;
31
32type
33 TRequestEventsImpl = class( TInterfacedObject, IRequestEvents)
34 protected
35 FStart : TDateTime;
36 // IRequestProcessingEvents
37 procedure PreRead;
38 procedure PostRead;
39 procedure PreWrite;
40 procedure PostWrite;
41 procedure OnewayComplete;
42 procedure UnhandledError( const e : Exception);
43 procedure CleanupContext;
44 public
45 constructor Create;
46 end;
47
48
49 TProcessorEventsImpl = class( TInterfacedObject, IProcessorEvents)
Jens Geyerd5436f52014-10-03 19:50:38 +020050 protected
51 FReqs : Integer;
52 // IProcessorEvents
53 procedure Processing( const transport : ITransport);
Jens Geyer01640402013-09-25 21:12:21 +020054 function CreateRequestContext( const aFunctionName : string) : IRequestEvents;
55 procedure CleanupContext;
56 public
57 constructor Create;
Jens Geyerd5436f52014-10-03 19:50:38 +020058 end;
Jens Geyer01640402013-09-25 21:12:21 +020059
60
61 TServerEventsImpl = class( TInterfacedObject, IServerEvents)
Jens Geyerd5436f52014-10-03 19:50:38 +020062 protected
63 // IServerEvents
64 procedure PreServe;
65 procedure PreAccept;
66 function CreateProcessingContext( const input, output : IProtocol) : IProcessorEvents;
67 end;
Jens Geyer01640402013-09-25 21:12:21 +020068
69
70implementation
71
72{ TServerEventsImpl }
Jens Geyerd5436f52014-10-03 19:50:38 +020073
Jens Geyer01640402013-09-25 21:12:21 +020074procedure TServerEventsImpl.PreServe;
Jens Geyerd5436f52014-10-03 19:50:38 +020075begin
76 Console.WriteLine('ServerEvents: Server starting to serve requests');
77end;
78
79
Jens Geyer01640402013-09-25 21:12:21 +020080procedure TServerEventsImpl.PreAccept;
Jens Geyerd5436f52014-10-03 19:50:38 +020081begin
82 Console.WriteLine('ServerEvents: Server transport is ready to accept incoming calls');
83end;
84
85
Jens Geyer01640402013-09-25 21:12:21 +020086function TServerEventsImpl.CreateProcessingContext(const input, output: IProtocol): IProcessorEvents;
Jens Geyerd5436f52014-10-03 19:50:38 +020087begin
88 result := TProcessorEventsImpl.Create;
89end;
90
91
Jens Geyer01640402013-09-25 21:12:21 +020092{ TProcessorEventsImpl }
Jens Geyerd5436f52014-10-03 19:50:38 +020093
Jens Geyer01640402013-09-25 21:12:21 +020094constructor TProcessorEventsImpl.Create;
Jens Geyerd5436f52014-10-03 19:50:38 +020095begin
96 inherited Create;
97 FReqs := 0;
98 Console.WriteLine('ProcessorEvents: Client connected, processing begins');
99end;
100
101procedure TProcessorEventsImpl.Processing(const transport: ITransport);
102begin
103 Console.WriteLine('ProcessorEvents: Processing of incoming request begins');
104end;
105
106
107function TProcessorEventsImpl.CreateRequestContext( const aFunctionName: string): IRequestEvents;
108begin
109 result := TRequestEventsImpl.Create;
110 Inc( FReqs);
111end;
112
113
114procedure TProcessorEventsImpl.CleanupContext;
115begin
116 Console.WriteLine( 'ProcessorEvents: completed after handling '+IntToStr(FReqs)+' requests.');
117end;
118
119
120{ TRequestEventsImpl }
121
Jens Geyer01640402013-09-25 21:12:21 +0200122
123constructor TRequestEventsImpl.Create;
Jens Geyerd5436f52014-10-03 19:50:38 +0200124begin
125 inherited Create;
126 FStart := Now;
127 Console.WriteLine('RequestEvents: New request');
128end;
129
130
Jens Geyer01640402013-09-25 21:12:21 +0200131procedure TRequestEventsImpl.PreRead;
Jens Geyerd5436f52014-10-03 19:50:38 +0200132begin
133 Console.WriteLine('RequestEvents: Reading request message ...');
134end;
135
Jens Geyer01640402013-09-25 21:12:21 +0200136
137procedure TRequestEventsImpl.PostRead;
Jens Geyerd5436f52014-10-03 19:50:38 +0200138begin
139 Console.WriteLine('RequestEvents: Reading request message completed');
140end;
Jens Geyer01640402013-09-25 21:12:21 +0200141
142procedure TRequestEventsImpl.PreWrite;
Jens Geyerd5436f52014-10-03 19:50:38 +0200143begin
144 Console.WriteLine('RequestEvents: Writing response message ...');
145end;
146
Jens Geyer01640402013-09-25 21:12:21 +0200147
148procedure TRequestEventsImpl.PostWrite;
Jens Geyerd5436f52014-10-03 19:50:38 +0200149begin
150 Console.WriteLine('RequestEvents: Writing response message completed');
151end;
152
Jens Geyer01640402013-09-25 21:12:21 +0200153
154procedure TRequestEventsImpl.OnewayComplete;
Jens Geyerd5436f52014-10-03 19:50:38 +0200155begin
156 Console.WriteLine('RequestEvents: Oneway message processed');
157end;
158
Jens Geyer01640402013-09-25 21:12:21 +0200159
160procedure TRequestEventsImpl.UnhandledError(const e: Exception);
Jens Geyerd5436f52014-10-03 19:50:38 +0200161begin
162 Console.WriteLine('RequestEvents: Unhandled exception of type '+e.classname);
163end;
164
165
166procedure TRequestEventsImpl.CleanupContext;
167var millis : Double;
168begin
169 millis := (Now - FStart) * (24*60*60*1000);
170 Console.WriteLine( 'Request processing completed in '+IntToStr(Round(millis))+' ms');
171end;
172
173
Jens Geyer01640402013-09-25 21:12:21 +0200174end.