本文整理汇总了Java中com.twitter.elephantbird.thrift.test.TestStructInMap类的典型用法代码示例。如果您正苦于以下问题:Java TestStructInMap类的具体用法?Java TestStructInMap怎么用?Java TestStructInMap使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
TestStructInMap类属于com.twitter.elephantbird.thrift.test包,在下文中一共展示了TestStructInMap类的8个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: testFieldsPath
import com.twitter.elephantbird.thrift.test.TestStructInMap; //导入依赖的package包/类
@Test
public void testFieldsPath() {
StructType person = ThriftSchemaConverter.toStructType(Person.class);
List<String> paths = PrimitivePathVisitor.visit(person, ".");
assertEquals(Arrays.asList("name.first_name", "name.last_name", "id", "email", "phones.number", "phones.type"),
paths);
paths = PrimitivePathVisitor.visit(person, "/");
assertEquals(Arrays.asList("name/first_name", "name/last_name", "id", "email", "phones/number", "phones/type"),
paths);
StructType structInMap = ThriftSchemaConverter.toStructType(TestStructInMap.class);
paths = PrimitivePathVisitor.visit(structInMap, ".");
assertEquals(Arrays.asList("name", "names.key", "names.value.name.first_name", "names.value.name.last_name",
"names.value.phones.key", "names.value.phones.value", "name_to_id.key", "name_to_id.value"), paths);
paths = PrimitivePathVisitor.visit(structInMap, "/");
assertEquals(Arrays.asList("name", "names/key", "names/value/name/first_name", "names/value/name/last_name",
"names/value/phones/key", "names/value/phones/value", "name_to_id/key", "name_to_id/value"), paths);
}
示例2: testProjectOnlyKeyInMap
import com.twitter.elephantbird.thrift.test.TestStructInMap; //导入依赖的package包/类
@Test
public void testProjectOnlyKeyInMap() {
shouldGetProjectedSchema("name;names/key", "name;names.key", "message ParquetSchema {\n" +
" optional binary name (UTF8) = 1;\n" +
" optional group names (MAP) = 2 {\n" +
" repeated group map (MAP_KEY_VALUE) {\n" +
" required binary key (UTF8);\n" +
" optional group value {\n" +
" optional group name = 1 {\n" +
" optional binary first_name (UTF8) = 1;\n" +
" }\n" +
" }" +
" }\n" +
" }\n" +
"}",TestStructInMap.class);
}
示例3: testStructInMap
import com.twitter.elephantbird.thrift.test.TestStructInMap; //导入依赖的package包/类
@Test
public void testStructInMap() throws Exception {
final Map<String, TestPerson> map = new HashMap<String, TestPerson>();
map.put("foo", new TestPerson(new TestName("john", "johnson"), new HashMap<TestPhoneType, String>()));
final Map<String, Integer> stringToIntMap = Collections.singletonMap("bar", 10);
TestStructInMap testMap = new TestStructInMap("map_name", map, stringToIntMap);
validate(testMap);
}
示例4: testProjectMapThriftType
import com.twitter.elephantbird.thrift.test.TestStructInMap; //导入依赖的package包/类
@Test
public void testProjectMapThriftType() {
//project nested map
shouldGetProjectedSchema("name;names/key*;names/value/**", "name;names.key*;names.value", "message ParquetSchema {\n" +
" optional binary name (UTF8) = 1;\n" +
" optional group names (MAP) = 2 {\n" +
" repeated group map (MAP_KEY_VALUE) {\n" +
" required binary key (UTF8);\n" +
" optional group value {\n" +
" optional group name = 1 {\n" +
" optional binary first_name (UTF8) = 1;\n" +
" optional binary last_name (UTF8) = 2;\n" +
" }\n" +
" optional group phones (MAP) = 2 {\n" +
" repeated group map (MAP_KEY_VALUE) {\n" +
" required binary key (ENUM);\n" +
" optional binary value (UTF8);\n" +
" }\n" +
" }\n" +
" }\n" +
" }\n" +
" }\n" +
"}", TestStructInMap.class);
//project only one level of nested map
shouldGetProjectedSchema("name;names/key;names/value/name/*", "name;names.key;names.value.name","message ParquetSchema {\n" +
" optional binary name (UTF8) = 1;\n" +
" optional group names (MAP) = 2 {\n" +
" repeated group map (MAP_KEY_VALUE) {\n" +
" required binary key (UTF8);\n" +
" optional group value {\n" +
" optional group name = 1 {\n" +
" optional binary first_name (UTF8) = 1;\n" +
" optional binary last_name (UTF8) = 2;\n" +
" }\n" +
" }\n" +
" }\n" +
" }\n" +
"}", TestStructInMap.class);
}
示例5: testThrowWhenProjectionFilterMatchesNothing
import com.twitter.elephantbird.thrift.test.TestStructInMap; //导入依赖的package包/类
@Test
public void testThrowWhenProjectionFilterMatchesNothing() {
shouldThrowWhenProjectionFilterMatchesNothing("name;non_existing", "non_existing", TestStructInMap.class);
shouldThrowWhenProjectionFilterMatchesNothing("**;non_existing", "non_existing", TestStructInMap.class);
shouldThrowWhenProjectionFilterMatchesNothing("**;names/non_existing", "names/non_existing", TestStructInMap.class);
shouldThrowWhenProjectionFilterMatchesNothing("**;names/non_existing;non_existing", "names/non_existing\nnon_existing", TestStructInMap.class);
}
示例6: testStructInMap
import com.twitter.elephantbird.thrift.test.TestStructInMap; //导入依赖的package包/类
@Test
public void testStructInMap() throws Exception {
final Map<String, TestPerson> map = new HashMap<String, TestPerson>();
map.put("foo", new TestPerson(new TestName("john", "johnson"), new HashMap<TestPhoneType, String>()));
final Map<String, Integer> stringToIntMap = Collections.singletonMap("bar", 10);
TestStructInMap testMap = new TestStructInMap("map_name", map, stringToIntMap);
validateSameTupleAsEB(testMap);
}
示例7: testStructInMap
import com.twitter.elephantbird.thrift.test.TestStructInMap; //导入依赖的package包/类
@Test
public void testStructInMap() throws Exception {
String[] expectations = {
"startMessage()",
"startField(name, 0)",
"addBinary(map_name)",
"endField(name, 0)",
"startField(names, 1)",
"startGroup()",
"startField(map, 0)",
"startGroup()",
"startField(key, 0)",
"addBinary(foo)",
"endField(key, 0)",
"startField(value, 1)",
"startGroup()",
"startField(name, 0)",
"startGroup()",
"startField(first_name, 0)",
"addBinary(john)",
"endField(first_name, 0)",
"startField(last_name, 1)",
"addBinary(johnson)",
"endField(last_name, 1)",
"endGroup()",
"endField(name, 0)",
"startField(phones, 1)",
"startGroup()",
"endGroup()",
"endField(phones, 1)",
"endGroup()",
"endField(value, 1)",
"endGroup()",
"endField(map, 0)",
"endGroup()",
"endField(names, 1)",
"startField(name_to_id, 2)",
"startGroup()",
"startField(map, 0)",
"startGroup()",
"startField(key, 0)",
"addBinary(bar)",
"endField(key, 0)",
"startField(value, 1)",
"addInt(10)",
"endField(value, 1)",
"endGroup()",
"endField(map, 0)",
"endGroup()",
"endField(name_to_id, 2)",
"endMessage()"
};
final Map<String, TestPerson> map = new HashMap<String, TestPerson>();
map.put("foo", new TestPerson(new TestName("john", "johnson"), new HashMap<TestPhoneType, String>()));
final Map<String, Integer> stringToIntMap = Collections.singletonMap("bar", 10);
TestStructInMap testMap = new TestStructInMap("map_name", map, stringToIntMap);
validatePig(expectations, testMap);
validateThrift(expectations, testMap);
}
示例8: testThrowWhenNoColumnsAreSelected
import com.twitter.elephantbird.thrift.test.TestStructInMap; //导入依赖的package包/类
@Test
public void testThrowWhenNoColumnsAreSelected() {
shouldThrowWhenNoColumnsAreSelected("non_existing", TestStructInMap.class);
}