blob: d759bb0d6d3f57900702794025e46c0652a28533 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.thrift;
import java.nio.ByteBuffer;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import thrift.test.Bonk;
import thrift.test.CompactProtoTestStruct;
import thrift.test.HolyMoley;
import thrift.test.Nesting;
import thrift.test.OneOfEach;
public class Fixtures {
public static final OneOfEach oneOfEach;
public static final Nesting nesting;
public static final HolyMoley holyMoley;
public static final CompactProtoTestStruct compactProtoTestStruct;
private static final byte[] kUnicodeBytes = {
(byte)0xd3, (byte)0x80, (byte)0xe2, (byte)0x85, (byte)0xae, (byte)0xce,
(byte)0x9d, (byte)0x20, (byte)0xd0, (byte)0x9d, (byte)0xce, (byte)0xbf,
(byte)0xe2, (byte)0x85, (byte)0xbf, (byte)0xd0, (byte)0xbe, (byte)0xc9,
(byte)0xa1, (byte)0xd0, (byte)0xb3, (byte)0xd0, (byte)0xb0, (byte)0xcf,
(byte)0x81, (byte)0xe2, (byte)0x84, (byte)0x8e, (byte)0x20, (byte)0xce,
(byte)0x91, (byte)0x74, (byte)0x74, (byte)0xce, (byte)0xb1, (byte)0xe2,
(byte)0x85, (byte)0xbd, (byte)0xce, (byte)0xba, (byte)0x83, (byte)0xe2,
(byte)0x80, (byte)0xbc
};
static {
try {
oneOfEach = new OneOfEach();
oneOfEach.im_true = true;
oneOfEach.im_false = false;
oneOfEach.a_bite = (byte) 0xd6;
oneOfEach.integer16 = 27000;
oneOfEach.integer32 = 1 << 24;
oneOfEach.integer64 = (long) 6000 * 1000 * 1000;
oneOfEach.double_precision = Math.PI;
oneOfEach.some_characters = "JSON THIS! \"\1";
oneOfEach.zomg_unicode = new String(kUnicodeBytes, "UTF-8");
oneOfEach.base64 = ByteBuffer.wrap("base64".getBytes());
// byte, i16, and i64 lists are populated by default constructor
Bonk bonk = new Bonk();
bonk.type = 31337;
bonk.message = "I am a bonk... xor!";
nesting = new Nesting(bonk, oneOfEach);
holyMoley = new HolyMoley();
holyMoley.big = new ArrayList<OneOfEach>();
holyMoley.big.add(new OneOfEach(oneOfEach));
holyMoley.big.add(nesting.my_ooe);
holyMoley.big.get(0).a_bite = (byte) 0x22;
holyMoley.big.get(1).a_bite = (byte) 0x23;
holyMoley.contain = new HashSet<List<String>>();
ArrayList<String> stage1 = new ArrayList<String>(2);
stage1.add("and a one");
stage1.add("and a two");
holyMoley.contain.add(stage1);
stage1 = new ArrayList<String>(3);
stage1.add("then a one, two");
stage1.add("three!");
stage1.add("FOUR!!");
holyMoley.contain.add(stage1);
stage1 = new ArrayList<String>(0);
holyMoley.contain.add(stage1);
ArrayList<Bonk> stage2 = new ArrayList<Bonk>();
holyMoley.bonks = new HashMap<String, List<Bonk>>();
// one empty
holyMoley.bonks.put("zero", stage2);
// one with two
stage2 = new ArrayList<Bonk>();
Bonk b = new Bonk();
b.type = 1;
b.message = "Wait.";
stage2.add(b);
b = new Bonk();
b.type = 2;
b.message = "What?";
stage2.add(b);
holyMoley.bonks.put("two", stage2);
// one with three
stage2 = new ArrayList<Bonk>();
b = new Bonk();
b.type = 3;
b.message = "quoth";
b = new Bonk();
b.type = 4;
b.message = "the raven";
b = new Bonk();
b.type = 5;
b.message = "nevermore";
holyMoley.bonks.put("three", stage2);
// superhuge compact proto test struct
compactProtoTestStruct = new CompactProtoTestStruct(thrift.test.Constants.COMPACT_TEST);
compactProtoTestStruct.a_binary = ByteBuffer.wrap(new byte[]{0,1,2,3,4,5,6,7,8});
} catch (Exception e) {
throw new RuntimeException(e);
}
}
}