zoukankan      html  css  js  c++  java
  • dremio 开发测试简单说明

    目前官方关于如何进行相关开发测试的明确的文档说明,但是我们基于官方提供的测试用例可以基本了解

    官方提供的测试用例

    sabot/kernel/src/test/java/com/dremio 目录

    ├── ArrowDsUtil.java
    ├── BaseDecimalFunctionTests.java
    ├── BaseTestQuery.java
    ├── DecimalCompleteTest.java
    ├── DremioTestWrapper.java
    ├── ParquetSchemaMerge.java
    ├── PlanTestBase.java
    ├── QueryTestUtil.java
    ├── SingleRowListener.java
    ├── TestAggNullable.java
    ├── TestAggregationQueries.java
    ├── TestAltSortQueries.java
    ├── TestBugFixes.java
    ├── TestBuilder.java
    ├── TestCTASPartitionFilter.java
    ├── TestCaseSensitivity.java
    ├── TestCorrelation.java
    ├── TestDecimalFunctionsInGandivaCodeGen.java
    ├── TestDecimalFunctionsInGandivaOnlyCodeGen.java
    ├── TestDecimalFunctionsInJavaCodeGen.java
    ├── TestDecimalQueries.java
    ├── TestDecimalSetting.java
    ├── TestDecimalStreamAgg.java
    ├── TestDecimalVJoin.java
    ├── TestDecimalVectorizedAgg.java
    ├── TestDisabledFunctionality.java
    ├── TestDropTable.java
    ├── TestExampleQueries.java
    ├── TestExplainJson.java
    ├── TestFilterPastJoin.java
    ├── TestFrameworkTest.java
    ├── TestFunctionsQuery.java
    ├── TestFunctionsWithTypeExpoQueries.java
    ├── TestGandivaOnlyQueries.java
    ├── TestImplicitCasting.java
    ├── TestInList.java
    ├── TestIndexBasedPruning.java
    ├── TestIsNotDistinctFromJoin.java
    ├── TestJoinNullable.java
    ├── TestMergeFilterPlan.java
    ├── TestMergingReceiverSpooling.java
    ├── TestMfsBlockLoader.java
    ├── TestMixedDecimalFunctionTests.java
    ├── TestNljPushdown.java
    ├── TestNotInQueries.java
    ├── TestOutOfMemoryException.java
    ├── TestOutOfMemoryOutcome.java
    ├── TestProjectPushDown.java
    ├── TestResult.java
    ├── TestSchemaChange.java
    ├── TestSelectWithOption.java
    ├── TestStarQueries.java
    ├── TestTextJoin.java
    ├── TestTextWriter.java
    ├── TestTpchDistributed.java
    ├── TestTpchDistributedConcurrent.java
    ├── TestTpchDistributedStreaming.java
    ├── TestTpchExplain.java
    ├── TestTpchLimit0.java
    ├── TestTpchPlanning.java
    ├── TestTpchSingleMode.java
    ├── TestTransitiveJoin.java
    ├── TestTruncateTable.java
    ├── TestUnionAll.java
    ├── TestUnionDistinct.java
    ├── TestVectorizedPartitionSender.java
    ├── common
    ├── exec
    └── sabot

    plugin 测试简单说明

    参考自官方的测试demo
    需要做的事情,初始化一个dremio catalog 服务(进行插件管理),注册自己开发的插件,进行查询测试(注意测试基类需要继承自BaseTestQuery我们可以利用好多base 的方法,test...)

    • 简单参考
     
    public class TestSubPathFileSystemPlugin extends BaseTestQuery {
      @ClassRule
      public static TemporaryFolder testFolder = new TemporaryFolder();
     
      protected static File storageBase;
     
      @Rule
      public TemporarySystemProperties properties = new TemporarySystemProperties();
     
      @Before
      public void before() {
        properties.set(DremioConfig.LEGACY_STORE_VIEWS_ENABLED, "true");
      }
     
      @BeforeClass
      public static void setup() throws Exception {
        testNoResult("alter system set "%s" = 1", FileDatasetHandle.DFS_MAX_FILES.getOptionName());
        generateTestData();
        addSubPathDfsPlugin();
      }
     
      @Test
      public void queryValidPath() throws Exception {
        test("SELECT * FROM subPathDfs."tblInside.csv"");
        test("SELECT * FROM subPathDfs."dirInside/tbl.csv"");
      }

    maven 依赖包

    • 参考
      注意需要引用dremio kernel 的test 包,同时repo 需要使用dremio 自己的
     
    <dependency>
      <groupId>com.dremio.sabot</groupId>
      <artifactId>dremio-sabot-kernel</artifactId>
      <version>${project.version}</version>
      <classifier>tests</classifier>
      <scope>test</scope>
      <exclusions>
            <exclusion>
              <groupId>org.slf4j</groupId>
              <artifactId>slf4j-log4j12</artifactId>
            </exclusion>      
      </exclusions>
    </dependency>
     
    <repositories>
        <repository>
            <id>tencent-public</id>
            <url>http://mirrors.cloud.tencent.com/nexus/repository/maven-public/</url>
        </repository>
        <repository>
            <id>dremio-public</id>
            <url>http://maven.dremio.com/public/</url>
        </repository>
        <repository>
            <id>dremio-free</id>
            <url>http://maven.dremio.com/free/</url>
        </repository>
    </repositories>

    说明

    以上是一个简单的说明,实际还需要自己多研究,官方已经提供了好多demo

    参考资料

    https://github.com/dremio/dremio-oss

  • 相关阅读:
    关于面向对象和面象过程的一些感想
    面向对象之旅软件生命周期
    函数参数栈传递
    看完后停下来想想我们究竟在追求什么???
    面向对象之旅设计与设计原则
    [译]多重继承和虚继承的内存布局
    61条面向对象设计的经验原则
    数据库设计14个技巧(转)
    js的tween
    三、windows8 store
  • 原文地址:https://www.cnblogs.com/rongfengliang/p/14642625.html
Copyright © 2011-2022 走看看