use of org.apache.drill.exec.physical.impl.scan.project.NullColumnBuilder.NullBuilderBuilder in project drill by apache.
the class TestReaderLevelProjection method testMapMismatch.
/**
* Project of a non-map as a map
*/
@Test
public void testMapMismatch() {
// Simulate SELECT a.b ...
final ScanLevelProjection scanProj = ScanLevelProjection.build(RowSetTestUtils.projectList("a.b"), ScanTestUtils.parsers());
// Simulate a data source, with early schema, of (a)
// where a is not a map.
final TupleMetadata tableSchema = new SchemaBuilder().add("a", MinorType.VARCHAR).buildSchema();
final NullColumnBuilder builder = new NullBuilderBuilder().build();
final ResolvedRow rootTuple = new ResolvedRow(builder);
try {
new ExplicitSchemaProjection(scanProj, tableSchema, rootTuple, ScanTestUtils.resolvers());
fail();
} catch (final UserException e) {
// Expected
}
}
use of org.apache.drill.exec.physical.impl.scan.project.NullColumnBuilder.NullBuilderBuilder in project drill by apache.
the class TestReaderLevelProjection method testWildcard.
/**
* Test wildcard projection: take all columns on offer from
* the data source, in the order that the data source specifies.
*/
@Test
public void testWildcard() {
final ScanLevelProjection scanProj = ScanLevelProjection.build(RowSetTestUtils.projectAll(), ScanTestUtils.parsers());
assertEquals(1, scanProj.columns().size());
final TupleMetadata tableSchema = new SchemaBuilder().add("a", MinorType.VARCHAR).addNullable("c", MinorType.INT).addArray("d", MinorType.FLOAT8).buildSchema();
final NullColumnBuilder builder = new NullBuilderBuilder().build();
final ResolvedRow rootTuple = new ResolvedRow(builder);
new WildcardProjection(scanProj, tableSchema, rootTuple, ScanTestUtils.resolvers());
final List<ResolvedColumn> columns = rootTuple.columns();
assertEquals(3, columns.size());
assertEquals("a", columns.get(0).name());
assertEquals(0, columns.get(0).sourceIndex());
assertSame(rootTuple, columns.get(0).source());
assertEquals("c", columns.get(1).name());
assertEquals(1, columns.get(1).sourceIndex());
assertSame(rootTuple, columns.get(1).source());
assertEquals("d", columns.get(2).name());
assertEquals(2, columns.get(2).sourceIndex());
assertSame(rootTuple, columns.get(2).source());
}
use of org.apache.drill.exec.physical.impl.scan.project.NullColumnBuilder.NullBuilderBuilder in project drill by apache.
the class TestReaderLevelProjection method testWildcardWithStrictSchema.
/**
* Strict metadata schema. Projects output the output schema
* columns; ignores other reader columns.
*/
@Test
public void testWildcardWithStrictSchema() {
TupleMetadata outputSchema = new SchemaBuilder().add("a", MinorType.INT).add("b", MinorType.BIGINT).buildSchema();
outputSchema.setProperty(TupleMetadata.IS_STRICT_SCHEMA_PROP, Boolean.TRUE.toString());
// Simulate SELECT * ...
final ScanLevelProjection scanProj = ScanLevelProjection.build(RowSetTestUtils.projectAll(), ScanTestUtils.parsers(), outputSchema);
assertEquals(2, scanProj.columns().size());
// Simulate a data source, with early schema, of (b, c)
final TupleMetadata tableSchema = new SchemaBuilder().add("B", MinorType.VARCHAR).add("C", MinorType.VARCHAR).buildSchema();
final NullColumnBuilder builder = new NullBuilderBuilder().build();
final ResolvedRow rootTuple = new ResolvedRow(builder);
new WildcardSchemaProjection(scanProj, tableSchema, rootTuple, ScanTestUtils.resolvers());
final List<ResolvedColumn> columns = rootTuple.columns();
assertEquals(2, columns.size());
ResolvedColumn aCol = columns.get(0);
assertEquals("a", aCol.name());
assertTrue(aCol instanceof ResolvedNullColumn);
assertNotNull(aCol.metadata());
assertSame(outputSchema.metadata("a"), aCol.metadata());
ResolvedColumn bCol = columns.get(1);
assertEquals("b", bCol.name());
assertTrue(bCol instanceof ResolvedTableColumn);
assertNotNull(bCol.metadata());
assertSame(outputSchema.metadata("b"), bCol.metadata());
final VectorSource nullBuilder = rootTuple.nullBuilder();
assertSame(nullBuilder, columns.get(0).source());
}
use of org.apache.drill.exec.physical.impl.scan.project.NullColumnBuilder.NullBuilderBuilder in project drill by apache.
the class TestReaderLevelProjection method testMissing.
/**
* Test SELECT list with columns missing from the table schema.
*/
@Test
public void testMissing() {
// Simulate SELECT c, v, b, w ...
final ScanLevelProjection scanProj = ScanLevelProjection.build(RowSetTestUtils.projectList("c", "v", "b", "w"), ScanTestUtils.parsers());
assertEquals(4, scanProj.columns().size());
// Simulate a data source, with early schema, of (a, b, c)
final TupleMetadata tableSchema = new SchemaBuilder().add("A", MinorType.VARCHAR).add("B", MinorType.VARCHAR).add("C", MinorType.VARCHAR).buildSchema();
final NullColumnBuilder builder = new NullBuilderBuilder().build();
final ResolvedRow rootTuple = new ResolvedRow(builder);
new ExplicitSchemaProjection(scanProj, tableSchema, rootTuple, ScanTestUtils.resolvers());
final List<ResolvedColumn> columns = rootTuple.columns();
assertEquals(4, columns.size());
final VectorSource nullBuilder = rootTuple.nullBuilder();
assertEquals("c", columns.get(0).name());
assertEquals(2, columns.get(0).sourceIndex());
assertSame(rootTuple, columns.get(0).source());
assertEquals("v", columns.get(1).name());
assertEquals(0, columns.get(1).sourceIndex());
assertSame(nullBuilder, columns.get(1).source());
assertEquals("b", columns.get(2).name());
assertEquals(1, columns.get(2).sourceIndex());
assertSame(rootTuple, columns.get(2).source());
assertEquals("w", columns.get(3).name());
assertEquals(1, columns.get(3).sourceIndex());
assertSame(nullBuilder, columns.get(3).source());
}
use of org.apache.drill.exec.physical.impl.scan.project.NullColumnBuilder.NullBuilderBuilder in project drill by apache.
the class TestReaderLevelProjection method testOmittedMap.
/**
* Test the obscure case that the data source contains a map, but we
* project only one of the members of the map. The output should be a
* map that contains only the members we request.
*/
@Test
public void testOmittedMap() {
// Simulate SELECT a, b.c.d ...
final ScanLevelProjection scanProj = ScanLevelProjection.build(RowSetTestUtils.projectList("a", "b.c.d"), ScanTestUtils.parsers());
assertEquals(2, scanProj.columns().size());
{
assertTrue(scanProj.columns().get(1) instanceof UnresolvedColumn);
final UnresolvedColumn bCol = (UnresolvedColumn) (scanProj.columns().get(1));
assertTrue(bCol.element().isTuple());
}
// Simulate a data source, with early schema, of (a)
final TupleMetadata tableSchema = new SchemaBuilder().add("a", MinorType.VARCHAR).buildSchema();
final NullColumnBuilder builder = new NullBuilderBuilder().build();
final ResolvedRow rootTuple = new ResolvedRow(builder);
new ExplicitSchemaProjection(scanProj, tableSchema, rootTuple, ScanTestUtils.resolvers());
final List<ResolvedColumn> columns = rootTuple.columns();
assertEquals(2, columns.size());
// Should have resolved a to a table column, b to a missing map.
// A is projected
final ResolvedColumn aCol = columns.get(0);
assertEquals("a", aCol.name());
assertTrue(aCol instanceof ResolvedTableColumn);
// B is not projected, is implicitly a map
final ResolvedColumn bCol = columns.get(1);
assertEquals("b", bCol.name());
assertTrue(bCol instanceof ResolvedMapColumn);
final ResolvedMapColumn bMap = (ResolvedMapColumn) bCol;
final ResolvedTuple bMembers = bMap.members();
assertNotNull(bMembers);
assertEquals(1, bMembers.columns().size());
// C is a map within b
final ResolvedColumn cCol = bMembers.columns().get(0);
assertTrue(cCol instanceof ResolvedMapColumn);
final ResolvedMapColumn cMap = (ResolvedMapColumn) cCol;
final ResolvedTuple cMembers = cMap.members();
assertNotNull(cMembers);
assertEquals(1, cMembers.columns().size());
// D is an unknown column type (not a map)
final ResolvedColumn dCol = cMembers.columns().get(0);
assertTrue(dCol instanceof ResolvedNullColumn);
}
Aggregations