blob: 50ae4c16ea336b8d3b99b14235cb55443a3d5c05 [file] [log] [blame]
David Reissea2cba82009-03-30 21:35:00 +00001/*
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
Roger Meier213a6642010-10-27 12:30:11 +000020namespace c_glib TTest
David Reiss2a4bfd62008-04-07 23:45:00 +000021namespace cpp thrift.test.debug
David Reiss3b15ebc2008-03-02 06:29:19 +000022namespace java thrift.test
Jens Geyer123258b2015-10-02 00:38:17 +020023namespace rb thrift.test
David Reiss00dcccf2007-07-21 01:18:10 +000024
David Reissdb0ea152008-02-18 01:49:37 +000025struct Doubles {
26 1: double nan,
27 2: double inf,
28 3: double neginf,
29 4: double repeating,
30 5: double big,
Roger Meier22888ce2014-02-09 11:31:02 +010031 6: double tiny,
David Reissdb0ea152008-02-18 01:49:37 +000032 7: double zero,
33 8: double negzero,
34}
35
David Reiss00dcccf2007-07-21 01:18:10 +000036struct OneOfEach {
37 1: bool im_true,
38 2: bool im_false,
Christian Lavoiecbf87cb2010-11-28 14:34:26 +000039 3: byte a_bite = 0x7f,
40 4: i16 integer16 = 0x7fff,
David Reiss00dcccf2007-07-21 01:18:10 +000041 5: i32 integer32,
David Reissa8efac82008-12-16 20:28:13 +000042 6: i64 integer64 = 10000000000,
David Reiss00dcccf2007-07-21 01:18:10 +000043 7: double double_precision,
44 8: string some_characters,
45 9: string zomg_unicode,
46 10: bool what_who,
David Reissdb0ea152008-02-18 01:49:37 +000047 11: binary base64,
David Reissa8efac82008-12-16 20:28:13 +000048 12: list<byte> byte_list = [1, 2, 3],
49 13: list<i16> i16_list = [1,2,3],
50 14: list<i64> i64_list = [1,2,3]
David Reiss00dcccf2007-07-21 01:18:10 +000051}
52
53struct Bonk {
54 1: i32 type,
55 2: string message,
56}
57
58struct Nesting {
59 1: Bonk my_bonk,
60 2: OneOfEach my_ooe,
61}
62
63struct HolyMoley {
64 1: list<OneOfEach> big,
65 2: set<list<string>> contain,
66 3: map<string,list<Bonk>> bonks,
67}
David Reiss382fc302007-08-25 18:01:30 +000068
69struct Backwards {
70 2: i32 first_tag2,
71 1: i32 second_tag1,
72}
73
74struct Empty {
75}
76
77struct Wrapper {
78 1: Empty foo
79}
80
81struct RandomStuff {
82 1: i32 a,
83 2: i32 b,
84 3: i32 c,
85 4: i32 d,
86 5: list<i32> myintlist,
87 6: map<i32,Wrapper> maps,
88 7: i64 bigint,
89 8: double triple,
90}
91
David Reiss4a8f46c2008-03-07 20:12:07 +000092struct Base64 {
93 1: i32 a,
94 2: binary b1,
95 3: binary b2,
96 4: binary b3,
97 5: binary b4,
98 6: binary b5,
99 7: binary b6,
100}
101
Bryan Duxbury538e3442009-02-10 04:49:39 +0000102struct CompactProtoTestStruct {
103 // primitive fields
David Reissfe5b77d2009-04-07 20:51:48 +0000104 1: byte a_byte;
105 2: i16 a_i16;
106 3: i32 a_i32;
107 4: i64 a_i64;
108 5: double a_double;
109 6: string a_string;
Bryan Duxbury538e3442009-02-10 04:49:39 +0000110 7: binary a_binary;
David Reissfe5b77d2009-04-07 20:51:48 +0000111 8: bool true_field;
112 9: bool false_field;
113 10: Empty empty_struct_field;
Jens Geyeraaa89472014-10-03 20:22:28 +0200114
Bryan Duxbury538e3442009-02-10 04:49:39 +0000115 // primitives in lists
David Reissfe5b77d2009-04-07 20:51:48 +0000116 11: list<byte> byte_list;
117 12: list<i16> i16_list;
118 13: list<i32> i32_list;
119 14: list<i64> i64_list;
120 15: list<double> double_list;
121 16: list<string> string_list;
Bryan Duxbury538e3442009-02-10 04:49:39 +0000122 17: list<binary> binary_list;
David Reissfe5b77d2009-04-07 20:51:48 +0000123 18: list<bool> boolean_list;
124 19: list<Empty> struct_list;
Jens Geyeraaa89472014-10-03 20:22:28 +0200125
Bryan Duxbury538e3442009-02-10 04:49:39 +0000126 // primitives in sets
David Reissfe5b77d2009-04-07 20:51:48 +0000127 20: set<byte> byte_set;
128 21: set<i16> i16_set;
129 22: set<i32> i32_set;
130 23: set<i64> i64_set;
131 24: set<double> double_set;
132 25: set<string> string_set;
Bryan Duxbury538e3442009-02-10 04:49:39 +0000133 26: set<binary> binary_set;
David Reissfe5b77d2009-04-07 20:51:48 +0000134 27: set<bool> boolean_set;
135 28: set<Empty> struct_set;
Jens Geyeraaa89472014-10-03 20:22:28 +0200136
Bryan Duxbury538e3442009-02-10 04:49:39 +0000137 // maps
138 // primitives as keys
David Reissfe5b77d2009-04-07 20:51:48 +0000139 29: map<byte, byte> byte_byte_map;
140 30: map<i16, byte> i16_byte_map;
141 31: map<i32, byte> i32_byte_map;
142 32: map<i64, byte> i64_byte_map;
143 33: map<double, byte> double_byte_map;
144 34: map<string, byte> string_byte_map;
Bryan Duxbury538e3442009-02-10 04:49:39 +0000145 35: map<binary, byte> binary_byte_map;
David Reissfe5b77d2009-04-07 20:51:48 +0000146 36: map<bool, byte> boolean_byte_map;
Bryan Duxbury538e3442009-02-10 04:49:39 +0000147 // primitives as values
David Reissfe5b77d2009-04-07 20:51:48 +0000148 37: map<byte, i16> byte_i16_map;
149 38: map<byte, i32> byte_i32_map;
150 39: map<byte, i64> byte_i64_map;
151 40: map<byte, double> byte_double_map;
152 41: map<byte, string> byte_string_map;
Bryan Duxbury538e3442009-02-10 04:49:39 +0000153 42: map<byte, binary> byte_binary_map;
David Reissfe5b77d2009-04-07 20:51:48 +0000154 43: map<byte, bool> byte_boolean_map;
Bryan Duxbury538e3442009-02-10 04:49:39 +0000155 // collections as keys
David Reissfe5b77d2009-04-07 20:51:48 +0000156 44: map<list<byte>, byte> list_byte_map;
157 45: map<set<byte>, byte> set_byte_map;
158 46: map<map<byte,byte>, byte> map_byte_map;
Bryan Duxbury538e3442009-02-10 04:49:39 +0000159 // collections as values
David Reissfe5b77d2009-04-07 20:51:48 +0000160 47: map<byte, map<byte,byte>> byte_map_map;
161 48: map<byte, set<byte>> byte_set_map;
162 49: map<byte, list<byte>> byte_list_map;
163}
164
Bryan Duxburye80a1942011-09-20 18:45:56 +0000165// To be used to test the serialization of an empty map
166struct SingleMapTestStruct {
167 1: required map<i32, i32> i32_map;
168}
David Reissfe5b77d2009-04-07 20:51:48 +0000169
170const CompactProtoTestStruct COMPACT_TEST = {
171 'a_byte' : 127,
172 'a_i16' : 32000,
173 'a_i32' : 1000000000,
174 'a_i64' : 0xffffffffff,
175 'a_double' : 5.6789,
176 'a_string' : "my string",
177//'a_binary,'
178 'true_field' : 1,
179 'false_field' : 0,
180 'empty_struct_field' : {},
181 'byte_list' : [-127, -1, 0, 1, 127],
182 'i16_list' : [-1, 0, 1, 0x7fff],
183 'i32_list' : [-1, 0, 0xff, 0xffff, 0xffffff, 0x7fffffff],
184 'i64_list' : [-1, 0, 0xff, 0xffff, 0xffffff, 0xffffffff, 0xffffffffff, 0xffffffffffff, 0xffffffffffffff, 0x7fffffffffffffff],
185 'double_list' : [0.1, 0.2, 0.3],
186 'string_list' : ["first", "second", "third"],
187//'binary_list,'
188 'boolean_list' : [1, 1, 1, 0, 0, 0],
189 'struct_list' : [{}, {}],
190 'byte_set' : [-127, -1, 0, 1, 127],
191 'i16_set' : [-1, 0, 1, 0x7fff],
192 'i32_set' : [1, 2, 3],
193 'i64_set' : [-1, 0, 0xff, 0xffff, 0xffffff, 0xffffffff, 0xffffffffff, 0xffffffffffff, 0xffffffffffffff, 0x7fffffffffffffff],
194 'double_set' : [0.1, 0.2, 0.3],
195 'string_set' : ["first", "second", "third"],
196//'binary_set,'
197 'boolean_set' : [1, 0],
198 'struct_set' : [{}],
199 'byte_byte_map' : {1 : 2},
200 'i16_byte_map' : {1 : 1, -1 : 1, 0x7fff : 1},
201 'i32_byte_map' : {1 : 1, -1 : 1, 0x7fffffff : 1},
202 'i64_byte_map' : {0 : 1, 1 : 1, -1 : 1, 0x7fffffffffffffff : 1},
203 'double_byte_map' : {-1.1 : 1, 1.1 : 1},
204 'string_byte_map' : {"first" : 1, "second" : 2, "third" : 3, "" : 0},
205//'binary_byte_map,'
206 'boolean_byte_map' : {1 : 1, 0 : 0},
207 'byte_i16_map' : {1 : 1, 2 : -1, 3 : 0x7fff},
208 'byte_i32_map' : {1 : 1, 2 : -1, 3 : 0x7fffffff},
209 'byte_i64_map' : {1 : 1, 2 : -1, 3 : 0x7fffffffffffffff},
210 'byte_double_map' : {1 : 0.1, 2 : -0.1, 3 : 1000000.1},
211 'byte_string_map' : {1 : "", 2 : "blah", 3 : "loooooooooooooong string"},
212//'byte_binary_map,'
213 'byte_boolean_map' : {1 : 1, 2 : 0},
214 'list_byte_map' : {[1, 2, 3] : 1, [0, 1] : 2, [] : 0},
215 'set_byte_map' : {[1, 2, 3] : 1, [0, 1] : 2, [] : 0},
216 'map_byte_map' : {{1 : 1} : 1, {2 : 2} : 2, {} : 0},
217 'byte_map_map' : {0 : {}, 1 : {1 : 1}, 2 : {1 : 1, 2 : 2}},
218 'byte_set_map' : {0 : [], 1 : [1], 2 : [1, 2]},
219 'byte_list_map' : {0 : [], 1 : [1], 2 : [1, 2]},
Bryan Duxbury538e3442009-02-10 04:49:39 +0000220}
Bryan Duxbury5b8b4842009-04-01 20:10:15 +0000221
222
Bryan Duxbury2d804702009-12-18 19:41:11 +0000223const i32 MYCONST = 2
Bryan Duxbury5b8b4842009-04-01 20:10:15 +0000224
Bryan Duxbury986d50f2009-12-31 18:18:00 +0000225
226exception ExceptionWithAMap {
227 1: string blah;
228 2: map<string, string> map_field;
229}
230
231service ServiceForExceptionWithAMap {
232 void methodThatThrowsAnException() throws (1: ExceptionWithAMap xwamap);
233}
234
Bryan Duxbury5b8b4842009-04-01 20:10:15 +0000235service Srv {
David Reiss689c9ad2009-04-02 19:24:02 +0000236 i32 Janky(1: i32 arg);
Bryan Duxburyd58ccec2010-05-26 16:34:48 +0000237
Bryan Duxbury5b8b4842009-04-01 20:10:15 +0000238 // return type only methods
Bryan Duxburyd58ccec2010-05-26 16:34:48 +0000239
Bryan Duxbury5b8b4842009-04-01 20:10:15 +0000240 void voidMethod();
241 i32 primitiveMethod();
242 CompactProtoTestStruct structMethod();
Bryan Duxburyd58ccec2010-05-26 16:34:48 +0000243
Bryan Duxbury2d804702009-12-18 19:41:11 +0000244 void methodWithDefaultArgs(1: i32 something = MYCONST);
Bryan Duxburyd58ccec2010-05-26 16:34:48 +0000245
246 oneway void onewayMethod();
Bryan Duxbury5b8b4842009-04-01 20:10:15 +0000247}
248
249service Inherited extends Srv {
David Reiss689c9ad2009-04-02 19:24:02 +0000250 i32 identity(1: i32 arg)
Bryan Duxbury5b8b4842009-04-01 20:10:15 +0000251}
252
253service EmptyService {}
254
255// The only purpose of this thing is to increase the size of the generated code
256// so that ZlibTest has more highly compressible data to play with.
257struct BlowUp {
258 1: map<list<i32>,set<map<i32,string>>> b1;
259 2: map<list<i32>,set<map<i32,string>>> b2;
260 3: map<list<i32>,set<map<i32,string>>> b3;
261 4: map<list<i32>,set<map<i32,string>>> b4;
262}
263
Bryan Duxburyff219ac2009-04-10 21:51:00 +0000264
265struct ReverseOrderStruct {
266 4: string first;
267 3: i16 second;
268 2: i32 third;
269 1: i64 fourth;
270}
271
272service ReverseOrderService {
273 void myMethod(4: string first, 3: i16 second, 2: i32 third, 1: i64 fourth);
Bryan Duxburyab3666e2009-09-01 23:03:47 +0000274}
275
Bryan Duxbury9af23d92009-11-19 17:26:38 +0000276enum SomeEnum {
Bryan Duxbury2d804702009-12-18 19:41:11 +0000277 ONE = 1
278 TWO = 2
279}
280
Bryan Duxburyd4235e02010-09-13 16:28:53 +0000281/** This is a docstring on a constant! */
Bryan Duxbury6e05e252010-09-12 15:22:49 +0000282const SomeEnum MY_SOME_ENUM = SomeEnum.ONE
Bryan Duxbury2d804702009-12-18 19:41:11 +0000283
284const SomeEnum MY_SOME_ENUM_1 = 1
285/*const SomeEnum MY_SOME_ENUM_2 = 7*/
286
287const map<SomeEnum,SomeEnum> MY_ENUM_MAP = {
Bryan Duxbury6e05e252010-09-12 15:22:49 +0000288 SomeEnum.ONE : SomeEnum.TWO
Bryan Duxbury2d804702009-12-18 19:41:11 +0000289}
290
291struct StructWithSomeEnum {
292 1: SomeEnum blah;
293}
294
295const map<SomeEnum,StructWithSomeEnum> EXTRA_CRAZY_MAP = {
Bryan Duxbury6e05e252010-09-12 15:22:49 +0000296 SomeEnum.ONE : {"blah" : SomeEnum.TWO}
Bryan Duxbury9af23d92009-11-19 17:26:38 +0000297}
298
Bryan Duxburyab3666e2009-09-01 23:03:47 +0000299union TestUnion {
300 /**
301 * A doc string
302 */
303 1: string string_field;
304 2: i32 i32_field;
305 3: OneOfEach struct_field;
306 4: list<RandomStuff> struct_list;
307 5: i32 other_i32_field;
Bryan Duxbury9af23d92009-11-19 17:26:38 +0000308 6: SomeEnum enum_field;
Bryan Duxbury162b3ac2010-06-23 21:17:48 +0000309 7: set<i32> i32_set;
310 8: map<i32, i32> i32_map;
Bryan Duxburyab3666e2009-09-01 23:03:47 +0000311}
312
Bryan Duxburyc2ec7ca2009-12-31 18:59:15 +0000313union TestUnionMinusStringField {
314 2: i32 i32_field;
315 3: OneOfEach struct_field;
316 4: list<RandomStuff> struct_list;
317 5: i32 other_i32_field;
318 6: SomeEnum enum_field;
Bryan Duxbury162b3ac2010-06-23 21:17:48 +0000319 7: set<i32> i32_set;
320 8: map<i32, i32> i32_map;
Bryan Duxburyc2ec7ca2009-12-31 18:59:15 +0000321}
322
Bryan Duxburye2e4ea12009-11-11 21:01:35 +0000323union ComparableUnion {
324 1: string string_field;
325 2: binary binary_field;
326}
327
Bryan Duxburyab3666e2009-09-01 23:03:47 +0000328struct StructWithAUnion {
329 1: TestUnion test_union;
Bryan Duxbury51f28802009-10-01 20:53:45 +0000330}
331
332struct PrimitiveThenStruct {
333 1: i32 blah;
334 2: i32 blah2;
335 3: Backwards bw;
Bryan Duxbury2845b162009-11-09 15:55:22 +0000336}
337
338typedef map<i32,i32> SomeMap
339
340struct StructWithASomemap {
341 1: required SomeMap somemap_field;
Bryan Duxbury986d50f2009-12-31 18:18:00 +0000342}
Bryan Duxbury35565a42010-01-06 23:12:09 +0000343
344struct BigFieldIdStruct {
345 1: string field1;
346 45: string field2;
347}
348
349struct BreaksRubyCompactProtocol {
350 1: string field1;
351 2: BigFieldIdStruct field2;
352 3: i32 field3;
Bryan Duxbury162b3ac2010-06-23 21:17:48 +0000353}
354
Bryan Duxbury40d51a22011-09-26 21:29:15 +0000355struct TupleProtocolTestStruct {
356 optional i32 field1;
357 optional i32 field2;
358 optional i32 field3;
359 optional i32 field4;
360 optional i32 field5;
361 optional i32 field6;
362 optional i32 field7;
363 optional i32 field8;
364 optional i32 field9;
365 optional i32 field10;
366 optional i32 field11;
367 optional i32 field12;
Ben Craig384f9762015-07-08 20:33:03 -0500368}
369
370struct ListDoublePerf {
371 1: list<double> field;
372}