add update integration tests
This commit is contained in:
parent
43182f07fd
commit
36a4cde89f
|
@ -34,14 +34,12 @@ import org.elasticsearch.action.get.GetResponse;
|
||||||
import org.elasticsearch.action.index.IndexResponse;
|
import org.elasticsearch.action.index.IndexResponse;
|
||||||
import org.elasticsearch.action.support.broadcast.BroadcastOperationThreading;
|
import org.elasticsearch.action.support.broadcast.BroadcastOperationThreading;
|
||||||
import org.elasticsearch.action.support.replication.ReplicationType;
|
import org.elasticsearch.action.support.replication.ReplicationType;
|
||||||
import org.elasticsearch.action.update.UpdateResponse;
|
|
||||||
import org.elasticsearch.client.Client;
|
import org.elasticsearch.client.Client;
|
||||||
import org.elasticsearch.common.Unicode;
|
import org.elasticsearch.common.Unicode;
|
||||||
import org.elasticsearch.common.settings.ImmutableSettings;
|
import org.elasticsearch.common.settings.ImmutableSettings;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.xcontent.XContentBuilder;
|
import org.elasticsearch.common.xcontent.XContentBuilder;
|
||||||
import org.elasticsearch.common.xcontent.XContentFactory;
|
import org.elasticsearch.common.xcontent.XContentFactory;
|
||||||
import org.elasticsearch.index.engine.DocumentMissingException;
|
|
||||||
import org.elasticsearch.test.integration.AbstractNodesTests;
|
import org.elasticsearch.test.integration.AbstractNodesTests;
|
||||||
import org.testng.annotations.AfterClass;
|
import org.testng.annotations.AfterClass;
|
||||||
import org.testng.annotations.BeforeClass;
|
import org.testng.annotations.BeforeClass;
|
||||||
|
@ -269,57 +267,6 @@ public class DocumentActionsTests extends AbstractNodesTests {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUpdate() throws Exception {
|
|
||||||
createIndex();
|
|
||||||
ClusterHealthResponse clusterHealth = client1.admin().cluster().prepareHealth().setWaitForGreenStatus().execute().actionGet();
|
|
||||||
assertThat(clusterHealth.timedOut(), equalTo(false));
|
|
||||||
assertThat(clusterHealth.status(), equalTo(ClusterHealthStatus.GREEN));
|
|
||||||
|
|
||||||
try {
|
|
||||||
client1.prepareUpdate("test", "type1", "1").setScript("ctx._source.field++").execute().actionGet();
|
|
||||||
assert false;
|
|
||||||
} catch (DocumentMissingException e) {
|
|
||||||
// all is well
|
|
||||||
}
|
|
||||||
|
|
||||||
client1.prepareIndex("test", "type1", "1").setSource("field", 1).execute().actionGet();
|
|
||||||
|
|
||||||
UpdateResponse updateResponse = client1.prepareUpdate("test", "type1", "1").setScript("ctx._source.field += 1").execute().actionGet();
|
|
||||||
assertThat(updateResponse.version(), equalTo(2L));
|
|
||||||
|
|
||||||
for (int i = 0; i < 5; i++) {
|
|
||||||
GetResponse getResponse = client1.prepareGet("test", "type1", "1").execute().actionGet();
|
|
||||||
assertThat(getResponse.sourceAsMap().get("field").toString(), equalTo("2"));
|
|
||||||
}
|
|
||||||
|
|
||||||
updateResponse = client1.prepareUpdate("test", "type1", "1").setScript("ctx._source.field += count").addScriptParam("count", 3).execute().actionGet();
|
|
||||||
assertThat(updateResponse.version(), equalTo(3L));
|
|
||||||
|
|
||||||
for (int i = 0; i < 5; i++) {
|
|
||||||
GetResponse getResponse = client1.prepareGet("test", "type1", "1").execute().actionGet();
|
|
||||||
assertThat(getResponse.sourceAsMap().get("field").toString(), equalTo("5"));
|
|
||||||
}
|
|
||||||
|
|
||||||
// check noop
|
|
||||||
updateResponse = client1.prepareUpdate("test", "type1", "1").setScript("ctx.op = 'none'").execute().actionGet();
|
|
||||||
assertThat(updateResponse.version(), equalTo(3L));
|
|
||||||
|
|
||||||
for (int i = 0; i < 5; i++) {
|
|
||||||
GetResponse getResponse = client1.prepareGet("test", "type1", "1").execute().actionGet();
|
|
||||||
assertThat(getResponse.sourceAsMap().get("field").toString(), equalTo("5"));
|
|
||||||
}
|
|
||||||
|
|
||||||
// check delete
|
|
||||||
updateResponse = client1.prepareUpdate("test", "type1", "1").setScript("ctx.op = 'delete'").execute().actionGet();
|
|
||||||
assertThat(updateResponse.version(), equalTo(4L));
|
|
||||||
|
|
||||||
for (int i = 0; i < 5; i++) {
|
|
||||||
GetResponse getResponse = client1.prepareGet("test", "type1", "1").execute().actionGet();
|
|
||||||
assertThat(getResponse.exists(), equalTo(false));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testBulk() throws Exception {
|
public void testBulk() throws Exception {
|
||||||
createIndex();
|
createIndex();
|
||||||
|
|
|
@ -0,0 +1,173 @@
|
||||||
|
/*
|
||||||
|
* Licensed to ElasticSearch and Shay Banon under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. ElasticSearch licenses this
|
||||||
|
* file to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.elasticsearch.test.integration.update;
|
||||||
|
|
||||||
|
import org.elasticsearch.action.admin.cluster.health.ClusterHealthResponse;
|
||||||
|
import org.elasticsearch.action.admin.cluster.health.ClusterHealthStatus;
|
||||||
|
import org.elasticsearch.action.get.GetResponse;
|
||||||
|
import org.elasticsearch.action.update.UpdateResponse;
|
||||||
|
import org.elasticsearch.client.Client;
|
||||||
|
import org.elasticsearch.common.settings.ImmutableSettings;
|
||||||
|
import org.elasticsearch.common.settings.Settings;
|
||||||
|
import org.elasticsearch.common.xcontent.XContentFactory;
|
||||||
|
import org.elasticsearch.index.engine.DocumentMissingException;
|
||||||
|
import org.elasticsearch.test.integration.AbstractNodesTests;
|
||||||
|
import org.testng.annotations.AfterClass;
|
||||||
|
import org.testng.annotations.BeforeClass;
|
||||||
|
import org.testng.annotations.Test;
|
||||||
|
|
||||||
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
|
import static org.elasticsearch.index.query.QueryBuilders.termQuery;
|
||||||
|
import static org.hamcrest.MatcherAssert.assertThat;
|
||||||
|
import static org.hamcrest.Matchers.*;
|
||||||
|
|
||||||
|
public class UpdateTests extends AbstractNodesTests {
|
||||||
|
private Client client;
|
||||||
|
|
||||||
|
@BeforeClass
|
||||||
|
public void startNodes() throws Exception {
|
||||||
|
startNode("node1", nodeSettings());
|
||||||
|
startNode("node2", nodeSettings());
|
||||||
|
client = getClient();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void createIndex() throws Exception {
|
||||||
|
try {
|
||||||
|
client.admin().indices().prepareDelete("test").execute().actionGet();
|
||||||
|
} catch (Exception e) {
|
||||||
|
// ignore
|
||||||
|
}
|
||||||
|
logger.info("--> creating index test");
|
||||||
|
client.admin().indices().prepareCreate("test")
|
||||||
|
.addMapping("type1", XContentFactory.jsonBuilder()
|
||||||
|
.startObject()
|
||||||
|
.startObject("type1")
|
||||||
|
.startObject("_timestamp").field("enabled", true).field("store", "yes").endObject()
|
||||||
|
.startObject("_ttl").field("enabled", true).field("store", "yes").endObject()
|
||||||
|
.endObject()
|
||||||
|
.endObject())
|
||||||
|
.execute().actionGet();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Settings nodeSettings() {
|
||||||
|
return ImmutableSettings.Builder.EMPTY_SETTINGS;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected String getConcreteIndexName() {
|
||||||
|
return "test";
|
||||||
|
}
|
||||||
|
|
||||||
|
@AfterClass
|
||||||
|
public void closeNodes() {
|
||||||
|
client.close();
|
||||||
|
closeAllNodes();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Client getClient() {
|
||||||
|
return client("node1");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testUpdate() throws Exception {
|
||||||
|
createIndex();
|
||||||
|
ClusterHealthResponse clusterHealth = client.admin().cluster().prepareHealth().setWaitForGreenStatus().execute().actionGet();
|
||||||
|
assertThat(clusterHealth.timedOut(), equalTo(false));
|
||||||
|
assertThat(clusterHealth.status(), equalTo(ClusterHealthStatus.GREEN));
|
||||||
|
|
||||||
|
try {
|
||||||
|
client.prepareUpdate("test", "type1", "1").setScript("ctx._source.field++").execute().actionGet();
|
||||||
|
assert false;
|
||||||
|
} catch (DocumentMissingException e) {
|
||||||
|
// all is well
|
||||||
|
}
|
||||||
|
|
||||||
|
client.prepareIndex("test", "type1", "1").setSource("field", 1).execute().actionGet();
|
||||||
|
|
||||||
|
UpdateResponse updateResponse = client.prepareUpdate("test", "type1", "1").setScript("ctx._source.field += 1").execute().actionGet();
|
||||||
|
assertThat(updateResponse.version(), equalTo(2L));
|
||||||
|
|
||||||
|
for (int i = 0; i < 5; i++) {
|
||||||
|
GetResponse getResponse = client.prepareGet("test", "type1", "1").execute().actionGet();
|
||||||
|
assertThat(getResponse.sourceAsMap().get("field").toString(), equalTo("2"));
|
||||||
|
}
|
||||||
|
|
||||||
|
updateResponse = client.prepareUpdate("test", "type1", "1").setScript("ctx._source.field += count").addScriptParam("count", 3).execute().actionGet();
|
||||||
|
assertThat(updateResponse.version(), equalTo(3L));
|
||||||
|
|
||||||
|
for (int i = 0; i < 5; i++) {
|
||||||
|
GetResponse getResponse = client.prepareGet("test", "type1", "1").execute().actionGet();
|
||||||
|
assertThat(getResponse.sourceAsMap().get("field").toString(), equalTo("5"));
|
||||||
|
}
|
||||||
|
|
||||||
|
// check noop
|
||||||
|
updateResponse = client.prepareUpdate("test", "type1", "1").setScript("ctx.op = 'none'").execute().actionGet();
|
||||||
|
assertThat(updateResponse.version(), equalTo(3L));
|
||||||
|
|
||||||
|
for (int i = 0; i < 5; i++) {
|
||||||
|
GetResponse getResponse = client.prepareGet("test", "type1", "1").execute().actionGet();
|
||||||
|
assertThat(getResponse.sourceAsMap().get("field").toString(), equalTo("5"));
|
||||||
|
}
|
||||||
|
|
||||||
|
// check delete
|
||||||
|
updateResponse = client.prepareUpdate("test", "type1", "1").setScript("ctx.op = 'delete'").execute().actionGet();
|
||||||
|
assertThat(updateResponse.version(), equalTo(4L));
|
||||||
|
|
||||||
|
for (int i = 0; i < 5; i++) {
|
||||||
|
GetResponse getResponse = client.prepareGet("test", "type1", "1").execute().actionGet();
|
||||||
|
assertThat(getResponse.exists(), equalTo(false));
|
||||||
|
}
|
||||||
|
|
||||||
|
// check percolation
|
||||||
|
client.prepareIndex("test", "type1", "1").setSource("field", 1).execute().actionGet();
|
||||||
|
logger.info("--> register a query");
|
||||||
|
client.prepareIndex("_percolator", "test", "1")
|
||||||
|
.setSource(jsonBuilder().startObject()
|
||||||
|
.field("query", termQuery("field", 2))
|
||||||
|
.endObject())
|
||||||
|
.setRefresh(true)
|
||||||
|
.execute().actionGet();
|
||||||
|
updateResponse = client.prepareUpdate("test", "type1", "1").setScript("ctx._source.field += 1").setPercolate("*").execute().actionGet();
|
||||||
|
assertThat(updateResponse.matches().size(), equalTo(1));
|
||||||
|
|
||||||
|
// check TTL is kept after an update without TTL
|
||||||
|
client.prepareIndex("test", "type1", "2").setSource("field", 1).setTTL(86400000L).setRefresh(true).execute().actionGet();
|
||||||
|
GetResponse getResponse = client.prepareGet("test", "type1", "2").setFields("_ttl").execute().actionGet();
|
||||||
|
long ttl = ((Number) getResponse.field("_ttl").value()).longValue();
|
||||||
|
assertThat(ttl, greaterThan(0L));
|
||||||
|
client.prepareUpdate("test", "type1", "2").setScript("ctx._source.field += 1").execute().actionGet();
|
||||||
|
getResponse = client.prepareGet("test", "type1", "2").setFields("_ttl").execute().actionGet();
|
||||||
|
ttl = ((Number) getResponse.field("_ttl").value()).longValue();
|
||||||
|
assertThat(ttl, greaterThan(0L));
|
||||||
|
|
||||||
|
// check TTL update
|
||||||
|
client.prepareUpdate("test", "type1", "2").setScript("ctx._ttl = 3600000").execute().actionGet();
|
||||||
|
getResponse = client.prepareGet("test", "type1", "2").setFields("_ttl").execute().actionGet();
|
||||||
|
ttl = ((Number) getResponse.field("_ttl").value()).longValue();
|
||||||
|
assertThat(ttl, greaterThan(0L));
|
||||||
|
assertThat(ttl, lessThan(3600000L));
|
||||||
|
|
||||||
|
// check timestamp update
|
||||||
|
client.prepareIndex("test", "type1", "3").setSource("field", 1).setRefresh(true).execute().actionGet();
|
||||||
|
client.prepareUpdate("test", "type1", "3").setScript("ctx._timestamp = \"2009-11-15T14:12:12\"").execute().actionGet();
|
||||||
|
getResponse = client.prepareGet("test", "type1", "3").setFields("_timestamp").execute().actionGet();
|
||||||
|
long timestamp = ((Number) getResponse.field("_timestamp").value()).longValue();
|
||||||
|
assertThat(timestamp, equalTo(1258294332000L));
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue