blob: 2be53fa24f1bc7177cd7ceee743046f3286e3cd5 [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.
Todd Lipcon53ae9f32009-12-07 00:42:38 +000018 *
19 * Contains some contributions under the Thrift Software License.
20 * Please see doc/old-thrift-license.txt in the Thrift distribution for
21 * details.
David Reissea2cba82009-03-30 21:35:00 +000022 */
23
Roger Meier213a6642010-10-27 12:30:11 +000024namespace c_glib TTest
David Reiss771f8c72008-02-27 01:55:25 +000025namespace java thrift.test
David Reiss9a08dc62008-02-27 01:55:17 +000026namespace cpp thrift.test
David Reiss6a4b82c2008-03-27 21:42:16 +000027namespace rb Thrift.Test
David Reiss07ef3a92008-03-27 21:42:39 +000028namespace perl ThriftTest
David Reiss9d65bf02008-03-27 21:41:37 +000029namespace csharp Thrift.Test
T Jake Luciani322caa22010-02-15 03:24:55 +000030namespace js ThriftTest
Bryan Duxbury4d8a9cd2010-08-30 17:09:58 +000031namespace st ThriftTest
Anthony F. Molinaro0b4936d2010-09-27 04:43:39 +000032namespace py ThriftTest
Roger Meier50e43492010-10-08 17:46:06 +000033namespace py.twisted ThriftTest
Christian Lavoieafc6d8f2011-02-20 02:39:19 +000034namespace go ThriftTest
Bryan Duxbury1d373bc2011-03-02 18:13:30 +000035namespace php ThriftTest
Jake Farrell7ae13e12011-10-18 14:35:26 +000036namespace delphi Thrift.Test
Jake Farrell9689d892011-12-06 01:07:17 +000037namespace cocoa ThriftTest
David Reissfb790d72010-09-02 16:41:45 +000038namespace * thrift.test
Marc Slemko17859852006-08-15 00:21:31 +000039
Bryan Duxbury9af23d92009-11-19 17:26:38 +000040/**
41 * Docstring!
42 */
Mark Sleee8540632006-05-30 09:24:40 +000043enum Numberz
44{
45 ONE = 1,
46 TWO,
47 THREE,
48 FIVE = 5,
49 SIX,
50 EIGHT = 8
51}
52
Bryan Duxbury9f0a7862010-09-12 14:38:36 +000053const Numberz myNumberz = Numberz.ONE;
54// the following is expected to fail:
55// const Numberz urNumberz = ONE;
56
Mark Slee6e536442006-06-30 18:28:50 +000057typedef i64 UserId
Mark Sleee8540632006-05-30 09:24:40 +000058
Mark Sleee129a2d2007-02-21 05:17:48 +000059struct Bonk
60{
61 1: string message,
62 2: i32 type
63}
64
Kevin Clark9a863ee2009-03-24 16:04:36 +000065struct Bools {
66 1: bool im_true,
67 2: bool im_false,
68}
69
Mark Sleee8540632006-05-30 09:24:40 +000070struct Xtruct
71{
Mark Sleea3302652006-10-25 19:03:32 +000072 1: string string_thing,
73 4: byte byte_thing,
74 9: i32 i32_thing,
75 11: i64 i64_thing
Mark Sleee8540632006-05-30 09:24:40 +000076}
77
78struct Xtruct2
79{
Mark Sleea3302652006-10-25 19:03:32 +000080 1: byte byte_thing,
81 2: Xtruct struct_thing,
82 3: i32 i32_thing
Mark Sleee8540632006-05-30 09:24:40 +000083}
84
David Reiss233ace52009-03-30 20:46:47 +000085struct Xtruct3
86{
87 1: string string_thing,
88 4: i32 changed,
89 9: i32 i32_thing,
90 11: i64 i64_thing
91}
92
93
Mark Sleee8540632006-05-30 09:24:40 +000094struct Insanity
95{
Mark Sleea3302652006-10-25 19:03:32 +000096 1: map<Numberz, UserId> userMap,
97 2: list<Xtruct> xtructs
Mark Sleee8540632006-05-30 09:24:40 +000098}
99
Bryan Duxbury986d7052009-01-29 01:51:08 +0000100struct CrazyNesting {
101 1: string string_field,
102 2: optional set<Insanity> set_field,
Bryan Duxburyb3d0aa02010-10-06 20:00:03 +0000103 3: required list< map<set<i32>,map<i32,set<list<map<Insanity,string>>>>>> list_field,
104 4: binary binary_field
Bryan Duxbury986d7052009-01-29 01:51:08 +0000105}
106
Marc Slemkobf4fd192006-08-15 21:29:39 +0000107exception Xception {
Mark Sleea3302652006-10-25 19:03:32 +0000108 1: i32 errorCode,
109 2: string message
Marc Slemkod8b10512006-08-14 23:30:37 +0000110}
111
Marc Slemkobf4fd192006-08-15 21:29:39 +0000112exception Xception2 {
Mark Sleea3302652006-10-25 19:03:32 +0000113 1: i32 errorCode,
114 2: Xtruct struct_thing
Marc Slemkod8b10512006-08-14 23:30:37 +0000115}
Mark Slee27ed6ec2007-08-16 01:26:31 +0000116
Mark Sleed3d733a2006-09-01 22:19:06 +0000117struct EmptyStruct {}
118
Marc Slemkod8b10512006-08-14 23:30:37 +0000119struct OneField {
Mark Sleea3302652006-10-25 19:03:32 +0000120 1: EmptyStruct field
Marc Slemkod8b10512006-08-14 23:30:37 +0000121}
Marc Slemko5b126d62006-08-11 23:03:42 +0000122
Mark Sleee8540632006-05-30 09:24:40 +0000123service ThriftTest
124{
Roger Meier1f8b48f2012-05-02 22:56:47 +0000125 /**
126 * Prints "testVoid()" and returns nothing.
127 */
Marc Slemkod8b10512006-08-14 23:30:37 +0000128 void testVoid(),
Roger Meier1f8b48f2012-05-02 22:56:47 +0000129
130 /**
131 * Prints 'testString("%s")' with thing as '%s'
132 * @param string thing - the string to print
133 * @return string - returns the string 'thing'
134 */
Mark Sleea3302652006-10-25 19:03:32 +0000135 string testString(1: string thing),
Roger Meier1f8b48f2012-05-02 22:56:47 +0000136
137 /**
138 * Prints 'testByte("%d")' with thing as '%d'
139 * @param byte thing - the byte to print
140 * @return byte - returns the byte 'thing'
141 */
Mark Sleea3302652006-10-25 19:03:32 +0000142 byte testByte(1: byte thing),
Roger Meier1f8b48f2012-05-02 22:56:47 +0000143
144 /**
145 * Prints 'testI32("%d")' with thing as '%d'
146 * @param i32 thing - the i32 to print
147 * @return i32 - returns the i32 'thing'
148 */
Mark Sleea3302652006-10-25 19:03:32 +0000149 i32 testI32(1: i32 thing),
Roger Meier1f8b48f2012-05-02 22:56:47 +0000150
151 /**
152 * Prints 'testI64("%d")' with thing as '%d'
153 * @param i64 thing - the i64 to print
154 * @return i64 - returns the i64 'thing'
155 */
Mark Sleea3302652006-10-25 19:03:32 +0000156 i64 testI64(1: i64 thing),
Roger Meier1f8b48f2012-05-02 22:56:47 +0000157
158 /**
159 * Prints 'testDouble("%f")' with thing as '%f'
160 * @param double thing - the double to print
161 * @return double - returns the double 'thing'
162 */
Mark Sleea3302652006-10-25 19:03:32 +0000163 double testDouble(1: double thing),
Roger Meier1f8b48f2012-05-02 22:56:47 +0000164
165 /**
166 * Prints 'testStruct("{%s}")' where thing has been formatted into a string of comma seperated values
167 * @param Xtruct thing - the Xtruct to print
168 * @return Xtruct - returns the Xtruct 'thing'
169 */
Mark Sleea3302652006-10-25 19:03:32 +0000170 Xtruct testStruct(1: Xtruct thing),
Roger Meier1f8b48f2012-05-02 22:56:47 +0000171
172 /**
173 * Prints 'testNest("{%s}")' where thing has been formatted into a string of the nested struct
174 * @param Xtruct2 thing - the Xtruct2 to print
175 * @return Xtruct2 - returns the Xtruct2 'thing'
176 */
Mark Sleea3302652006-10-25 19:03:32 +0000177 Xtruct2 testNest(1: Xtruct2 thing),
Roger Meier1f8b48f2012-05-02 22:56:47 +0000178
179 /**
180 * Prints 'testMap("{%s")' where thing has been formatted into a string of 'key => value' pairs
181 * seperated by commas and new lines
182 * @param map<i32,i32> thing - the map<i32,i32> to print
183 * @return map<i32,i32> - returns the map<i32,i32> 'thing'
184 */
Mark Sleea3302652006-10-25 19:03:32 +0000185 map<i32,i32> testMap(1: map<i32,i32> thing),
Roger Meier1f8b48f2012-05-02 22:56:47 +0000186
187 /**
188 * Prints 'testStringMap("{%s}")' where thing has been formatted into a string of 'key => value' pairs
189 * seperated by commas and new lines
190 * @param map<string,string> thing - the map<string,string> to print
191 * @return map<string,string> - returns the map<string,string> 'thing'
192 */
Roger Meier9d8e8f82011-06-14 19:38:27 +0000193 map<string,string> testStringMap(1: map<string,string> thing),
Roger Meier1f8b48f2012-05-02 22:56:47 +0000194
195 /**
196 * Prints 'testSet("{%s}")' where thing has been formatted into a string of values
197 * seperated by commas and new lines
198 * @param set<i32> thing - the set<i32> to print
199 * @return set<i32> - returns the set<i32> 'thing'
200 */
Mark Sleea3302652006-10-25 19:03:32 +0000201 set<i32> testSet(1: set<i32> thing),
Roger Meier1f8b48f2012-05-02 22:56:47 +0000202
203 /**
204 * Prints 'testList("{%s}")' where thing has been formatted into a string of values
205 * seperated by commas and new lines
206 * @param list<i32> thing - the list<i32> to print
207 * @return list<i32> - returns the list<i32> 'thing'
208 */
Mark Sleea3302652006-10-25 19:03:32 +0000209 list<i32> testList(1: list<i32> thing),
Roger Meier1f8b48f2012-05-02 22:56:47 +0000210
211 /**
212 * Prints 'testEnum("%d")' where thing has been formatted into it's numeric value
213 * @param Numberz thing - the Numberz to print
214 * @return Numberz - returns the Numberz 'thing'
215 */
Mark Sleea3302652006-10-25 19:03:32 +0000216 Numberz testEnum(1: Numberz thing),
Roger Meier1f8b48f2012-05-02 22:56:47 +0000217
218 /**
219 * Prints 'testTypedef("%d")' with thing as '%d'
220 * @param UserId thing - the UserId to print
221 * @return UserId - returns the UserId 'thing'
222 */
Mark Sleea3302652006-10-25 19:03:32 +0000223 UserId testTypedef(1: UserId thing),
Mark Sleee8540632006-05-30 09:24:40 +0000224
Roger Meier1f8b48f2012-05-02 22:56:47 +0000225 /**
226 * Prints 'testMapMap("%d")' with hello as '%d'
227 * @param i32 hello - the i32 to print
228 * @return map<i32,map<i32,i32>> - returns a dictionary with these values:
229 * {-4 => {-4 => -4, -3 => -3, -2 => -2, -1 => -1, }, 4 => {1 => 1, 2 => 2, 3 => 3, 4 => 4, }, }
230 */
Mark Sleea3302652006-10-25 19:03:32 +0000231 map<i32,map<i32,i32>> testMapMap(1: i32 hello),
Mark Sleee8540632006-05-30 09:24:40 +0000232
Roger Meier1f8b48f2012-05-02 22:56:47 +0000233 /**
234 * So you think you've got this all worked, out eh?
235 *
236 * Creates a the returned map with these values and prints it out:
237 * { 1 => { 2 => argument,
238 * 3 => argument,
239 * },
240 * 2 => { 6 => <empty Insanity struct>, },
241 * }
242 * @return map<UserId, map<Numberz,Insanity>> - a map with the above values
243 */
Mark Sleea3302652006-10-25 19:03:32 +0000244 map<UserId, map<Numberz,Insanity>> testInsanity(1: Insanity argument),
Marc Slemkod8b10512006-08-14 23:30:37 +0000245
Roger Meier1f8b48f2012-05-02 22:56:47 +0000246 /**
247 * Prints 'testMulti()'
248 * @param byte arg0 -
249 * @param i32 arg1 -
250 * @param i64 arg2 -
251 * @param map<i16, string> arg3 -
252 * @param Numberz arg4 -
253 * @param UserId arg5 -
254 * @return Xtruct - returns an Xtruct with string_thing = "Hello2, byte_thing = arg0, i32_thing = arg1
255 * and i64_thing = arg2
256 */
David Reiss689c9ad2009-04-02 19:24:02 +0000257 Xtruct testMulti(1: byte arg0, 2: i32 arg1, 3: i64 arg2, 4: map<i16, string> arg3, 5: Numberz arg4, 6: UserId arg5),
Marc Slemkod8b10512006-08-14 23:30:37 +0000258
Roger Meier1f8b48f2012-05-02 22:56:47 +0000259 /**
260 * Print 'testException(%s)' with arg as '%s'
261 * @param string arg - a string indication what type of exception to throw
262 * if arg == "Xception" throw Xception with errorCode = 1001 and message = arg
263 * elsen if arg == "TException" throw TException
264 * else do not throw anything
265 */
David Reiss689c9ad2009-04-02 19:24:02 +0000266 void testException(1: string arg) throws(1: Xception err1),
Marc Slemkod8b10512006-08-14 23:30:37 +0000267
Roger Meier1f8b48f2012-05-02 22:56:47 +0000268 /**
269 * Print 'testMultiException(%s, %s)' with arg0 as '%s' and arg1 as '%s'
270 * @param string arg - a string indication what type of exception to throw
271 * if arg0 == "Xception" throw Xception with errorCode = 1001 and message = "This is an Xception"
272 * elsen if arg0 == "Xception2" throw Xception2 with errorCode = 2002 and message = "This is an Xception2"
273 * else do not throw anything
274 * @return Xtruct - an Xtruct with string_thing = arg1
275 */
David Reiss689c9ad2009-04-02 19:24:02 +0000276 Xtruct testMultiException(1: string arg0, 2: string arg1) throws(1: Xception err1, 2: Xception2 err2)
David Reiss2ab6fe82008-02-18 02:11:44 +0000277
Roger Meier1f8b48f2012-05-02 22:56:47 +0000278 /**
279 * Print 'testOneway(%d): Sleeping...' with secondsToSleep as '%d'
280 * sleep 'secondsToSleep'
281 * Print 'testOneway(%d): done sleeping!' with secondsToSleep as '%d'
282 * @param i32 secondsToSleep - the number of seconds to sleep
283 */
David Reisscecbed82009-03-24 20:02:22 +0000284 oneway void testOneway(1:i32 secondsToSleep)
Mark Sleee8540632006-05-30 09:24:40 +0000285}
Mark Sleedafa3cf2006-09-02 23:56:49 +0000286
287service SecondService
288{
289 void blahBlah()
290}
David Reiss9ff3b9d2008-02-15 01:10:23 +0000291
292struct VersioningTestV1 {
293 1: i32 begin_in_both,
David Reissa528f542009-03-24 22:48:40 +0000294 3: string old_string,
David Reiss9ff3b9d2008-02-15 01:10:23 +0000295 12: i32 end_in_both
296}
297
298struct VersioningTestV2 {
299 1: i32 begin_in_both,
300
301 2: i32 newint,
302 3: byte newbyte,
303 4: i16 newshort,
304 5: i64 newlong,
305 6: double newdouble
306 7: Bonk newstruct,
307 8: list<i32> newlist,
308 9: set<i32> newset,
309 10: map<i32, i32> newmap,
310 11: string newstring,
311 12: i32 end_in_both
David Reiss9a08dc62008-02-27 01:55:17 +0000312}
David Reiss2a4bfd62008-04-07 23:45:00 +0000313
314struct ListTypeVersioningV1 {
315 1: list<i32> myints;
316 2: string hello;
317}
318
319struct ListTypeVersioningV2 {
320 1: list<string> strings;
321 2: string hello;
Bryan Duxbury986d7052009-01-29 01:51:08 +0000322}
Bryan Duxbury206c0dc2010-10-19 23:00:27 +0000323
324struct GuessProtocolStruct {
325 7: map<string,string> map_field,
326}
Bryan Duxburydf4cffd2011-03-15 17:16:09 +0000327
328struct LargeDeltas {
329 1: Bools b1,
330 10: Bools b10,
331 100: Bools b100,
332 500: bool check_true,
333 1000: Bools b1000,
334 1500: bool check_false,
335 2000: VersioningTestV2 vertwo2000,
336 2500: set<string> a_set2500,
337 3000: VersioningTestV2 vertwo3000,
338 4000: list<i32> big_numbers
339}
Roger Meierf4eec7a2011-09-11 18:16:21 +0000340
341struct NestedListsI32x2 {
342 1: list<list<i32>> integerlist
343}
344struct NestedListsI32x3 {
345 1: list<list<list<i32>>> integerlist
346}
347struct NestedMixedx2 {
348 1: list<set<i32>> int_set_list
349 2: map<i32,set<string>> map_int_strset
350 3: list<map<i32,set<string>>> map_int_strset_list
351}
352struct ListBonks {
353 1: list<Bonk> bonk
354}
355struct NestedListsBonk {
356 1: list<list<list<Bonk>>> bonk
357}
Bryan Duxbury6c928f32011-10-13 21:32:52 +0000358
359struct BoolTest {
360 1: optional bool b = true;
361 2: optional string s = "true";
362}
Bryan Duxburya3df5472011-12-27 22:26:59 +0000363
364struct StructA {
365 1: required string s;
366}
367
368struct StructB {
369 1: optional StructA aa;
370 2: required StructA ab;
371}