blob: e025b7f54a6a1a5443eeb2758651ac6fe2eff7bb [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 Reiss9a08dc62008-02-27 01:55:17 +000025namespace cpp thrift.test
David Reiss9d65bf02008-03-27 21:41:37 +000026namespace csharp Thrift.Test
James E. King III234fb472019-01-13 23:19:18 -050027namespace delphi Thrift.Test
28namespace go thrifttest
29namespace java thrift.test
T Jake Luciani322caa22010-02-15 03:24:55 +000030namespace js ThriftTest
James E. King III234fb472019-01-13 23:19:18 -050031namespace lua ThriftTest
32namespace netcore ThriftTest
33namespace perl ThriftTest
34namespace php ThriftTest
Anthony F. Molinaro0b4936d2010-09-27 04:43:39 +000035namespace py ThriftTest
Roger Meier50e43492010-10-08 17:46:06 +000036namespace py.twisted ThriftTest
James E. King III234fb472019-01-13 23:19:18 -050037namespace rb Thrift.Test
38namespace st 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
Allen George60611912016-12-11 08:33:52 -0500118union SomeUnion {
119 1: map<Numberz, UserId> map_thing,
120 2: string string_thing,
121 3: i32 i32_thing,
122 4: Xtruct3 xtruct_thing,
123 5: Insanity insanity_thing
124}
125
Marc Slemkobf4fd192006-08-15 21:29:39 +0000126exception Xception {
Mark Sleea3302652006-10-25 19:03:32 +0000127 1: i32 errorCode,
128 2: string message
Marc Slemkod8b10512006-08-14 23:30:37 +0000129}
130
Marc Slemkobf4fd192006-08-15 21:29:39 +0000131exception Xception2 {
Mark Sleea3302652006-10-25 19:03:32 +0000132 1: i32 errorCode,
133 2: Xtruct struct_thing
Marc Slemkod8b10512006-08-14 23:30:37 +0000134}
Mark Slee27ed6ec2007-08-16 01:26:31 +0000135
Mark Sleed3d733a2006-09-01 22:19:06 +0000136struct EmptyStruct {}
137
Marc Slemkod8b10512006-08-14 23:30:37 +0000138struct OneField {
Mark Sleea3302652006-10-25 19:03:32 +0000139 1: EmptyStruct field
Marc Slemkod8b10512006-08-14 23:30:37 +0000140}
Marc Slemko5b126d62006-08-11 23:03:42 +0000141
Mark Sleee8540632006-05-30 09:24:40 +0000142service ThriftTest
143{
Roger Meier1f8b48f2012-05-02 22:56:47 +0000144 /**
145 * Prints "testVoid()" and returns nothing.
146 */
Marc Slemkod8b10512006-08-14 23:30:37 +0000147 void testVoid(),
Jens Geyeraaa89472014-10-03 20:22:28 +0200148
Roger Meier1f8b48f2012-05-02 22:56:47 +0000149 /**
150 * Prints 'testString("%s")' with thing as '%s'
151 * @param string thing - the string to print
152 * @return string - returns the string 'thing'
153 */
Mark Sleea3302652006-10-25 19:03:32 +0000154 string testString(1: string thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200155
Roger Meier1f8b48f2012-05-02 22:56:47 +0000156 /**
Nobuaki Sukegawaa649e742015-09-21 13:53:25 +0900157 * Prints 'testBool("%s")' where '%s' with thing as 'true' or 'false'
158 * @param bool thing - the bool data to print
159 * @return bool - returns the bool 'thing'
160 */
161 bool testBool(1: bool thing),
162
163 /**
Roger Meier1f8b48f2012-05-02 22:56:47 +0000164 * Prints 'testByte("%d")' with thing as '%d'
Jens Geyer40c28d32015-10-20 23:13:02 +0200165 * The types i8 and byte are synonyms, use of i8 is encouraged, byte still exists for the sake of compatibility.
166 * @param byte thing - the i8/byte to print
167 * @return i8 - returns the i8/byte 'thing'
Roger Meier1f8b48f2012-05-02 22:56:47 +0000168 */
Nobuaki Sukegawaeb344a82016-03-25 09:37:18 +0900169 i8 testByte(1: i8 thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200170
Roger Meier1f8b48f2012-05-02 22:56:47 +0000171 /**
172 * Prints 'testI32("%d")' with thing as '%d'
173 * @param i32 thing - the i32 to print
174 * @return i32 - returns the i32 'thing'
175 */
Mark Sleea3302652006-10-25 19:03:32 +0000176 i32 testI32(1: i32 thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200177
Roger Meier1f8b48f2012-05-02 22:56:47 +0000178 /**
179 * Prints 'testI64("%d")' with thing as '%d'
180 * @param i64 thing - the i64 to print
181 * @return i64 - returns the i64 'thing'
182 */
Mark Sleea3302652006-10-25 19:03:32 +0000183 i64 testI64(1: i64 thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200184
Roger Meier1f8b48f2012-05-02 22:56:47 +0000185 /**
186 * Prints 'testDouble("%f")' with thing as '%f'
187 * @param double thing - the double to print
188 * @return double - returns the double 'thing'
189 */
Mark Sleea3302652006-10-25 19:03:32 +0000190 double testDouble(1: double thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200191
Roger Meier1f8b48f2012-05-02 22:56:47 +0000192 /**
Jens Geyera2d5dfd2014-12-13 23:39:45 +0100193 * Prints 'testBinary("%s")' where '%s' is a hex-formatted string of thing's data
194 * @param binary thing - the binary data to print
195 * @return binary - returns the binary 'thing'
196 */
197 binary testBinary(1: binary thing),
wilfrem2c69b5a2015-04-20 19:24:50 +0900198
Jens Geyera2d5dfd2014-12-13 23:39:45 +0100199 /**
Konrad Grochowski3b5dacb2014-11-24 10:55:31 +0100200 * Prints 'testStruct("{%s}")' where thing has been formatted into a string of comma separated values
Roger Meier1f8b48f2012-05-02 22:56:47 +0000201 * @param Xtruct thing - the Xtruct to print
202 * @return Xtruct - returns the Xtruct 'thing'
203 */
Mark Sleea3302652006-10-25 19:03:32 +0000204 Xtruct testStruct(1: Xtruct thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200205
Roger Meier1f8b48f2012-05-02 22:56:47 +0000206 /**
207 * Prints 'testNest("{%s}")' where thing has been formatted into a string of the nested struct
208 * @param Xtruct2 thing - the Xtruct2 to print
209 * @return Xtruct2 - returns the Xtruct2 'thing'
210 */
Mark Sleea3302652006-10-25 19:03:32 +0000211 Xtruct2 testNest(1: Xtruct2 thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200212
Roger Meier1f8b48f2012-05-02 22:56:47 +0000213 /**
214 * Prints 'testMap("{%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<i32,i32> thing - the map<i32,i32> to print
217 * @return map<i32,i32> - returns the map<i32,i32> 'thing'
218 */
Mark Sleea3302652006-10-25 19:03:32 +0000219 map<i32,i32> testMap(1: map<i32,i32> thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200220
Roger Meier1f8b48f2012-05-02 22:56:47 +0000221 /**
222 * Prints 'testStringMap("{%s}")' where thing has been formatted into a string of 'key => value' pairs
Konrad Grochowski3b5dacb2014-11-24 10:55:31 +0100223 * separated by commas and new lines
Roger Meier1f8b48f2012-05-02 22:56:47 +0000224 * @param map<string,string> thing - the map<string,string> to print
225 * @return map<string,string> - returns the map<string,string> 'thing'
226 */
Roger Meier9d8e8f82011-06-14 19:38:27 +0000227 map<string,string> testStringMap(1: map<string,string> thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200228
Roger Meier1f8b48f2012-05-02 22:56:47 +0000229 /**
230 * Prints 'testSet("{%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 set<i32> thing - the set<i32> to print
233 * @return set<i32> - returns the set<i32> 'thing'
234 */
Mark Sleea3302652006-10-25 19:03:32 +0000235 set<i32> testSet(1: set<i32> thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200236
Roger Meier1f8b48f2012-05-02 22:56:47 +0000237 /**
238 * Prints 'testList("{%s}")' where thing has been formatted into a string of values
Konrad Grochowski3b5dacb2014-11-24 10:55:31 +0100239 * separated by commas and new lines
Roger Meier1f8b48f2012-05-02 22:56:47 +0000240 * @param list<i32> thing - the list<i32> to print
241 * @return list<i32> - returns the list<i32> 'thing'
242 */
Mark Sleea3302652006-10-25 19:03:32 +0000243 list<i32> testList(1: list<i32> thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200244
Roger Meier1f8b48f2012-05-02 22:56:47 +0000245 /**
246 * Prints 'testEnum("%d")' where thing has been formatted into it's numeric value
247 * @param Numberz thing - the Numberz to print
248 * @return Numberz - returns the Numberz 'thing'
249 */
Mark Sleea3302652006-10-25 19:03:32 +0000250 Numberz testEnum(1: Numberz thing),
Roger Meier1f8b48f2012-05-02 22:56:47 +0000251
252 /**
253 * Prints 'testTypedef("%d")' with thing as '%d'
254 * @param UserId thing - the UserId to print
255 * @return UserId - returns the UserId 'thing'
256 */
Mark Sleea3302652006-10-25 19:03:32 +0000257 UserId testTypedef(1: UserId thing),
Mark Sleee8540632006-05-30 09:24:40 +0000258
Roger Meier1f8b48f2012-05-02 22:56:47 +0000259 /**
260 * Prints 'testMapMap("%d")' with hello as '%d'
261 * @param i32 hello - the i32 to print
262 * @return map<i32,map<i32,i32>> - returns a dictionary with these values:
263 * {-4 => {-4 => -4, -3 => -3, -2 => -2, -1 => -1, }, 4 => {1 => 1, 2 => 2, 3 => 3, 4 => 4, }, }
264 */
Mark Sleea3302652006-10-25 19:03:32 +0000265 map<i32,map<i32,i32>> testMapMap(1: i32 hello),
Mark Sleee8540632006-05-30 09:24:40 +0000266
Roger Meier1f8b48f2012-05-02 22:56:47 +0000267 /**
268 * So you think you've got this all worked, out eh?
269 *
270 * Creates a the returned map with these values and prints it out:
Jens Geyeraaa89472014-10-03 20:22:28 +0200271 * { 1 => { 2 => argument,
272 * 3 => argument,
Roger Meier1f8b48f2012-05-02 22:56:47 +0000273 * },
274 * 2 => { 6 => <empty Insanity struct>, },
275 * }
Jens Geyeraaa89472014-10-03 20:22:28 +0200276 * @return map<UserId, map<Numberz,Insanity>> - a map with the above values
Roger Meier1f8b48f2012-05-02 22:56:47 +0000277 */
Mark Sleea3302652006-10-25 19:03:32 +0000278 map<UserId, map<Numberz,Insanity>> testInsanity(1: Insanity argument),
Marc Slemkod8b10512006-08-14 23:30:37 +0000279
Roger Meier1f8b48f2012-05-02 22:56:47 +0000280 /**
281 * Prints 'testMulti()'
Nobuaki Sukegawaeb344a82016-03-25 09:37:18 +0900282 * @param i8 arg0 -
Jens Geyeraaa89472014-10-03 20:22:28 +0200283 * @param i32 arg1 -
284 * @param i64 arg2 -
285 * @param map<i16, string> arg3 -
286 * @param Numberz arg4 -
287 * @param UserId arg5 -
Roger Meier1f8b48f2012-05-02 22:56:47 +0000288 * @return Xtruct - returns an Xtruct with string_thing = "Hello2, byte_thing = arg0, i32_thing = arg1
289 * and i64_thing = arg2
290 */
Nobuaki Sukegawaeb344a82016-03-25 09:37:18 +0900291 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 +0000292
Roger Meier1f8b48f2012-05-02 22:56:47 +0000293 /**
294 * Print 'testException(%s)' with arg as '%s'
295 * @param string arg - a string indication what type of exception to throw
296 * if arg == "Xception" throw Xception with errorCode = 1001 and message = arg
297 * elsen if arg == "TException" throw TException
298 * else do not throw anything
299 */
David Reiss689c9ad2009-04-02 19:24:02 +0000300 void testException(1: string arg) throws(1: Xception err1),
Marc Slemkod8b10512006-08-14 23:30:37 +0000301
Roger Meier1f8b48f2012-05-02 22:56:47 +0000302 /**
303 * Print 'testMultiException(%s, %s)' with arg0 as '%s' and arg1 as '%s'
304 * @param string arg - a string indication what type of exception to throw
305 * if arg0 == "Xception" throw Xception with errorCode = 1001 and message = "This is an Xception"
Nobuaki Sukegawa01ede042015-09-29 02:16:53 +0900306 * 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 +0000307 * else do not throw anything
308 * @return Xtruct - an Xtruct with string_thing = arg1
309 */
David Reiss689c9ad2009-04-02 19:24:02 +0000310 Xtruct testMultiException(1: string arg0, 2: string arg1) throws(1: Xception err1, 2: Xception2 err2)
David Reiss2ab6fe82008-02-18 02:11:44 +0000311
Roger Meier1f8b48f2012-05-02 22:56:47 +0000312 /**
313 * Print 'testOneway(%d): Sleeping...' with secondsToSleep as '%d'
314 * sleep 'secondsToSleep'
315 * Print 'testOneway(%d): done sleeping!' with secondsToSleep as '%d'
316 * @param i32 secondsToSleep - the number of seconds to sleep
317 */
David Reisscecbed82009-03-24 20:02:22 +0000318 oneway void testOneway(1:i32 secondsToSleep)
Mark Sleee8540632006-05-30 09:24:40 +0000319}
Mark Sleedafa3cf2006-09-02 23:56:49 +0000320
321service SecondService
322{
henrique2fdd9162013-08-28 14:03:34 +0200323 /**
324 * Prints 'testString("%s")' with thing as '%s'
325 * @param string thing - the string to print
326 * @return string - returns the string 'thing'
327 */
James E. King, III58402ff2017-11-17 14:41:46 -0500328 string secondtestString(1: string thing)
Mark Sleedafa3cf2006-09-02 23:56:49 +0000329}
David Reiss9ff3b9d2008-02-15 01:10:23 +0000330
331struct VersioningTestV1 {
332 1: i32 begin_in_both,
David Reissa528f542009-03-24 22:48:40 +0000333 3: string old_string,
David Reiss9ff3b9d2008-02-15 01:10:23 +0000334 12: i32 end_in_both
335}
336
337struct VersioningTestV2 {
338 1: i32 begin_in_both,
339
340 2: i32 newint,
Nobuaki Sukegawaeb344a82016-03-25 09:37:18 +0900341 3: i8 newbyte,
David Reiss9ff3b9d2008-02-15 01:10:23 +0000342 4: i16 newshort,
343 5: i64 newlong,
344 6: double newdouble
345 7: Bonk newstruct,
346 8: list<i32> newlist,
347 9: set<i32> newset,
348 10: map<i32, i32> newmap,
349 11: string newstring,
350 12: i32 end_in_both
David Reiss9a08dc62008-02-27 01:55:17 +0000351}
David Reiss2a4bfd62008-04-07 23:45:00 +0000352
353struct ListTypeVersioningV1 {
354 1: list<i32> myints;
355 2: string hello;
356}
357
358struct ListTypeVersioningV2 {
359 1: list<string> strings;
360 2: string hello;
Bryan Duxbury986d7052009-01-29 01:51:08 +0000361}
Bryan Duxbury206c0dc2010-10-19 23:00:27 +0000362
363struct GuessProtocolStruct {
364 7: map<string,string> map_field,
365}
Bryan Duxburydf4cffd2011-03-15 17:16:09 +0000366
367struct LargeDeltas {
368 1: Bools b1,
369 10: Bools b10,
370 100: Bools b100,
371 500: bool check_true,
372 1000: Bools b1000,
373 1500: bool check_false,
374 2000: VersioningTestV2 vertwo2000,
375 2500: set<string> a_set2500,
376 3000: VersioningTestV2 vertwo3000,
377 4000: list<i32> big_numbers
378}
Roger Meierf4eec7a2011-09-11 18:16:21 +0000379
380struct NestedListsI32x2 {
381 1: list<list<i32>> integerlist
382}
383struct NestedListsI32x3 {
384 1: list<list<list<i32>>> integerlist
385}
386struct NestedMixedx2 {
387 1: list<set<i32>> int_set_list
388 2: map<i32,set<string>> map_int_strset
389 3: list<map<i32,set<string>>> map_int_strset_list
390}
391struct ListBonks {
392 1: list<Bonk> bonk
393}
394struct NestedListsBonk {
395 1: list<list<list<Bonk>>> bonk
396}
Bryan Duxbury6c928f32011-10-13 21:32:52 +0000397
398struct BoolTest {
399 1: optional bool b = true;
400 2: optional string s = "true";
401}
Bryan Duxburya3df5472011-12-27 22:26:59 +0000402
403struct StructA {
404 1: required string s;
405}
406
407struct StructB {
408 1: optional StructA aa;
409 2: required StructA ab;
Henrique Mendonça8ad13a32013-05-16 21:26:20 +0200410}