blob: 56adf3971ab339ae69d3dc34220adb1f0a87789d [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
Jens Geyere52c0462014-05-02 23:37:39 +020034namespace 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
Roger Meier6cf0ffc2014-04-05 00:45:42 +020038namespace lua ThriftTest
BCGcc193c12015-11-12 21:02:51 -050039namespace xsd test (uri = 'http://thrift.apache.org/ns/ThriftTest')
Henrique Mendonça8ad13a32013-05-16 21:26:20 +020040
41// Presence of namespaces and sub-namespaces for which there is
42// no generator should compile with warnings only
43namespace noexist ThriftTest
44namespace cpp.noexist ThriftTest
45
David Reissfb790d72010-09-02 16:41:45 +000046namespace * thrift.test
Marc Slemko17859852006-08-15 00:21:31 +000047
Bryan Duxbury9af23d92009-11-19 17:26:38 +000048/**
49 * Docstring!
50 */
Mark Sleee8540632006-05-30 09:24:40 +000051enum Numberz
52{
53 ONE = 1,
54 TWO,
55 THREE,
56 FIVE = 5,
57 SIX,
58 EIGHT = 8
59}
60
Bryan Duxbury9f0a7862010-09-12 14:38:36 +000061const Numberz myNumberz = Numberz.ONE;
62// the following is expected to fail:
63// const Numberz urNumberz = ONE;
64
Mark Slee6e536442006-06-30 18:28:50 +000065typedef i64 UserId
Mark Sleee8540632006-05-30 09:24:40 +000066
Mark Sleee129a2d2007-02-21 05:17:48 +000067struct Bonk
68{
69 1: string message,
70 2: i32 type
71}
72
Jens Geyer11430df2013-07-26 00:23:00 +020073typedef map<string,Bonk> MapType
74
Kevin Clark9a863ee2009-03-24 16:04:36 +000075struct Bools {
76 1: bool im_true,
77 2: bool im_false,
78}
79
Mark Sleee8540632006-05-30 09:24:40 +000080struct Xtruct
81{
Mark Sleea3302652006-10-25 19:03:32 +000082 1: string string_thing,
Nobuaki Sukegawaeb344a82016-03-25 09:37:18 +090083 4: i8 byte_thing,
Mark Sleea3302652006-10-25 19:03:32 +000084 9: i32 i32_thing,
85 11: i64 i64_thing
Mark Sleee8540632006-05-30 09:24:40 +000086}
87
88struct Xtruct2
89{
Jens Geyer40c28d32015-10-20 23:13:02 +020090 1: i8 byte_thing, // used to be byte, hence the name
Mark Sleea3302652006-10-25 19:03:32 +000091 2: Xtruct struct_thing,
92 3: i32 i32_thing
Mark Sleee8540632006-05-30 09:24:40 +000093}
94
David Reiss233ace52009-03-30 20:46:47 +000095struct Xtruct3
96{
97 1: string string_thing,
98 4: i32 changed,
99 9: i32 i32_thing,
100 11: i64 i64_thing
101}
102
103
Mark Sleee8540632006-05-30 09:24:40 +0000104struct Insanity
105{
Mark Sleea3302652006-10-25 19:03:32 +0000106 1: map<Numberz, UserId> userMap,
107 2: list<Xtruct> xtructs
Nobuaki Sukegawae841b3d2015-11-17 11:01:17 +0900108} (python.immutable= "")
Mark Sleee8540632006-05-30 09:24:40 +0000109
Bryan Duxbury986d7052009-01-29 01:51:08 +0000110struct CrazyNesting {
111 1: string string_field,
112 2: optional set<Insanity> set_field,
Nobuaki Sukegawa6dab9bb2015-11-28 22:27:16 +0900113 // Do not insert line break as test/go/Makefile.am is removing this line with pattern match
114 3: required list<map<set<i32> (python.immutable = ""), map<i32,set<list<map<Insanity,string>(python.immutable = "")> (python.immutable = "")>>>> list_field,
Bryan Duxburyb3d0aa02010-10-06 20:00:03 +0000115 4: binary binary_field
Bryan Duxbury986d7052009-01-29 01:51:08 +0000116}
117
Marc Slemkobf4fd192006-08-15 21:29:39 +0000118exception Xception {
Mark Sleea3302652006-10-25 19:03:32 +0000119 1: i32 errorCode,
120 2: string message
Marc Slemkod8b10512006-08-14 23:30:37 +0000121}
122
Marc Slemkobf4fd192006-08-15 21:29:39 +0000123exception Xception2 {
Mark Sleea3302652006-10-25 19:03:32 +0000124 1: i32 errorCode,
125 2: Xtruct struct_thing
Marc Slemkod8b10512006-08-14 23:30:37 +0000126}
Mark Slee27ed6ec2007-08-16 01:26:31 +0000127
Mark Sleed3d733a2006-09-01 22:19:06 +0000128struct EmptyStruct {}
129
Marc Slemkod8b10512006-08-14 23:30:37 +0000130struct OneField {
Mark Sleea3302652006-10-25 19:03:32 +0000131 1: EmptyStruct field
Marc Slemkod8b10512006-08-14 23:30:37 +0000132}
Marc Slemko5b126d62006-08-11 23:03:42 +0000133
Mark Sleee8540632006-05-30 09:24:40 +0000134service ThriftTest
135{
Roger Meier1f8b48f2012-05-02 22:56:47 +0000136 /**
137 * Prints "testVoid()" and returns nothing.
138 */
Marc Slemkod8b10512006-08-14 23:30:37 +0000139 void testVoid(),
Jens Geyeraaa89472014-10-03 20:22:28 +0200140
Roger Meier1f8b48f2012-05-02 22:56:47 +0000141 /**
142 * Prints 'testString("%s")' with thing as '%s'
143 * @param string thing - the string to print
144 * @return string - returns the string 'thing'
145 */
Mark Sleea3302652006-10-25 19:03:32 +0000146 string testString(1: string thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200147
Roger Meier1f8b48f2012-05-02 22:56:47 +0000148 /**
Nobuaki Sukegawaa649e742015-09-21 13:53:25 +0900149 * Prints 'testBool("%s")' where '%s' with thing as 'true' or 'false'
150 * @param bool thing - the bool data to print
151 * @return bool - returns the bool 'thing'
152 */
153 bool testBool(1: bool thing),
154
155 /**
Roger Meier1f8b48f2012-05-02 22:56:47 +0000156 * Prints 'testByte("%d")' with thing as '%d'
Jens Geyer40c28d32015-10-20 23:13:02 +0200157 * The types i8 and byte are synonyms, use of i8 is encouraged, byte still exists for the sake of compatibility.
158 * @param byte thing - the i8/byte to print
159 * @return i8 - returns the i8/byte 'thing'
Roger Meier1f8b48f2012-05-02 22:56:47 +0000160 */
Nobuaki Sukegawaeb344a82016-03-25 09:37:18 +0900161 i8 testByte(1: i8 thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200162
Roger Meier1f8b48f2012-05-02 22:56:47 +0000163 /**
164 * Prints 'testI32("%d")' with thing as '%d'
165 * @param i32 thing - the i32 to print
166 * @return i32 - returns the i32 'thing'
167 */
Mark Sleea3302652006-10-25 19:03:32 +0000168 i32 testI32(1: i32 thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200169
Roger Meier1f8b48f2012-05-02 22:56:47 +0000170 /**
171 * Prints 'testI64("%d")' with thing as '%d'
172 * @param i64 thing - the i64 to print
173 * @return i64 - returns the i64 'thing'
174 */
Mark Sleea3302652006-10-25 19:03:32 +0000175 i64 testI64(1: i64 thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200176
Roger Meier1f8b48f2012-05-02 22:56:47 +0000177 /**
178 * Prints 'testDouble("%f")' with thing as '%f'
179 * @param double thing - the double to print
180 * @return double - returns the double 'thing'
181 */
Mark Sleea3302652006-10-25 19:03:32 +0000182 double testDouble(1: double thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200183
Roger Meier1f8b48f2012-05-02 22:56:47 +0000184 /**
Jens Geyera2d5dfd2014-12-13 23:39:45 +0100185 * Prints 'testBinary("%s")' where '%s' is a hex-formatted string of thing's data
186 * @param binary thing - the binary data to print
187 * @return binary - returns the binary 'thing'
188 */
189 binary testBinary(1: binary thing),
190
191 /**
Konrad Grochowski3b5dacb2014-11-24 10:55:31 +0100192 * Prints 'testStruct("{%s}")' where thing has been formatted into a string of comma separated values
Roger Meier1f8b48f2012-05-02 22:56:47 +0000193 * @param Xtruct thing - the Xtruct to print
194 * @return Xtruct - returns the Xtruct 'thing'
195 */
Mark Sleea3302652006-10-25 19:03:32 +0000196 Xtruct testStruct(1: Xtruct thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200197
Roger Meier1f8b48f2012-05-02 22:56:47 +0000198 /**
199 * Prints 'testNest("{%s}")' where thing has been formatted into a string of the nested struct
200 * @param Xtruct2 thing - the Xtruct2 to print
201 * @return Xtruct2 - returns the Xtruct2 'thing'
202 */
Mark Sleea3302652006-10-25 19:03:32 +0000203 Xtruct2 testNest(1: Xtruct2 thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200204
Roger Meier1f8b48f2012-05-02 22:56:47 +0000205 /**
206 * Prints 'testMap("{%s")' where thing has been formatted into a string of 'key => value' pairs
Konrad Grochowski3b5dacb2014-11-24 10:55:31 +0100207 * separated by commas and new lines
Roger Meier1f8b48f2012-05-02 22:56:47 +0000208 * @param map<i32,i32> thing - the map<i32,i32> to print
209 * @return map<i32,i32> - returns the map<i32,i32> 'thing'
210 */
Mark Sleea3302652006-10-25 19:03:32 +0000211 map<i32,i32> testMap(1: map<i32,i32> thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200212
Roger Meier1f8b48f2012-05-02 22:56:47 +0000213 /**
214 * Prints 'testStringMap("{%s}")' where thing has been formatted into a string of 'key => value' pairs
Konrad Grochowski3b5dacb2014-11-24 10:55:31 +0100215 * separated by commas and new lines
Roger Meier1f8b48f2012-05-02 22:56:47 +0000216 * @param map<string,string> thing - the map<string,string> to print
217 * @return map<string,string> - returns the map<string,string> 'thing'
218 */
Roger Meier9d8e8f82011-06-14 19:38:27 +0000219 map<string,string> testStringMap(1: map<string,string> thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200220
Roger Meier1f8b48f2012-05-02 22:56:47 +0000221 /**
222 * Prints 'testSet("{%s}")' where thing has been formatted into a string of values
Konrad Grochowski3b5dacb2014-11-24 10:55:31 +0100223 * separated by commas and new lines
Roger Meier1f8b48f2012-05-02 22:56:47 +0000224 * @param set<i32> thing - the set<i32> to print
225 * @return set<i32> - returns the set<i32> 'thing'
226 */
Mark Sleea3302652006-10-25 19:03:32 +0000227 set<i32> testSet(1: set<i32> thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200228
Roger Meier1f8b48f2012-05-02 22:56:47 +0000229 /**
230 * Prints 'testList("{%s}")' where thing has been formatted into a string of values
Konrad Grochowski3b5dacb2014-11-24 10:55:31 +0100231 * separated by commas and new lines
Roger Meier1f8b48f2012-05-02 22:56:47 +0000232 * @param list<i32> thing - the list<i32> to print
233 * @return list<i32> - returns the list<i32> 'thing'
234 */
Mark Sleea3302652006-10-25 19:03:32 +0000235 list<i32> testList(1: list<i32> thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200236
Roger Meier1f8b48f2012-05-02 22:56:47 +0000237 /**
238 * Prints 'testEnum("%d")' where thing has been formatted into it's numeric value
239 * @param Numberz thing - the Numberz to print
240 * @return Numberz - returns the Numberz 'thing'
241 */
Mark Sleea3302652006-10-25 19:03:32 +0000242 Numberz testEnum(1: Numberz thing),
Roger Meier1f8b48f2012-05-02 22:56:47 +0000243
244 /**
245 * Prints 'testTypedef("%d")' with thing as '%d'
246 * @param UserId thing - the UserId to print
247 * @return UserId - returns the UserId 'thing'
248 */
Mark Sleea3302652006-10-25 19:03:32 +0000249 UserId testTypedef(1: UserId thing),
Mark Sleee8540632006-05-30 09:24:40 +0000250
Roger Meier1f8b48f2012-05-02 22:56:47 +0000251 /**
252 * Prints 'testMapMap("%d")' with hello as '%d'
253 * @param i32 hello - the i32 to print
254 * @return map<i32,map<i32,i32>> - returns a dictionary with these values:
255 * {-4 => {-4 => -4, -3 => -3, -2 => -2, -1 => -1, }, 4 => {1 => 1, 2 => 2, 3 => 3, 4 => 4, }, }
256 */
Mark Sleea3302652006-10-25 19:03:32 +0000257 map<i32,map<i32,i32>> testMapMap(1: i32 hello),
Mark Sleee8540632006-05-30 09:24:40 +0000258
Roger Meier1f8b48f2012-05-02 22:56:47 +0000259 /**
260 * So you think you've got this all worked, out eh?
261 *
262 * Creates a the returned map with these values and prints it out:
Jens Geyeraaa89472014-10-03 20:22:28 +0200263 * { 1 => { 2 => argument,
264 * 3 => argument,
Roger Meier1f8b48f2012-05-02 22:56:47 +0000265 * },
266 * 2 => { 6 => <empty Insanity struct>, },
267 * }
Jens Geyeraaa89472014-10-03 20:22:28 +0200268 * @return map<UserId, map<Numberz,Insanity>> - a map with the above values
Roger Meier1f8b48f2012-05-02 22:56:47 +0000269 */
Mark Sleea3302652006-10-25 19:03:32 +0000270 map<UserId, map<Numberz,Insanity>> testInsanity(1: Insanity argument),
Marc Slemkod8b10512006-08-14 23:30:37 +0000271
Roger Meier1f8b48f2012-05-02 22:56:47 +0000272 /**
273 * Prints 'testMulti()'
Nobuaki Sukegawaeb344a82016-03-25 09:37:18 +0900274 * @param i8 arg0 -
Jens Geyeraaa89472014-10-03 20:22:28 +0200275 * @param i32 arg1 -
276 * @param i64 arg2 -
277 * @param map<i16, string> arg3 -
278 * @param Numberz arg4 -
279 * @param UserId arg5 -
Roger Meier1f8b48f2012-05-02 22:56:47 +0000280 * @return Xtruct - returns an Xtruct with string_thing = "Hello2, byte_thing = arg0, i32_thing = arg1
281 * and i64_thing = arg2
282 */
Nobuaki Sukegawaeb344a82016-03-25 09:37:18 +0900283 Xtruct testMulti(1: i8 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 +0000284
Roger Meier1f8b48f2012-05-02 22:56:47 +0000285 /**
286 * Print 'testException(%s)' with arg as '%s'
287 * @param string arg - a string indication what type of exception to throw
288 * if arg == "Xception" throw Xception with errorCode = 1001 and message = arg
289 * elsen if arg == "TException" throw TException
290 * else do not throw anything
291 */
David Reiss689c9ad2009-04-02 19:24:02 +0000292 void testException(1: string arg) throws(1: Xception err1),
Marc Slemkod8b10512006-08-14 23:30:37 +0000293
Roger Meier1f8b48f2012-05-02 22:56:47 +0000294 /**
295 * Print 'testMultiException(%s, %s)' with arg0 as '%s' and arg1 as '%s'
296 * @param string arg - a string indication what type of exception to throw
297 * if arg0 == "Xception" throw Xception with errorCode = 1001 and message = "This is an Xception"
Nobuaki Sukegawa01ede042015-09-29 02:16:53 +0900298 * elsen if arg0 == "Xception2" throw Xception2 with errorCode = 2002 and struct_thing.string_thing = "This is an Xception2"
Roger Meier1f8b48f2012-05-02 22:56:47 +0000299 * else do not throw anything
300 * @return Xtruct - an Xtruct with string_thing = arg1
301 */
David Reiss689c9ad2009-04-02 19:24:02 +0000302 Xtruct testMultiException(1: string arg0, 2: string arg1) throws(1: Xception err1, 2: Xception2 err2)
David Reiss2ab6fe82008-02-18 02:11:44 +0000303
Roger Meier1f8b48f2012-05-02 22:56:47 +0000304 /**
305 * Print 'testOneway(%d): Sleeping...' with secondsToSleep as '%d'
306 * sleep 'secondsToSleep'
307 * Print 'testOneway(%d): done sleeping!' with secondsToSleep as '%d'
308 * @param i32 secondsToSleep - the number of seconds to sleep
309 */
David Reisscecbed82009-03-24 20:02:22 +0000310 oneway void testOneway(1:i32 secondsToSleep)
Mark Sleee8540632006-05-30 09:24:40 +0000311}
Mark Sleedafa3cf2006-09-02 23:56:49 +0000312
313service SecondService
314{
315 void blahBlah()
henrique2fdd9162013-08-28 14:03:34 +0200316 /**
317 * Prints 'testString("%s")' with thing as '%s'
318 * @param string thing - the string to print
319 * @return string - returns the string 'thing'
320 */
321 string secondtestString(1: string thing),
Mark Sleedafa3cf2006-09-02 23:56:49 +0000322}
David Reiss9ff3b9d2008-02-15 01:10:23 +0000323
324struct VersioningTestV1 {
325 1: i32 begin_in_both,
David Reissa528f542009-03-24 22:48:40 +0000326 3: string old_string,
David Reiss9ff3b9d2008-02-15 01:10:23 +0000327 12: i32 end_in_both
328}
329
330struct VersioningTestV2 {
331 1: i32 begin_in_both,
332
333 2: i32 newint,
Nobuaki Sukegawaeb344a82016-03-25 09:37:18 +0900334 3: i8 newbyte,
David Reiss9ff3b9d2008-02-15 01:10:23 +0000335 4: i16 newshort,
336 5: i64 newlong,
337 6: double newdouble
338 7: Bonk newstruct,
339 8: list<i32> newlist,
340 9: set<i32> newset,
341 10: map<i32, i32> newmap,
342 11: string newstring,
343 12: i32 end_in_both
David Reiss9a08dc62008-02-27 01:55:17 +0000344}
David Reiss2a4bfd62008-04-07 23:45:00 +0000345
346struct ListTypeVersioningV1 {
347 1: list<i32> myints;
348 2: string hello;
349}
350
351struct ListTypeVersioningV2 {
352 1: list<string> strings;
353 2: string hello;
Bryan Duxbury986d7052009-01-29 01:51:08 +0000354}
Bryan Duxbury206c0dc2010-10-19 23:00:27 +0000355
356struct GuessProtocolStruct {
357 7: map<string,string> map_field,
358}
Bryan Duxburydf4cffd2011-03-15 17:16:09 +0000359
360struct LargeDeltas {
361 1: Bools b1,
362 10: Bools b10,
363 100: Bools b100,
364 500: bool check_true,
365 1000: Bools b1000,
366 1500: bool check_false,
367 2000: VersioningTestV2 vertwo2000,
368 2500: set<string> a_set2500,
369 3000: VersioningTestV2 vertwo3000,
370 4000: list<i32> big_numbers
371}
Roger Meierf4eec7a2011-09-11 18:16:21 +0000372
373struct NestedListsI32x2 {
374 1: list<list<i32>> integerlist
375}
376struct NestedListsI32x3 {
377 1: list<list<list<i32>>> integerlist
378}
379struct NestedMixedx2 {
380 1: list<set<i32>> int_set_list
381 2: map<i32,set<string>> map_int_strset
382 3: list<map<i32,set<string>>> map_int_strset_list
383}
384struct ListBonks {
385 1: list<Bonk> bonk
386}
387struct NestedListsBonk {
388 1: list<list<list<Bonk>>> bonk
389}
Bryan Duxbury6c928f32011-10-13 21:32:52 +0000390
391struct BoolTest {
392 1: optional bool b = true;
393 2: optional string s = "true";
394}
Bryan Duxburya3df5472011-12-27 22:26:59 +0000395
396struct StructA {
397 1: required string s;
398}
399
400struct StructB {
401 1: optional StructA aa;
402 2: required StructA ab;
Henrique Mendonça8ad13a32013-05-16 21:26:20 +0200403}