ElasticSearch 测试

  • 测试

    Elasticsearch提供了一个jar文件,可以将其添加到任何Java IDE中,并可以用于测试与Elasticsearch相关的代码。使用Elasticsearch提供的框架可以执行一系列测试。在本章中,我们将详细讨论这些测试-
    • 单元测试
    • 整合测试
    • 随机测试
  • 先决条件

    要开始测试,您需要将Elasticsearch测试依赖项添加到程序中。您可以为此使用maven,并可以在pom.xml中添加以下内容。
    
    <dependency>
       <groupId>org.elasticsearch</groupId>
       <artifactId>elasticsearch</artifactId>
       <version>2.1.0</version>
    </dependency>
    
    EsSetup已被初始化,以启动和停止Elasticsearch节点并创建索引。
    
    EsSetup esSetup = new EsSetup();
    
    带有createIndex的esSetup.execute() 函数将创建索引,您需要指定设置,类型和数据。
  • 单元测试

    单元测试是通过使用JUnit和Elasticsearch测试框架进行的。可以使用Elasticsearch类创建节点和索引,并且可以使用test方法执行测试。ESTestCase和ESTokenStreamTestCase类用于此测试。
  • 整合测试

    集成测试使用集群中的多个节点。ESIntegTestCase类用于此测试。有多种方法可以简化准备测试用例的工作。
    方法 说明
    refresh() 刷新集群中的所有索引
    ensureGreen() 确保绿色健康集群状态
    ensureYellow() 确保黄色的健康群集状态
    createIndex(name) 使用传递给此方法的名称创建索引
    flush() 集群中的所有索引均被刷新
    flushAndRefresh() flush()和refresh()
    indexExists(name) 验证指定索引的存在
    clusterService() 返回集群服务的java类
    cluster() 返回测试集群类
  • 测试集群方法

    方法 说明
    ensureAtLeastNumNodes(n) 确保集群中的最小节点数大于或等于指定数目。
    ensureAtMostNumNodes(n) 确保群集中最多的节点数小于或等于指定的数目。
    stopRandomNode() 停止集群中的随机节点
    stopCurrentMasterNode() 停止主节点
    stopRandomNonMaster() 停止集群中不是主节点的随机节点。
    buildNode() 创建一个新节点
    startNode(settings) 启动一个新节点
    nodeSettings() 覆盖此方法以更改节点设置。
  • 访问客户端

    客户端用于访问群集中的不同节点并执行某些操作。ESIntegTestCase.client()方法用于获取随机客户端。Elasticsearch还提供了其他方法来访问客户端,并且可以使用ESIntegTestCase.internalCluster()方法来访问这些方法。
    方法 说明
    iterator() 这可以帮助您访问所有可用的客户端。
    masterClient() 这将返回一个正在与主节点进行通信的客户端。
    nonMasterClient() 这将返回不与主节点通信的客户端。
    clientNodeClient() 这将返回当前在客户端节点上运行的客户端。
  • 随机测试

    该测试用于对所有可能的数据进行用户代码测试,以便将来不会出现任何类型的数据故障。随机数据是执行此测试的最佳选择。

    生成随机数据

    在此测试中,Random类由RandomizedTest提供的实例实例化,并提供了许多用于获取不同类型数据的方法。
    方法 返回值
    getRandom() Instance of random class
    randomBoolean() Random boolean
    randomByte() Random byte
    randomShort() Random short
    randomInt() Random integer
    randomLong() Random long
    randomFloat() Random float
    randomDouble() Random double
    randomLocale() Random locale
    randomTimeZone() Random time zone
    randomFrom() Random element from array
  • 断言

    ElasticsearchAssertions和ElasticsearchGeoAssertions类包含断言,这些断言用于在测试时执行一些常规检查。例如,观察此处给出的代码-
    
    SearchResponse seearchResponse = client().prepareSearch();
    assertHitCount(searchResponse, 6);
    assertFirstHit(searchResponse, hasId("6"));
    assertSearchHits(searchResponse, "1", "2", "3", "4",”5”,”6”);