blob: ac49aee01c8a4bb3257594321ccdefe971bb49c7 [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
James E. King III234fb472019-01-13 23:19:18 -050026namespace delphi Thrift.Test
27namespace go thrifttest
28namespace java thrift.test
T Jake Luciani322caa22010-02-15 03:24:55 +000029namespace js ThriftTest
James E. King III234fb472019-01-13 23:19:18 -050030namespace lua ThriftTest
Jens Geyeraa0c8b32019-01-28 23:27:45 +010031namespace netstd ThriftTest
James E. King III234fb472019-01-13 23:19:18 -050032namespace perl ThriftTest
33namespace php ThriftTest
Anthony F. Molinaro0b4936d2010-09-27 04:43:39 +000034namespace py ThriftTest
Roger Meier50e43492010-10-08 17:46:06 +000035namespace py.twisted ThriftTest
James E. King III234fb472019-01-13 23:19:18 -050036namespace rb Thrift.Test
37namespace st ThriftTest
BCGcc193c12015-11-12 21:02:51 -050038namespace xsd test (uri = 'http://thrift.apache.org/ns/ThriftTest')
Henrique Mendonça8ad13a32013-05-16 21:26:20 +020039
40// Presence of namespaces and sub-namespaces for which there is
41// no generator should compile with warnings only
42namespace noexist ThriftTest
43namespace cpp.noexist ThriftTest
44
David Reissfb790d72010-09-02 16:41:45 +000045namespace * thrift.test
Marc Slemko17859852006-08-15 00:21:31 +000046
Bryan Duxbury9af23d92009-11-19 17:26:38 +000047/**
48 * Docstring!
49 */
Mark Sleee8540632006-05-30 09:24:40 +000050enum Numberz
51{
52 ONE = 1,
53 TWO,
54 THREE,
55 FIVE = 5,
56 SIX,
57 EIGHT = 8
58}
59
Bryan Duxbury9f0a7862010-09-12 14:38:36 +000060const Numberz myNumberz = Numberz.ONE;
61// the following is expected to fail:
62// const Numberz urNumberz = ONE;
63
Mark Slee6e536442006-06-30 18:28:50 +000064typedef i64 UserId
Mark Sleee8540632006-05-30 09:24:40 +000065
Mark Sleee129a2d2007-02-21 05:17:48 +000066struct Bonk
67{
68 1: string message,
69 2: i32 type
70}
71
Jens Geyer11430df2013-07-26 00:23:00 +020072typedef map<string,Bonk> MapType
73
Kevin Clark9a863ee2009-03-24 16:04:36 +000074struct Bools {
75 1: bool im_true,
76 2: bool im_false,
77}
78
Mark Sleee8540632006-05-30 09:24:40 +000079struct Xtruct
80{
Mark Sleea3302652006-10-25 19:03:32 +000081 1: string string_thing,
Nobuaki Sukegawaeb344a82016-03-25 09:37:18 +090082 4: i8 byte_thing,
Mark Sleea3302652006-10-25 19:03:32 +000083 9: i32 i32_thing,
84 11: i64 i64_thing
Mark Sleee8540632006-05-30 09:24:40 +000085}
86
87struct Xtruct2
88{
Jens Geyer40c28d32015-10-20 23:13:02 +020089 1: i8 byte_thing, // used to be byte, hence the name
Mark Sleea3302652006-10-25 19:03:32 +000090 2: Xtruct struct_thing,
91 3: i32 i32_thing
Mark Sleee8540632006-05-30 09:24:40 +000092}
93
David Reiss233ace52009-03-30 20:46:47 +000094struct Xtruct3
95{
96 1: string string_thing,
97 4: i32 changed,
98 9: i32 i32_thing,
99 11: i64 i64_thing
100}
101
102
Mark Sleee8540632006-05-30 09:24:40 +0000103struct Insanity
104{
Mark Sleea3302652006-10-25 19:03:32 +0000105 1: map<Numberz, UserId> userMap,
106 2: list<Xtruct> xtructs
Nobuaki Sukegawae841b3d2015-11-17 11:01:17 +0900107} (python.immutable= "")
Mark Sleee8540632006-05-30 09:24:40 +0000108
Bryan Duxbury986d7052009-01-29 01:51:08 +0000109struct CrazyNesting {
110 1: string string_field,
111 2: optional set<Insanity> set_field,
Nobuaki Sukegawa6dab9bb2015-11-28 22:27:16 +0900112 // Do not insert line break as test/go/Makefile.am is removing this line with pattern match
113 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 +0000114 4: binary binary_field
Bryan Duxbury986d7052009-01-29 01:51:08 +0000115}
116
Allen George60611912016-12-11 08:33:52 -0500117union SomeUnion {
118 1: map<Numberz, UserId> map_thing,
119 2: string string_thing,
120 3: i32 i32_thing,
121 4: Xtruct3 xtruct_thing,
122 5: Insanity insanity_thing
123}
124
Marc Slemkobf4fd192006-08-15 21:29:39 +0000125exception Xception {
Mark Sleea3302652006-10-25 19:03:32 +0000126 1: i32 errorCode,
127 2: string message
Marc Slemkod8b10512006-08-14 23:30:37 +0000128}
129
Marc Slemkobf4fd192006-08-15 21:29:39 +0000130exception Xception2 {
Mark Sleea3302652006-10-25 19:03:32 +0000131 1: i32 errorCode,
132 2: Xtruct struct_thing
Marc Slemkod8b10512006-08-14 23:30:37 +0000133}
Mark Slee27ed6ec2007-08-16 01:26:31 +0000134
Mark Sleed3d733a2006-09-01 22:19:06 +0000135struct EmptyStruct {}
136
Marc Slemkod8b10512006-08-14 23:30:37 +0000137struct OneField {
Mark Sleea3302652006-10-25 19:03:32 +0000138 1: EmptyStruct field
Marc Slemkod8b10512006-08-14 23:30:37 +0000139}
Marc Slemko5b126d62006-08-11 23:03:42 +0000140
Mark Sleee8540632006-05-30 09:24:40 +0000141service ThriftTest
142{
Roger Meier1f8b48f2012-05-02 22:56:47 +0000143 /**
144 * Prints "testVoid()" and returns nothing.
145 */
Marc Slemkod8b10512006-08-14 23:30:37 +0000146 void testVoid(),
Jens Geyeraaa89472014-10-03 20:22:28 +0200147
Roger Meier1f8b48f2012-05-02 22:56:47 +0000148 /**
149 * Prints 'testString("%s")' with thing as '%s'
150 * @param string thing - the string to print
151 * @return string - returns the string 'thing'
152 */
Mark Sleea3302652006-10-25 19:03:32 +0000153 string testString(1: string thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200154
Roger Meier1f8b48f2012-05-02 22:56:47 +0000155 /**
Nobuaki Sukegawaa649e742015-09-21 13:53:25 +0900156 * Prints 'testBool("%s")' where '%s' with thing as 'true' or 'false'
157 * @param bool thing - the bool data to print
158 * @return bool - returns the bool 'thing'
159 */
160 bool testBool(1: bool thing),
161
162 /**
Roger Meier1f8b48f2012-05-02 22:56:47 +0000163 * Prints 'testByte("%d")' with thing as '%d'
Jens Geyer40c28d32015-10-20 23:13:02 +0200164 * The types i8 and byte are synonyms, use of i8 is encouraged, byte still exists for the sake of compatibility.
165 * @param byte thing - the i8/byte to print
166 * @return i8 - returns the i8/byte 'thing'
Roger Meier1f8b48f2012-05-02 22:56:47 +0000167 */
Nobuaki Sukegawaeb344a82016-03-25 09:37:18 +0900168 i8 testByte(1: i8 thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200169
Roger Meier1f8b48f2012-05-02 22:56:47 +0000170 /**
171 * Prints 'testI32("%d")' with thing as '%d'
172 * @param i32 thing - the i32 to print
173 * @return i32 - returns the i32 'thing'
174 */
Mark Sleea3302652006-10-25 19:03:32 +0000175 i32 testI32(1: i32 thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200176
Roger Meier1f8b48f2012-05-02 22:56:47 +0000177 /**
178 * Prints 'testI64("%d")' with thing as '%d'
179 * @param i64 thing - the i64 to print
180 * @return i64 - returns the i64 'thing'
181 */
Mark Sleea3302652006-10-25 19:03:32 +0000182 i64 testI64(1: i64 thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200183
Roger Meier1f8b48f2012-05-02 22:56:47 +0000184 /**
185 * Prints 'testDouble("%f")' with thing as '%f'
186 * @param double thing - the double to print
187 * @return double - returns the double 'thing'
188 */
Mark Sleea3302652006-10-25 19:03:32 +0000189 double testDouble(1: double thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200190
Roger Meier1f8b48f2012-05-02 22:56:47 +0000191 /**
Jens Geyera2d5dfd2014-12-13 23:39:45 +0100192 * Prints 'testBinary("%s")' where '%s' is a hex-formatted string of thing's data
193 * @param binary thing - the binary data to print
194 * @return binary - returns the binary 'thing'
195 */
196 binary testBinary(1: binary thing),
wilfrem2c69b5a2015-04-20 19:24:50 +0900197
Jens Geyera2d5dfd2014-12-13 23:39:45 +0100198 /**
Konrad Grochowski3b5dacb2014-11-24 10:55:31 +0100199 * Prints 'testStruct("{%s}")' where thing has been formatted into a string of comma separated values
Roger Meier1f8b48f2012-05-02 22:56:47 +0000200 * @param Xtruct thing - the Xtruct to print
201 * @return Xtruct - returns the Xtruct 'thing'
202 */
Mark Sleea3302652006-10-25 19:03:32 +0000203 Xtruct testStruct(1: Xtruct thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200204
Roger Meier1f8b48f2012-05-02 22:56:47 +0000205 /**
206 * Prints 'testNest("{%s}")' where thing has been formatted into a string of the nested struct
207 * @param Xtruct2 thing - the Xtruct2 to print
208 * @return Xtruct2 - returns the Xtruct2 'thing'
209 */
Mark Sleea3302652006-10-25 19:03:32 +0000210 Xtruct2 testNest(1: Xtruct2 thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200211
Roger Meier1f8b48f2012-05-02 22:56:47 +0000212 /**
Kevin Wojniakc5068e22019-06-26 22:11:01 -0700213 * Prints 'testMap("{%s")' where thing has been formatted into a string of 'key => value' pairs
Konrad Grochowski3b5dacb2014-11-24 10:55:31 +0100214 * separated by commas and new lines
Roger Meier1f8b48f2012-05-02 22:56:47 +0000215 * @param map<i32,i32> thing - the map<i32,i32> to print
216 * @return map<i32,i32> - returns the map<i32,i32> 'thing'
217 */
Mark Sleea3302652006-10-25 19:03:32 +0000218 map<i32,i32> testMap(1: map<i32,i32> thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200219
Roger Meier1f8b48f2012-05-02 22:56:47 +0000220 /**
Kevin Wojniakc5068e22019-06-26 22:11:01 -0700221 * Prints 'testStringMap("{%s}")' where thing has been formatted into a string of 'key => value' pairs
Konrad Grochowski3b5dacb2014-11-24 10:55:31 +0100222 * separated by commas and new lines
Roger Meier1f8b48f2012-05-02 22:56:47 +0000223 * @param map<string,string> thing - the map<string,string> to print
224 * @return map<string,string> - returns the map<string,string> 'thing'
225 */
Roger Meier9d8e8f82011-06-14 19:38:27 +0000226 map<string,string> testStringMap(1: map<string,string> thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200227
Roger Meier1f8b48f2012-05-02 22:56:47 +0000228 /**
Kevin Wojniakc5068e22019-06-26 22:11:01 -0700229 * Prints 'testSet("{%s}")' where thing has been formatted into a string of values
Konrad Grochowski3b5dacb2014-11-24 10:55:31 +0100230 * separated by commas and new lines
Roger Meier1f8b48f2012-05-02 22:56:47 +0000231 * @param set<i32> thing - the set<i32> to print
232 * @return set<i32> - returns the set<i32> 'thing'
233 */
Mark Sleea3302652006-10-25 19:03:32 +0000234 set<i32> testSet(1: set<i32> thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200235
Roger Meier1f8b48f2012-05-02 22:56:47 +0000236 /**
Kevin Wojniakc5068e22019-06-26 22:11:01 -0700237 * Prints 'testList("{%s}")' where thing has been formatted into a string of values
Konrad Grochowski3b5dacb2014-11-24 10:55:31 +0100238 * separated by commas and new lines
Roger Meier1f8b48f2012-05-02 22:56:47 +0000239 * @param list<i32> thing - the list<i32> to print
240 * @return list<i32> - returns the list<i32> 'thing'
241 */
Mark Sleea3302652006-10-25 19:03:32 +0000242 list<i32> testList(1: list<i32> thing),
Jens Geyeraaa89472014-10-03 20:22:28 +0200243
Roger Meier1f8b48f2012-05-02 22:56:47 +0000244 /**
Kevin Wojniakc5068e22019-06-26 22:11:01 -0700245 * Prints 'testEnum("%d")' where thing has been formatted into its numeric value
Roger Meier1f8b48f2012-05-02 22:56:47 +0000246 * @param Numberz thing - the Numberz to print
247 * @return Numberz - returns the Numberz 'thing'
248 */
Mark Sleea3302652006-10-25 19:03:32 +0000249 Numberz testEnum(1: Numberz thing),
Roger Meier1f8b48f2012-05-02 22:56:47 +0000250
251 /**
252 * Prints 'testTypedef("%d")' with thing as '%d'
253 * @param UserId thing - the UserId to print
254 * @return UserId - returns the UserId 'thing'
255 */
Mark Sleea3302652006-10-25 19:03:32 +0000256 UserId testTypedef(1: UserId thing),
Mark Sleee8540632006-05-30 09:24:40 +0000257
Roger Meier1f8b48f2012-05-02 22:56:47 +0000258 /**
259 * Prints 'testMapMap("%d")' with hello as '%d'
260 * @param i32 hello - the i32 to print
261 * @return map<i32,map<i32,i32>> - returns a dictionary with these values:
262 * {-4 => {-4 => -4, -3 => -3, -2 => -2, -1 => -1, }, 4 => {1 => 1, 2 => 2, 3 => 3, 4 => 4, }, }
263 */
Mark Sleea3302652006-10-25 19:03:32 +0000264 map<i32,map<i32,i32>> testMapMap(1: i32 hello),
Mark Sleee8540632006-05-30 09:24:40 +0000265
Roger Meier1f8b48f2012-05-02 22:56:47 +0000266 /**
Kevin Wojniakc5068e22019-06-26 22:11:01 -0700267 * So you think you've got this all worked out, eh?
Roger Meier1f8b48f2012-05-02 22:56:47 +0000268 *
Kevin Wojniakc5068e22019-06-26 22:11:01 -0700269 * Creates a map with these values and prints it out:
Jens Geyeraaa89472014-10-03 20:22:28 +0200270 * { 1 => { 2 => argument,
271 * 3 => argument,
Roger Meier1f8b48f2012-05-02 22:56:47 +0000272 * },
273 * 2 => { 6 => <empty Insanity struct>, },
274 * }
Jens Geyeraaa89472014-10-03 20:22:28 +0200275 * @return map<UserId, map<Numberz,Insanity>> - a map with the above values
Roger Meier1f8b48f2012-05-02 22:56:47 +0000276 */
Mark Sleea3302652006-10-25 19:03:32 +0000277 map<UserId, map<Numberz,Insanity>> testInsanity(1: Insanity argument),
Marc Slemkod8b10512006-08-14 23:30:37 +0000278
Roger Meier1f8b48f2012-05-02 22:56:47 +0000279 /**
280 * Prints 'testMulti()'
Nobuaki Sukegawaeb344a82016-03-25 09:37:18 +0900281 * @param i8 arg0 -
Jens Geyeraaa89472014-10-03 20:22:28 +0200282 * @param i32 arg1 -
283 * @param i64 arg2 -
284 * @param map<i16, string> arg3 -
285 * @param Numberz arg4 -
286 * @param UserId arg5 -
Roger Meier1f8b48f2012-05-02 22:56:47 +0000287 * @return Xtruct - returns an Xtruct with string_thing = "Hello2, byte_thing = arg0, i32_thing = arg1
288 * and i64_thing = arg2
289 */
Nobuaki Sukegawaeb344a82016-03-25 09:37:18 +0900290 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 +0000291
Roger Meier1f8b48f2012-05-02 22:56:47 +0000292 /**
293 * Print 'testException(%s)' with arg as '%s'
294 * @param string arg - a string indication what type of exception to throw
295 * if arg == "Xception" throw Xception with errorCode = 1001 and message = arg
Kevin Wojniakc5068e22019-06-26 22:11:01 -0700296 * else if arg == "TException" throw TException
Roger Meier1f8b48f2012-05-02 22:56:47 +0000297 * else do not throw anything
298 */
David Reiss689c9ad2009-04-02 19:24:02 +0000299 void testException(1: string arg) throws(1: Xception err1),
Marc Slemkod8b10512006-08-14 23:30:37 +0000300
Roger Meier1f8b48f2012-05-02 22:56:47 +0000301 /**
302 * Print 'testMultiException(%s, %s)' with arg0 as '%s' and arg1 as '%s'
Kevin Wojniakc5068e22019-06-26 22:11:01 -0700303 * @param string arg - a string indicating what type of exception to throw
Roger Meier1f8b48f2012-05-02 22:56:47 +0000304 * if arg0 == "Xception" throw Xception with errorCode = 1001 and message = "This is an Xception"
Kevin Wojniakc5068e22019-06-26 22:11:01 -0700305 * else if arg0 == "Xception2" throw Xception2 with errorCode = 2002 and struct_thing.string_thing = "This is an Xception2"
Roger Meier1f8b48f2012-05-02 22:56:47 +0000306 * else do not throw anything
307 * @return Xtruct - an Xtruct with string_thing = arg1
308 */
David Reiss689c9ad2009-04-02 19:24:02 +0000309 Xtruct testMultiException(1: string arg0, 2: string arg1) throws(1: Xception err1, 2: Xception2 err2)
David Reiss2ab6fe82008-02-18 02:11:44 +0000310
Roger Meier1f8b48f2012-05-02 22:56:47 +0000311 /**
312 * Print 'testOneway(%d): Sleeping...' with secondsToSleep as '%d'
313 * sleep 'secondsToSleep'
314 * Print 'testOneway(%d): done sleeping!' with secondsToSleep as '%d'
315 * @param i32 secondsToSleep - the number of seconds to sleep
316 */
David Reisscecbed82009-03-24 20:02:22 +0000317 oneway void testOneway(1:i32 secondsToSleep)
Mark Sleee8540632006-05-30 09:24:40 +0000318}
Mark Sleedafa3cf2006-09-02 23:56:49 +0000319
320service SecondService
321{
henrique2fdd9162013-08-28 14:03:34 +0200322 /**
323 * Prints 'testString("%s")' with thing as '%s'
324 * @param string thing - the string to print
325 * @return string - returns the string 'thing'
326 */
James E. King, III58402ff2017-11-17 14:41:46 -0500327 string secondtestString(1: string thing)
Mark Sleedafa3cf2006-09-02 23:56:49 +0000328}
David Reiss9ff3b9d2008-02-15 01:10:23 +0000329
330struct VersioningTestV1 {
331 1: i32 begin_in_both,
David Reissa528f542009-03-24 22:48:40 +0000332 3: string old_string,
David Reiss9ff3b9d2008-02-15 01:10:23 +0000333 12: i32 end_in_both
334}
335
336struct VersioningTestV2 {
337 1: i32 begin_in_both,
338
339 2: i32 newint,
Nobuaki Sukegawaeb344a82016-03-25 09:37:18 +0900340 3: i8 newbyte,
David Reiss9ff3b9d2008-02-15 01:10:23 +0000341 4: i16 newshort,
342 5: i64 newlong,
343 6: double newdouble
344 7: Bonk newstruct,
345 8: list<i32> newlist,
346 9: set<i32> newset,
347 10: map<i32, i32> newmap,
348 11: string newstring,
349 12: i32 end_in_both
David Reiss9a08dc62008-02-27 01:55:17 +0000350}
David Reiss2a4bfd62008-04-07 23:45:00 +0000351
352struct ListTypeVersioningV1 {
353 1: list<i32> myints;
354 2: string hello;
355}
356
357struct ListTypeVersioningV2 {
358 1: list<string> strings;
359 2: string hello;
Bryan Duxbury986d7052009-01-29 01:51:08 +0000360}
Bryan Duxbury206c0dc2010-10-19 23:00:27 +0000361
362struct GuessProtocolStruct {
363 7: map<string,string> map_field,
364}
Bryan Duxburydf4cffd2011-03-15 17:16:09 +0000365
366struct LargeDeltas {
367 1: Bools b1,
368 10: Bools b10,
369 100: Bools b100,
370 500: bool check_true,
371 1000: Bools b1000,
372 1500: bool check_false,
373 2000: VersioningTestV2 vertwo2000,
374 2500: set<string> a_set2500,
375 3000: VersioningTestV2 vertwo3000,
376 4000: list<i32> big_numbers
377}
Roger Meierf4eec7a2011-09-11 18:16:21 +0000378
379struct NestedListsI32x2 {
380 1: list<list<i32>> integerlist
381}
382struct NestedListsI32x3 {
383 1: list<list<list<i32>>> integerlist
384}
385struct NestedMixedx2 {
386 1: list<set<i32>> int_set_list
387 2: map<i32,set<string>> map_int_strset
388 3: list<map<i32,set<string>>> map_int_strset_list
389}
390struct ListBonks {
391 1: list<Bonk> bonk
392}
393struct NestedListsBonk {
394 1: list<list<list<Bonk>>> bonk
395}
Bryan Duxbury6c928f32011-10-13 21:32:52 +0000396
397struct BoolTest {
398 1: optional bool b = true;
399 2: optional string s = "true";
400}
Bryan Duxburya3df5472011-12-27 22:26:59 +0000401
402struct StructA {
403 1: required string s;
404}
405
406struct StructB {
407 1: optional StructA aa;
408 2: required StructA ab;
Henrique Mendonça8ad13a32013-05-16 21:26:20 +0200409}
John Boiles5eef01f2019-06-13 10:49:45 -0700410
411struct OptionalSetDefaultTest {
412 1: optional set<string> with_default = [ "test" ]
413}