use of org.apache.drill.exec.physical.impl.scan.project.ResolvedTuple.ResolvedRow in project drill by apache.
the class TestReaderLevelProjection method testArrayProject.
/**
* Test project of an array. At the scan level, we just verify
* that the requested column is, indeed, an array.
*/
@Test
public void testArrayProject() {
// Simulate SELECT a[0] ...
final ScanLevelProjection scanProj = ScanLevelProjection.build(RowSetTestUtils.projectList("a[0]"), ScanTestUtils.parsers());
// Simulate a data source, with early schema, of (a)
// where a is not an array.
final TupleMetadata tableSchema = new SchemaBuilder().addArray("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(1, columns.size());
final ResolvedColumn aCol = columns.get(0);
assertEquals("a", aCol.name());
assertTrue(aCol instanceof ResolvedTableColumn);
assertSame(rootTuple, aCol.source());
assertEquals(0, aCol.sourceIndex());
}
use of org.apache.drill.exec.physical.impl.scan.project.ResolvedTuple.ResolvedRow in project drill by apache.
the class TestReaderLevelProjection method testWildcardWithSchema.
/**
* Non-strict metadata schema. Projects all schema columns
* followed by any "extra" reader columns.
*/
@Test
public void testWildcardWithSchema() {
TupleMetadata outputSchema = new SchemaBuilder().add("a", MinorType.INT).add("b", MinorType.BIGINT).buildSchema();
// 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(3, columns.size());
// Columns from schema preferentially use schema-defined names
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());
// Non-schema columns use reader names
ResolvedColumn cCol = columns.get(2);
assertEquals("C", cCol.name());
assertTrue(cCol instanceof ResolvedTableColumn);
assertNull(cCol.metadata());
final VectorSource nullBuilder = rootTuple.nullBuilder();
assertSame(nullBuilder, columns.get(0).source());
}
use of org.apache.drill.exec.physical.impl.scan.project.ResolvedTuple.ResolvedRow in project drill by apache.
the class TestReaderLevelProjection method testFullList.
/**
* Test SELECT list with columns defined in a order and with
* name case different than the early-schema table.
*/
@Test
public void testFullList() {
// Simulate SELECT c, b, a ...
final ScanLevelProjection scanProj = ScanLevelProjection.build(RowSetTestUtils.projectList("c", "b", "a"), ScanTestUtils.parsers());
assertEquals(3, 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(3, columns.size());
assertEquals("c", columns.get(0).name());
assertEquals(2, columns.get(0).sourceIndex());
assertSame(rootTuple, columns.get(0).source());
assertEquals("b", columns.get(1).name());
assertEquals(1, columns.get(1).sourceIndex());
assertSame(rootTuple, columns.get(1).source());
assertEquals("a", columns.get(2).name());
assertEquals(0, columns.get(2).sourceIndex());
assertSame(rootTuple, columns.get(2).source());
}
use of org.apache.drill.exec.physical.impl.scan.project.ResolvedTuple.ResolvedRow 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.ResolvedTuple.ResolvedRow 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());
}
Aggregations