Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 1 | (* |
| 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 | |
| 20 | unit TestServer; |
| 21 | |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 22 | {$WARN SYMBOL_PLATFORM OFF} |
| 23 | |
Jens Geyer | 06045cf | 2013-03-27 20:26:25 +0200 | [diff] [blame] | 24 | {.$DEFINE RunEndless} // activate to interactively stress-test the server stop routines via Ctrl+C |
| 25 | |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 26 | interface |
| 27 | |
| 28 | uses |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 29 | Windows, SysUtils, |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 30 | Generics.Collections, |
| 31 | Thrift.Console, |
| 32 | Thrift.Server, |
| 33 | Thrift.Transport, |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 34 | Thrift.Transport.Pipes, |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 35 | Thrift.Protocol, |
| 36 | Thrift.Protocol.JSON, |
Jens Geyer | f0e6331 | 2015-03-01 18:47:49 +0100 | [diff] [blame] | 37 | Thrift.Protocol.Compact, |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 38 | Thrift.Collections, |
| 39 | Thrift.Utils, |
| 40 | Thrift.Test, |
| 41 | Thrift, |
| 42 | TestConstants, |
Jens Geyer | 0164040 | 2013-09-25 21:12:21 +0200 | [diff] [blame] | 43 | TestServerEvents, |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 44 | Contnrs; |
| 45 | |
| 46 | type |
| 47 | TTestServer = class |
| 48 | public |
| 49 | type |
| 50 | |
| 51 | ITestHandler = interface( TThriftTest.Iface ) |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 52 | procedure SetServer( const AServer : IServer ); |
Jens Geyer | 06045cf | 2013-03-27 20:26:25 +0200 | [diff] [blame] | 53 | procedure TestStop; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 54 | end; |
| 55 | |
| 56 | TTestHandlerImpl = class( TInterfacedObject, ITestHandler ) |
| 57 | private |
| 58 | FServer : IServer; |
| 59 | protected |
| 60 | procedure testVoid(); |
Jens Geyer | 39ba6b7 | 2015-09-22 00:00:49 +0200 | [diff] [blame] | 61 | function testBool(thing: Boolean): Boolean; |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 62 | function testString(const thing: string): string; |
Jake Farrell | 7ae13e1 | 2011-10-18 14:35:26 +0000 | [diff] [blame] | 63 | function testByte(thing: ShortInt): ShortInt; |
| 64 | function testI32(thing: Integer): Integer; |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 65 | function testI64(const thing: Int64): Int64; |
| 66 | function testDouble(const thing: Double): Double; |
Jens Geyer | fd1b358 | 2014-12-13 23:42:58 +0100 | [diff] [blame] | 67 | function testBinary(const thing: TBytes): TBytes; |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 68 | function testStruct(const thing: IXtruct): IXtruct; |
| 69 | function testNest(const thing: IXtruct2): IXtruct2; |
| 70 | function testMap(const thing: IThriftDictionary<Integer, Integer>): IThriftDictionary<Integer, Integer>; |
| 71 | function testStringMap(const thing: IThriftDictionary<string, string>): IThriftDictionary<string, string>; |
| 72 | function testSet(const thing: IHashSet<Integer>): IHashSet<Integer>; |
| 73 | function testList(const thing: IThriftList<Integer>): IThriftList<Integer>; |
Jake Farrell | 7ae13e1 | 2011-10-18 14:35:26 +0000 | [diff] [blame] | 74 | function testEnum(thing: TNumberz): TNumberz; |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 75 | function testTypedef(const thing: Int64): Int64; |
Jake Farrell | 7ae13e1 | 2011-10-18 14:35:26 +0000 | [diff] [blame] | 76 | function testMapMap(hello: Integer): IThriftDictionary<Integer, IThriftDictionary<Integer, Integer>>; |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 77 | function testInsanity(const argument: IInsanity): IThriftDictionary<Int64, IThriftDictionary<TNumberz, IInsanity>>; |
| 78 | function testMulti(arg0: ShortInt; arg1: Integer; const arg2: Int64; const arg3: IThriftDictionary<SmallInt, string>; arg4: TNumberz; const arg5: Int64): IXtruct; |
| 79 | procedure testException(const arg: string); |
| 80 | function testMultiException(const arg0: string; const arg1: string): IXtruct; |
Jake Farrell | 7ae13e1 | 2011-10-18 14:35:26 +0000 | [diff] [blame] | 81 | procedure testOneway(secondsToSleep: Integer); |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 82 | |
Jens Geyer | 06045cf | 2013-03-27 20:26:25 +0200 | [diff] [blame] | 83 | procedure TestStop; |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 84 | procedure SetServer( const AServer : IServer ); |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 85 | end; |
| 86 | |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 87 | class procedure PrintCmdLineHelp; |
| 88 | class procedure InvalidArgs; |
| 89 | |
Jens Geyer | 06045cf | 2013-03-27 20:26:25 +0200 | [diff] [blame] | 90 | class procedure LaunchAnonPipeChild( const app : string; const transport : IAnonymousPipeServerTransport); |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 91 | class procedure Execute( const args: array of string); |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 92 | end; |
| 93 | |
| 94 | implementation |
| 95 | |
Jens Geyer | 06045cf | 2013-03-27 20:26:25 +0200 | [diff] [blame] | 96 | |
| 97 | var g_Handler : TTestServer.ITestHandler = nil; |
| 98 | |
| 99 | |
| 100 | function MyConsoleEventHandler( dwCtrlType : DWORD) : BOOL; stdcall; |
| 101 | // Note that this Handler procedure is called from another thread |
| 102 | var handler : TTestServer.ITestHandler; |
| 103 | begin |
| 104 | result := TRUE; |
| 105 | try |
| 106 | case dwCtrlType of |
| 107 | CTRL_C_EVENT : Console.WriteLine( 'Ctrl+C pressed'); |
| 108 | CTRL_BREAK_EVENT : Console.WriteLine( 'Ctrl+Break pressed'); |
| 109 | CTRL_CLOSE_EVENT : Console.WriteLine( 'Received CloseTask signal'); |
| 110 | CTRL_LOGOFF_EVENT : Console.WriteLine( 'Received LogOff signal'); |
| 111 | CTRL_SHUTDOWN_EVENT : Console.WriteLine( 'Received Shutdown signal'); |
| 112 | else |
| 113 | Console.WriteLine( 'Received console event #'+IntToStr(Integer(dwCtrlType))); |
| 114 | end; |
| 115 | |
| 116 | handler := g_Handler; |
| 117 | if handler <> nil then handler.TestStop; |
| 118 | |
| 119 | except |
| 120 | // catch all |
| 121 | end; |
| 122 | end; |
| 123 | |
| 124 | |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 125 | { TTestServer.TTestHandlerImpl } |
| 126 | |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 127 | procedure TTestServer.TTestHandlerImpl.SetServer( const AServer: IServer); |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 128 | begin |
| 129 | FServer := AServer; |
| 130 | end; |
| 131 | |
| 132 | function TTestServer.TTestHandlerImpl.testByte(thing: ShortInt): ShortInt; |
| 133 | begin |
| 134 | Console.WriteLine('testByte("' + IntToStr( thing) + '")'); |
| 135 | Result := thing; |
| 136 | end; |
| 137 | |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 138 | function TTestServer.TTestHandlerImpl.testDouble( const thing: Double): Double; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 139 | begin |
| 140 | Console.WriteLine('testDouble("' + FloatToStr( thing ) + '")'); |
| 141 | Result := thing; |
| 142 | end; |
| 143 | |
Jens Geyer | fd1b358 | 2014-12-13 23:42:58 +0100 | [diff] [blame] | 144 | function TTestServer.TTestHandlerImpl.testBinary(const thing: TBytes): TBytes; |
| 145 | begin |
| 146 | Console.WriteLine('testBinary("' + BytesToHex( thing ) + '")'); |
| 147 | Result := thing; |
| 148 | end; |
| 149 | |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 150 | function TTestServer.TTestHandlerImpl.testEnum(thing: TNumberz): TNumberz; |
| 151 | begin |
| 152 | Console.WriteLine('testEnum(' + IntToStr( Integer( thing)) + ')'); |
| 153 | Result := thing; |
| 154 | end; |
| 155 | |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 156 | procedure TTestServer.TTestHandlerImpl.testException(const arg: string); |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 157 | begin |
| 158 | Console.WriteLine('testException(' + arg + ')'); |
| 159 | if ( arg = 'Xception') then |
| 160 | begin |
Roger Meier | bb6de7a | 2012-05-04 23:35:45 +0000 | [diff] [blame] | 161 | raise TXception.Create( 1001, arg); |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 162 | end; |
Roger Meier | bb6de7a | 2012-05-04 23:35:45 +0000 | [diff] [blame] | 163 | |
| 164 | if (arg = 'TException') then |
| 165 | begin |
| 166 | raise TException.Create(''); |
| 167 | end; |
| 168 | |
| 169 | // else do not throw anything |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 170 | end; |
| 171 | |
| 172 | function TTestServer.TTestHandlerImpl.testI32(thing: Integer): Integer; |
| 173 | begin |
| 174 | Console.WriteLine('testI32("' + IntToStr( thing) + '")'); |
| 175 | Result := thing; |
| 176 | end; |
| 177 | |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 178 | function TTestServer.TTestHandlerImpl.testI64( const thing: Int64): Int64; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 179 | begin |
| 180 | Console.WriteLine('testI64("' + IntToStr( thing) + '")'); |
| 181 | Result := thing; |
| 182 | end; |
| 183 | |
| 184 | function TTestServer.TTestHandlerImpl.testInsanity( |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 185 | const argument: IInsanity): IThriftDictionary<Int64, IThriftDictionary<TNumberz, IInsanity>>; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 186 | var |
| 187 | hello, goodbye : IXtruct; |
| 188 | crazy : IInsanity; |
| 189 | looney : IInsanity; |
| 190 | first_map : IThriftDictionary<TNumberz, IInsanity>; |
| 191 | second_map : IThriftDictionary<TNumberz, IInsanity>; |
| 192 | insane : IThriftDictionary<Int64, IThriftDictionary<TNumberz, IInsanity>>; |
| 193 | |
| 194 | begin |
| 195 | |
| 196 | Console.WriteLine('testInsanity()'); |
| 197 | hello := TXtructImpl.Create; |
Roger Meier | bb6de7a | 2012-05-04 23:35:45 +0000 | [diff] [blame] | 198 | hello.String_thing := 'Hello2'; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 199 | hello.Byte_thing := 2; |
| 200 | hello.I32_thing := 2; |
| 201 | hello.I64_thing := 2; |
| 202 | |
| 203 | goodbye := TXtructImpl.Create; |
| 204 | goodbye.String_thing := 'Goodbye4'; |
| 205 | goodbye.Byte_thing := 4; |
| 206 | goodbye.I32_thing := 4; |
| 207 | goodbye.I64_thing := 4; |
| 208 | |
| 209 | crazy := TInsanityImpl.Create; |
| 210 | crazy.UserMap := TThriftDictionaryImpl<TNumberz, Int64>.Create; |
| 211 | crazy.UserMap.AddOrSetValue( TNumberz.EIGHT, 8); |
| 212 | crazy.Xtructs := TThriftListImpl<IXtruct>.Create; |
| 213 | crazy.Xtructs.Add(goodbye); |
| 214 | |
| 215 | looney := TInsanityImpl.Create; |
| 216 | crazy.UserMap.AddOrSetValue( TNumberz.FIVE, 5); |
| 217 | crazy.Xtructs.Add(hello); |
| 218 | |
| 219 | first_map := TThriftDictionaryImpl<TNumberz, IInsanity>.Create; |
| 220 | second_map := TThriftDictionaryImpl<TNumberz, IInsanity>.Create; |
| 221 | |
Roger Meier | bb6de7a | 2012-05-04 23:35:45 +0000 | [diff] [blame] | 222 | first_map.AddOrSetValue( TNumberz.TWO, crazy); |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 223 | first_map.AddOrSetValue( TNumberz.THREE, crazy); |
| 224 | |
| 225 | second_map.AddOrSetValue( TNumberz.SIX, looney); |
| 226 | |
| 227 | insane := TThriftDictionaryImpl<Int64, IThriftDictionary<TNumberz, IInsanity>>.Create; |
| 228 | |
| 229 | insane.AddOrSetValue( 1, first_map); |
| 230 | insane.AddOrSetValue( 2, second_map); |
| 231 | |
| 232 | Result := insane; |
| 233 | end; |
| 234 | |
| 235 | function TTestServer.TTestHandlerImpl.testList( |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 236 | const thing: IThriftList<Integer>): IThriftList<Integer>; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 237 | var |
| 238 | first : Boolean; |
| 239 | elem : Integer; |
| 240 | begin |
| 241 | Console.Write('testList({'); |
| 242 | first := True; |
| 243 | for elem in thing do |
| 244 | begin |
| 245 | if first then |
| 246 | begin |
| 247 | first := False; |
| 248 | end else |
| 249 | begin |
| 250 | Console.Write(', '); |
| 251 | end; |
| 252 | Console.Write( IntToStr( elem)); |
| 253 | end; |
| 254 | Console.WriteLine('})'); |
| 255 | Result := thing; |
| 256 | end; |
| 257 | |
| 258 | function TTestServer.TTestHandlerImpl.testMap( |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 259 | const thing: IThriftDictionary<Integer, Integer>): IThriftDictionary<Integer, Integer>; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 260 | var |
| 261 | first : Boolean; |
| 262 | key : Integer; |
| 263 | begin |
| 264 | Console.Write('testMap({'); |
| 265 | first := True; |
| 266 | for key in thing.Keys do |
| 267 | begin |
| 268 | if (first) then |
| 269 | begin |
| 270 | first := false; |
| 271 | end else |
| 272 | begin |
| 273 | Console.Write(', '); |
| 274 | end; |
| 275 | Console.Write(IntToStr(key) + ' => ' + IntToStr( thing[key])); |
| 276 | end; |
| 277 | Console.WriteLine('})'); |
| 278 | Result := thing; |
| 279 | end; |
| 280 | |
| 281 | function TTestServer.TTestHandlerImpl.TestMapMap( |
| 282 | hello: Integer): IThriftDictionary<Integer, IThriftDictionary<Integer, Integer>>; |
| 283 | var |
| 284 | mapmap : IThriftDictionary<Integer, IThriftDictionary<Integer, Integer>>; |
| 285 | pos : IThriftDictionary<Integer, Integer>; |
| 286 | neg : IThriftDictionary<Integer, Integer>; |
| 287 | i : Integer; |
| 288 | begin |
| 289 | Console.WriteLine('testMapMap(' + IntToStr( hello) + ')'); |
| 290 | mapmap := TThriftDictionaryImpl<Integer, IThriftDictionary<Integer, Integer>>.Create; |
| 291 | pos := TThriftDictionaryImpl<Integer, Integer>.Create; |
| 292 | neg := TThriftDictionaryImpl<Integer, Integer>.Create; |
| 293 | |
| 294 | for i := 1 to 4 do |
| 295 | begin |
| 296 | pos.AddOrSetValue( i, i); |
| 297 | neg.AddOrSetValue( -i, -i); |
| 298 | end; |
| 299 | |
| 300 | mapmap.AddOrSetValue(4, pos); |
| 301 | mapmap.AddOrSetValue( -4, neg); |
| 302 | |
| 303 | Result := mapmap; |
| 304 | end; |
| 305 | |
| 306 | function TTestServer.TTestHandlerImpl.testMulti(arg0: ShortInt; arg1: Integer; |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 307 | const arg2: Int64; const arg3: IThriftDictionary<SmallInt, string>; |
| 308 | arg4: TNumberz; const arg5: Int64): IXtruct; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 309 | var |
| 310 | hello : IXtruct; |
| 311 | begin |
| 312 | Console.WriteLine('testMulti()'); |
| 313 | hello := TXtructImpl.Create; |
| 314 | hello.String_thing := 'Hello2'; |
| 315 | hello.Byte_thing := arg0; |
| 316 | hello.I32_thing := arg1; |
| 317 | hello.I64_thing := arg2; |
| 318 | Result := hello; |
| 319 | end; |
| 320 | |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 321 | function TTestServer.TTestHandlerImpl.testMultiException( const arg0, arg1: string): IXtruct; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 322 | var |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 323 | x2 : TXception2; |
| 324 | begin |
| 325 | Console.WriteLine('testMultiException(' + arg0 + ', ' + arg1 + ')'); |
| 326 | if ( arg0 = 'Xception') then |
| 327 | begin |
Jens Geyer | d5436f5 | 2014-10-03 19:50:38 +0200 | [diff] [blame] | 328 | raise TXception.Create( 1001, 'This is an Xception'); // test the new rich CTOR |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 329 | end else |
| 330 | if ( arg0 = 'Xception2') then |
| 331 | begin |
Jake Farrell | 343c61d | 2011-12-09 02:29:56 +0000 | [diff] [blame] | 332 | x2 := TXception2.Create; // the old way still works too? |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 333 | x2.ErrorCode := 2002; |
| 334 | x2.Struct_thing := TXtructImpl.Create; |
| 335 | x2.Struct_thing.String_thing := 'This is an Xception2'; |
Jake Farrell | ac10256 | 2011-11-23 14:30:41 +0000 | [diff] [blame] | 336 | x2.UpdateMessageProperty; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 337 | raise x2; |
| 338 | end; |
| 339 | |
| 340 | Result := TXtructImpl.Create; |
| 341 | Result.String_thing := arg1; |
| 342 | end; |
| 343 | |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 344 | function TTestServer.TTestHandlerImpl.testNest( const thing: IXtruct2): IXtruct2; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 345 | var |
| 346 | temp : IXtruct; |
| 347 | begin |
| 348 | temp := thing.Struct_thing; |
| 349 | Console.WriteLine('testNest({' + |
| 350 | IntToStr( thing.Byte_thing) + ', {' + |
| 351 | '"' + temp.String_thing + '", ' + |
| 352 | IntToStr( temp.Byte_thing) + ', ' + |
| 353 | IntToStr( temp.I32_thing) + ', ' + |
| 354 | IntToStr( temp.I64_thing) + '}, ' + |
| 355 | IntToStr( temp.I32_thing) + '})'); |
| 356 | Result := thing; |
| 357 | end; |
| 358 | |
| 359 | procedure TTestServer.TTestHandlerImpl.testOneway(secondsToSleep: Integer); |
| 360 | begin |
| 361 | Console.WriteLine('testOneway(' + IntToStr( secondsToSleep )+ '), sleeping...'); |
| 362 | Sleep(secondsToSleep * 1000); |
| 363 | Console.WriteLine('testOneway finished'); |
| 364 | end; |
| 365 | |
| 366 | function TTestServer.TTestHandlerImpl.testSet( |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 367 | const thing: IHashSet<Integer>):IHashSet<Integer>; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 368 | var |
| 369 | first : Boolean; |
| 370 | elem : Integer; |
| 371 | begin |
| 372 | Console.Write('testSet({'); |
| 373 | first := True; |
| 374 | |
| 375 | for elem in thing do |
| 376 | begin |
| 377 | if first then |
| 378 | begin |
| 379 | first := False; |
| 380 | end else |
| 381 | begin |
| 382 | Console.Write( ', '); |
| 383 | end; |
| 384 | Console.Write( IntToStr( elem)); |
| 385 | end; |
| 386 | Console.WriteLine('})'); |
| 387 | Result := thing; |
| 388 | end; |
| 389 | |
| 390 | procedure TTestServer.TTestHandlerImpl.testStop; |
| 391 | begin |
| 392 | if FServer <> nil then |
| 393 | begin |
| 394 | FServer.Stop; |
| 395 | end; |
| 396 | end; |
| 397 | |
Jens Geyer | 39ba6b7 | 2015-09-22 00:00:49 +0200 | [diff] [blame] | 398 | function TTestServer.TTestHandlerImpl.testBool(thing: Boolean): Boolean; |
| 399 | begin |
| 400 | Console.WriteLine('testBool(' + BoolToStr(thing,true) + ')'); |
| 401 | Result := thing; |
| 402 | end; |
| 403 | |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 404 | function TTestServer.TTestHandlerImpl.testString( const thing: string): string; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 405 | begin |
| 406 | Console.WriteLine('teststring("' + thing + '")'); |
| 407 | Result := thing; |
| 408 | end; |
| 409 | |
| 410 | function TTestServer.TTestHandlerImpl.testStringMap( |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 411 | const thing: IThriftDictionary<string, string>): IThriftDictionary<string, string>; |
Roger Meier | bb6de7a | 2012-05-04 23:35:45 +0000 | [diff] [blame] | 412 | var |
| 413 | first : Boolean; |
| 414 | key : string; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 415 | begin |
Roger Meier | bb6de7a | 2012-05-04 23:35:45 +0000 | [diff] [blame] | 416 | Console.Write('testStringMap({'); |
| 417 | first := True; |
| 418 | for key in thing.Keys do |
| 419 | begin |
| 420 | if (first) then |
| 421 | begin |
| 422 | first := false; |
| 423 | end else |
| 424 | begin |
| 425 | Console.Write(', '); |
| 426 | end; |
| 427 | Console.Write(key + ' => ' + thing[key]); |
| 428 | end; |
| 429 | Console.WriteLine('})'); |
| 430 | Result := thing; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 431 | end; |
| 432 | |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 433 | function TTestServer.TTestHandlerImpl.testTypedef( const thing: Int64): Int64; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 434 | begin |
| 435 | Console.WriteLine('testTypedef(' + IntToStr( thing) + ')'); |
| 436 | Result := thing; |
| 437 | end; |
| 438 | |
| 439 | procedure TTestServer.TTestHandlerImpl.TestVoid; |
| 440 | begin |
| 441 | Console.WriteLine('testVoid()'); |
| 442 | end; |
| 443 | |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 444 | function TTestServer.TTestHandlerImpl.testStruct( const thing: IXtruct): IXtruct; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 445 | begin |
| 446 | Console.WriteLine('testStruct({' + |
| 447 | '"' + thing.String_thing + '", ' + |
| 448 | IntToStr( thing.Byte_thing) + ', ' + |
| 449 | IntToStr( thing.I32_thing) + ', ' + |
| 450 | IntToStr( thing.I64_thing)); |
| 451 | Result := thing; |
| 452 | end; |
| 453 | |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 454 | |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 455 | { TTestServer } |
| 456 | |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 457 | |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 458 | class procedure TTestServer.PrintCmdLineHelp; |
| 459 | const HELPTEXT = ' [options]'#10 |
| 460 | + #10 |
| 461 | + 'Allowed options:'#10 |
| 462 | + ' -h [ --help ] produce help message'#10 |
| 463 | + ' --port arg (=9090) Port number to listen'#10 |
| 464 | + ' --domain-socket arg Unix Domain Socket (e.g. /tmp/ThriftTest.thrift)'#10 |
| 465 | + ' --named-pipe arg Windows Named Pipe (e.g. MyThriftPipe)'#10 |
| 466 | + ' --server-type arg (=simple) type of server, "simple", "thread-pool",'#10 |
| 467 | + ' "threaded", or "nonblocking"'#10 |
| 468 | + ' --transport arg (=socket) transport: buffered, framed, http, anonpipe'#10 |
| 469 | + ' --protocol arg (=binary) protocol: binary, compact, json'#10 |
| 470 | + ' --ssl Encrypted Transport using SSL'#10 |
| 471 | + ' --processor-events processor-events'#10 |
| 472 | + ' -n [ --workers ] arg (=4) Number of thread pools workers. Only valid for'#10 |
| 473 | + ' thread-pool server type'#10 |
| 474 | ; |
| 475 | begin |
| 476 | Console.WriteLine( ChangeFileExt(ExtractFileName(ParamStr(0)),'') + HELPTEXT); |
| 477 | end; |
| 478 | |
| 479 | class procedure TTestServer.InvalidArgs; |
| 480 | begin |
| 481 | Console.WriteLine( 'Invalid args.'); |
| 482 | Console.WriteLine( ChangeFileExt(ExtractFileName(ParamStr(0)),'') + ' -h for more information'); |
| 483 | Abort; |
| 484 | end; |
| 485 | |
Jens Geyer | 06045cf | 2013-03-27 20:26:25 +0200 | [diff] [blame] | 486 | class procedure TTestServer.LaunchAnonPipeChild( const app : string; const transport : IAnonymousPipeServerTransport); |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 487 | //Launch child process and pass R/W anonymous pipe handles on cmd line. |
| 488 | //This is a simple example and does not include elevation or other |
| 489 | //advanced features. |
| 490 | var pi : PROCESS_INFORMATION; |
Jens Geyer | d5436f5 | 2014-10-03 19:50:38 +0200 | [diff] [blame] | 491 | si : STARTUPINFO; |
| 492 | sArg, sHandles, sCmdLine : string; |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 493 | i : Integer; |
| 494 | begin |
| 495 | GetStartupInfo( si); //set startupinfo for the spawned process |
| 496 | |
| 497 | // preformat handles args |
| 498 | sHandles := Format( '%d %d', |
| 499 | [ Integer(transport.ClientAnonRead), |
| 500 | Integer(transport.ClientAnonWrite)]); |
| 501 | |
| 502 | // pass all settings to client |
| 503 | sCmdLine := app; |
| 504 | for i := 1 to ParamCount do begin |
| 505 | sArg := ParamStr(i); |
| 506 | |
| 507 | // add anonymous handles and quote strings where appropriate |
| 508 | if sArg = '-anon' |
| 509 | then sArg := sArg +' '+ sHandles |
| 510 | else begin |
| 511 | if Pos(' ',sArg) > 0 |
| 512 | then sArg := '"'+sArg+'"'; |
| 513 | end;; |
| 514 | |
| 515 | sCmdLine := sCmdLine +' '+ sArg; |
| 516 | end; |
| 517 | |
| 518 | // spawn the child process |
| 519 | Console.WriteLine('Starting client '+sCmdLine); |
| 520 | Win32Check( CreateProcess( nil, PChar(sCmdLine), nil,nil,TRUE,0,nil,nil,si,pi)); |
| 521 | |
| 522 | CloseHandle( pi.hThread); |
Jens Geyer | d5436f5 | 2014-10-03 19:50:38 +0200 | [diff] [blame] | 523 | CloseHandle( pi.hProcess); |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 524 | end; |
| 525 | |
| 526 | |
Roger Meier | 333bbf3 | 2012-01-08 21:51:08 +0000 | [diff] [blame] | 527 | class procedure TTestServer.Execute( const args: array of string); |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 528 | var |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 529 | Port : Integer; |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 530 | ServerEvents : Boolean; |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 531 | sPipeName : string; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 532 | testHandler : ITestHandler; |
| 533 | testProcessor : IProcessor; |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 534 | ServerTrans : IServerTransport; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 535 | ServerEngine : IServer; |
Jens Geyer | 06045cf | 2013-03-27 20:26:25 +0200 | [diff] [blame] | 536 | anonymouspipe : IAnonymousPipeServerTransport; |
| 537 | namedpipe : INamedPipeServerTransport; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 538 | TransportFactory : ITransportFactory; |
| 539 | ProtocolFactory : IProtocolFactory; |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 540 | i, numWorker : Integer; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 541 | s : string; |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 542 | protType : TKnownProtocol; |
| 543 | servertype : TServerType; |
| 544 | endpoint : TEndpointTransport; |
| 545 | layered : TLayeredTransports; |
| 546 | UseSSL : Boolean; // include where appropriate (TLayeredTransport?) |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 547 | begin |
| 548 | try |
Jens Geyer | 0164040 | 2013-09-25 21:12:21 +0200 | [diff] [blame] | 549 | ServerEvents := FALSE; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 550 | protType := prot_Binary; |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 551 | servertype := srv_Simple; |
| 552 | endpoint := trns_Sockets; |
| 553 | layered := []; |
| 554 | UseSSL := FALSE; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 555 | Port := 9090; |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 556 | sPipeName := ''; |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 557 | numWorker := 4; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 558 | |
| 559 | i := 0; |
| 560 | while ( i < Length(args) ) do begin |
| 561 | s := args[i]; |
| 562 | Inc(i); |
| 563 | |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 564 | // Allowed options: |
| 565 | if (s = '-h') or (s = '--help') then begin |
| 566 | // -h [ --help ] produce help message |
| 567 | PrintCmdLineHelp; |
| 568 | Exit; |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 569 | end |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 570 | else if (s = '--port') then begin |
| 571 | // --port arg (=9090) Port number to listen |
| 572 | s := args[i]; |
| 573 | Inc(i); |
| 574 | Port := StrToIntDef( s, Port); |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 575 | end |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 576 | else if (s = '--domain-socket') then begin |
| 577 | // --domain-socket arg Unix Domain Socket (e.g. /tmp/ThriftTest.thrift) |
| 578 | raise Exception.Create('domain-socket not supported'); |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 579 | end |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 580 | else if (s = '--named-pipe') then begin |
| 581 | // --named-pipe arg Windows Named Pipe (e.g. MyThriftPipe) |
| 582 | endpoint := trns_NamedPipes; |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 583 | sPipeName := args[i]; // -pipe <name> |
| 584 | Inc( i ); |
| 585 | end |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 586 | else if (s = '--server-type') then begin |
| 587 | // --server-type arg (=simple) type of server, |
| 588 | // arg = "simple", "thread-pool", "threaded", or "nonblocking" |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 589 | s := args[i]; |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 590 | Inc(i); |
| 591 | |
| 592 | if s = 'simple' then servertype := srv_Simple |
| 593 | else if s = 'thread-pool' then servertype := srv_Threadpool |
| 594 | else if s = 'threaded' then servertype := srv_Threaded |
| 595 | else if s = 'nonblocking' then servertype := srv_Nonblocking |
| 596 | else InvalidArgs; |
Jens Geyer | 0164040 | 2013-09-25 21:12:21 +0200 | [diff] [blame] | 597 | end |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 598 | else if (s = '--transport') then begin |
| 599 | // --transport arg (=buffered) transport: buffered, framed, http |
| 600 | s := args[i]; |
| 601 | Inc(i); |
| 602 | |
| 603 | if s = 'buffered' then Include( layered, trns_Buffered) |
| 604 | else if s = 'framed' then Include( layered, trns_Framed) |
| 605 | else if s = 'http' then endpoint := trns_Http |
| 606 | else if s = 'anonpipe' then endpoint := trns_AnonPipes |
| 607 | else InvalidArgs; |
| 608 | end |
| 609 | else if (s = '--protocol') then begin |
| 610 | // --protocol arg (=binary) protocol: binary, compact, json |
| 611 | s := args[i]; |
| 612 | Inc(i); |
| 613 | |
| 614 | if s = 'binary' then protType := prot_Binary |
| 615 | else if s = 'compact' then protType := prot_Compact |
| 616 | else if s = 'json' then protType := prot_JSON |
| 617 | else InvalidArgs; |
| 618 | end |
| 619 | else if (s = '--ssl') then begin |
| 620 | // --ssl Encrypted Transport using SSL |
| 621 | UseSSL := TRUE; |
| 622 | end |
| 623 | else if (s = '--processor-events') then begin |
| 624 | // --processor-events processor-events |
| 625 | ServerEvents := TRUE; |
| 626 | end |
| 627 | else if (s = '-n') or (s = '--workers') then begin |
| 628 | // -n [ --workers ] arg (=4) Number of thread pools workers. |
| 629 | // Only valid for thread-pool server type |
| 630 | s := args[i]; |
| 631 | numWorker := StrToIntDef(s,0); |
| 632 | if numWorker > 0 |
| 633 | then Inc(i) |
| 634 | else numWorker := 4; |
Jens Geyer | 0164040 | 2013-09-25 21:12:21 +0200 | [diff] [blame] | 635 | end |
| 636 | else begin |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 637 | InvalidArgs; |
| 638 | end; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 639 | end; |
| 640 | |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 641 | |
| 642 | Console.WriteLine('Server configuration: '); |
| 643 | |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 644 | // create protocol factory, default to BinaryProtocol |
| 645 | case protType of |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 646 | prot_Binary : ProtocolFactory := TBinaryProtocolImpl.TFactory.Create( BINARY_STRICT_READ, BINARY_STRICT_WRITE); |
| 647 | prot_JSON : ProtocolFactory := TJSONProtocolImpl.TFactory.Create; |
Jens Geyer | f0e6331 | 2015-03-01 18:47:49 +0100 | [diff] [blame] | 648 | prot_Compact : ProtocolFactory := TCompactProtocolImpl.TFactory.Create; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 649 | else |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 650 | raise Exception.Create('Unhandled protocol'); |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 651 | end; |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 652 | ASSERT( ProtocolFactory <> nil); |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 653 | Console.WriteLine('- '+THRIFT_PROTOCOLS[protType]+' protocol'); |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 654 | |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 655 | case endpoint of |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 656 | |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 657 | trns_Sockets : begin |
| 658 | Console.WriteLine('- sockets (port '+IntToStr(port)+')'); |
| 659 | if (trns_Buffered in layered) then Console.WriteLine('- buffered'); |
| 660 | servertrans := TServerSocketImpl.Create( Port, 0, (trns_Buffered in layered)); |
| 661 | end; |
| 662 | |
| 663 | trns_Http : begin |
| 664 | raise Exception.Create('HTTP server transport not implemented'); |
| 665 | end; |
| 666 | |
| 667 | trns_NamedPipes : begin |
| 668 | Console.WriteLine('- named pipe ('+sPipeName+')'); |
Jens Geyer | 2ad6c30 | 2015-02-26 19:38:53 +0100 | [diff] [blame] | 669 | namedpipe := TNamedPipeServerTransportImpl.Create( sPipeName, 4096, PIPE_UNLIMITED_INSTANCES); |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 670 | servertrans := namedpipe; |
| 671 | end; |
| 672 | |
| 673 | trns_AnonPipes : begin |
| 674 | Console.WriteLine('- anonymous pipes'); |
| 675 | anonymouspipe := TAnonymousPipeServerTransportImpl.Create; |
| 676 | servertrans := anonymouspipe; |
| 677 | end |
| 678 | |
| 679 | else |
| 680 | raise Exception.Create('Unhandled endpoint transport'); |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 681 | end; |
| 682 | ASSERT( servertrans <> nil); |
| 683 | |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 684 | if UseSSL then begin |
| 685 | raise Exception.Create('SSL not implemented'); |
| 686 | end; |
| 687 | |
| 688 | if (trns_Framed in layered) then begin |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 689 | Console.WriteLine('- framed transport'); |
| 690 | TransportFactory := TFramedTransportImpl.TFactory.Create |
| 691 | end |
| 692 | else begin |
| 693 | TransportFactory := TTransportFactoryImpl.Create; |
| 694 | end; |
| 695 | ASSERT( TransportFactory <> nil); |
| 696 | |
| 697 | testHandler := TTestHandlerImpl.Create; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 698 | testProcessor := TThriftTest.TProcessorImpl.Create( testHandler ); |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 699 | |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 700 | case servertype of |
| 701 | srv_Simple : begin |
| 702 | ServerEngine := TSimpleServer.Create( testProcessor, ServerTrans, TransportFactory, ProtocolFactory); |
| 703 | end; |
| 704 | |
| 705 | srv_Nonblocking : begin |
| 706 | raise Exception.Create(SERVER_TYPES[servertype]+' server not implemented'); |
| 707 | end; |
| 708 | |
| 709 | srv_Threadpool, |
| 710 | srv_Threaded: begin |
| 711 | if numWorker > 1 then {use here}; |
| 712 | raise Exception.Create(SERVER_TYPES[servertype]+' server not implemented'); |
| 713 | end; |
| 714 | |
| 715 | else |
| 716 | raise Exception.Create('Unhandled server type'); |
| 717 | end; |
| 718 | ASSERT( ServerEngine <> nil); |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 719 | |
| 720 | testHandler.SetServer( ServerEngine); |
| 721 | |
Jens Geyer | 0164040 | 2013-09-25 21:12:21 +0200 | [diff] [blame] | 722 | // test events? |
| 723 | if ServerEvents then begin |
| 724 | Console.WriteLine('- server events test enabled'); |
| 725 | ServerEngine.ServerEvents := TServerEventsImpl.Create; |
| 726 | end; |
| 727 | |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 728 | // start the client now when we have the anon handles, but before the server starts |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 729 | if endpoint = trns_AnonPipes |
Roger Meier | 79655fb | 2012-10-20 20:59:41 +0000 | [diff] [blame] | 730 | then LaunchAnonPipeChild( ExtractFilePath(ParamStr(0))+'client.exe', anonymouspipe); |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 731 | |
Jens Geyer | 06045cf | 2013-03-27 20:26:25 +0200 | [diff] [blame] | 732 | // install Ctrl+C handler before the server starts |
| 733 | g_Handler := testHandler; |
| 734 | SetConsoleCtrlHandler( @MyConsoleEventHandler, TRUE); |
Roger Meier | 3bef8c2 | 2012-10-06 06:58:00 +0000 | [diff] [blame] | 735 | |
| 736 | Console.WriteLine(''); |
Jens Geyer | 06045cf | 2013-03-27 20:26:25 +0200 | [diff] [blame] | 737 | repeat |
| 738 | Console.WriteLine('Starting the server ...'); |
| 739 | serverEngine.Serve; |
| 740 | until {$IFDEF RunEndless} FALSE {$ELSE} TRUE {$ENDIF}; |
| 741 | |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 742 | testHandler.SetServer( nil); |
Jens Geyer | 06045cf | 2013-03-27 20:26:25 +0200 | [diff] [blame] | 743 | g_Handler := nil; |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 744 | |
| 745 | except |
Jens Geyer | f8a1b7a | 2014-09-24 00:26:46 +0200 | [diff] [blame] | 746 | on E: EAbort do raise; |
| 747 | on E: Exception do begin |
| 748 | Console.WriteLine( E.Message + #10 + E.StackTrace ); |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 749 | end; |
| 750 | end; |
| 751 | Console.WriteLine( 'done.'); |
| 752 | end; |
| 753 | |
Jens Geyer | 06045cf | 2013-03-27 20:26:25 +0200 | [diff] [blame] | 754 | |
Jake Farrell | 2727422 | 2011-11-10 20:32:44 +0000 | [diff] [blame] | 755 | end. |