|  | @@ -45,8 +45,9 @@ import java.util.concurrent.atomic.AtomicInteger;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  import static org.elasticsearch.index.query.QueryBuilders.matchAllQuery;
 |  |  import static org.elasticsearch.index.query.QueryBuilders.matchAllQuery;
 | 
											
												
													
														|  |  import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
 |  |  import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
 | 
											
												
													
														|  | 
 |  | +import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertFutureThrows;
 | 
											
												
													
														|  |  import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertHitCount;
 |  |  import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertHitCount;
 | 
											
												
													
														|  | -import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertThrows;
 |  | 
 | 
											
												
													
														|  | 
 |  | +import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertRequestBuilderThrows;
 | 
											
												
													
														|  |  import static org.hamcrest.Matchers.equalTo;
 |  |  import static org.hamcrest.Matchers.equalTo;
 | 
											
												
													
														|  |  import static org.hamcrest.Matchers.lessThanOrEqualTo;
 |  |  import static org.hamcrest.Matchers.lessThanOrEqualTo;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -63,7 +64,7 @@ public class SimpleVersioningIT extends ESIntegTestCase {
 | 
											
												
													
														|  |          assertEquals(DocWriteResponse.Result.NOT_FOUND, deleteResponse.getResult());
 |  |          assertEquals(DocWriteResponse.Result.NOT_FOUND, deleteResponse.getResult());
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          // this should conflict with the delete command transaction which told us that the object was deleted at version 17.
 |  |          // this should conflict with the delete command transaction which told us that the object was deleted at version 17.
 | 
											
												
													
														|  | -        assertThrows(
 |  | 
 | 
											
												
													
														|  | 
 |  | +        assertFutureThrows(
 | 
											
												
													
														|  |                  client().prepareIndex("test").setId("1").setSource("field1", "value1_1").setVersion(13)
 |  |                  client().prepareIndex("test").setId("1").setSource("field1", "value1_1").setVersion(13)
 | 
											
												
													
														|  |                      .setVersionType(VersionType.EXTERNAL).execute(),
 |  |                      .setVersionType(VersionType.EXTERNAL).execute(),
 | 
											
												
													
														|  |                  VersionConflictEngineException.class
 |  |                  VersionConflictEngineException.class
 | 
											
										
											
												
													
														|  | @@ -89,7 +90,7 @@ public class SimpleVersioningIT extends ESIntegTestCase {
 | 
											
												
													
														|  |              .setVersionType(VersionType.EXTERNAL_GTE).get();
 |  |              .setVersionType(VersionType.EXTERNAL_GTE).get();
 | 
											
												
													
														|  |          assertThat(indexResponse.getVersion(), equalTo(14L));
 |  |          assertThat(indexResponse.getVersion(), equalTo(14L));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -        assertThrows(client().prepareIndex("test").setId("1").setSource("field1", "value1_1").setVersion(13)
 |  | 
 | 
											
												
													
														|  | 
 |  | +        assertRequestBuilderThrows(client().prepareIndex("test").setId("1").setSource("field1", "value1_1").setVersion(13)
 | 
											
												
													
														|  |                  .setVersionType(VersionType.EXTERNAL_GTE),
 |  |                  .setVersionType(VersionType.EXTERNAL_GTE),
 | 
											
												
													
														|  |                  VersionConflictEngineException.class);
 |  |                  VersionConflictEngineException.class);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -102,7 +103,7 @@ public class SimpleVersioningIT extends ESIntegTestCase {
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          // deleting with a lower version fails.
 |  |          // deleting with a lower version fails.
 | 
											
												
													
														|  | -        assertThrows(
 |  | 
 | 
											
												
													
														|  | 
 |  | +        assertRequestBuilderThrows(
 | 
											
												
													
														|  |                  client().prepareDelete("test", "1").setVersion(2).setVersionType(VersionType.EXTERNAL_GTE),
 |  |                  client().prepareDelete("test", "1").setVersion(2).setVersionType(VersionType.EXTERNAL_GTE),
 | 
											
												
													
														|  |                  VersionConflictEngineException.class);
 |  |                  VersionConflictEngineException.class);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -114,7 +115,7 @@ public class SimpleVersioningIT extends ESIntegTestCase {
 | 
											
												
													
														|  |          assertThat(deleteResponse.getVersion(), equalTo(v));
 |  |          assertThat(deleteResponse.getVersion(), equalTo(v));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          // Deleting with a lower version keeps on failing after a delete.
 |  |          // Deleting with a lower version keeps on failing after a delete.
 | 
											
												
													
														|  | -        assertThrows(
 |  | 
 | 
											
												
													
														|  | 
 |  | +        assertFutureThrows(
 | 
											
												
													
														|  |                  client().prepareDelete("test", "1").setVersion(2).setVersionType(VersionType.EXTERNAL_GTE).execute(),
 |  |                  client().prepareDelete("test", "1").setVersion(2).setVersionType(VersionType.EXTERNAL_GTE).execute(),
 | 
											
												
													
														|  |                  VersionConflictEngineException.class);
 |  |                  VersionConflictEngineException.class);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -138,9 +139,9 @@ public class SimpleVersioningIT extends ESIntegTestCase {
 | 
											
												
													
														|  |              .setVersionType(VersionType.EXTERNAL).execute().actionGet();
 |  |              .setVersionType(VersionType.EXTERNAL).execute().actionGet();
 | 
											
												
													
														|  |          assertThat(indexResponse.getVersion(), equalTo(14L));
 |  |          assertThat(indexResponse.getVersion(), equalTo(14L));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -        assertThrows(client().prepareIndex("test").setId("1").setSource("field1", "value1_1").setVersion(13)
 |  | 
 | 
											
												
													
														|  | -                .setVersionType(VersionType.EXTERNAL).execute(),
 |  | 
 | 
											
												
													
														|  | -                VersionConflictEngineException.class);
 |  | 
 | 
											
												
													
														|  | 
 |  | +        assertFutureThrows(client().prepareIndex("test").setId("1").setSource("field1", "value1_1").setVersion(13)
 | 
											
												
													
														|  | 
 |  | +            .setVersionType(VersionType.EXTERNAL).execute(),
 | 
											
												
													
														|  | 
 |  | +            VersionConflictEngineException.class);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          if (randomBoolean()) {
 |  |          if (randomBoolean()) {
 | 
											
												
													
														|  |              refresh();
 |  |              refresh();
 | 
											
										
											
												
													
														|  | @@ -150,7 +151,7 @@ public class SimpleVersioningIT extends ESIntegTestCase {
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          // deleting with a lower version fails.
 |  |          // deleting with a lower version fails.
 | 
											
												
													
														|  | -        assertThrows(
 |  | 
 | 
											
												
													
														|  | 
 |  | +        assertFutureThrows(
 | 
											
												
													
														|  |                  client().prepareDelete("test", "1").setVersion(2).setVersionType(VersionType.EXTERNAL).execute(),
 |  |                  client().prepareDelete("test", "1").setVersion(2).setVersionType(VersionType.EXTERNAL).execute(),
 | 
											
												
													
														|  |                  VersionConflictEngineException.class);
 |  |                  VersionConflictEngineException.class);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -161,7 +162,7 @@ public class SimpleVersioningIT extends ESIntegTestCase {
 | 
											
												
													
														|  |          assertThat(deleteResponse.getVersion(), equalTo(17L));
 |  |          assertThat(deleteResponse.getVersion(), equalTo(17L));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          // Deleting with a lower version keeps on failing after a delete.
 |  |          // Deleting with a lower version keeps on failing after a delete.
 | 
											
												
													
														|  | -        assertThrows(
 |  | 
 | 
											
												
													
														|  | 
 |  | +        assertFutureThrows(
 | 
											
												
													
														|  |                  client().prepareDelete("test", "1").setVersion(2).setVersionType(VersionType.EXTERNAL).execute(),
 |  |                  client().prepareDelete("test", "1").setVersion(2).setVersionType(VersionType.EXTERNAL).execute(),
 | 
											
												
													
														|  |                  VersionConflictEngineException.class);
 |  |                  VersionConflictEngineException.class);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -217,7 +218,7 @@ public class SimpleVersioningIT extends ESIntegTestCase {
 | 
											
												
													
														|  |          createIndex("test");
 |  |          createIndex("test");
 | 
											
												
													
														|  |          ensureGreen();
 |  |          ensureGreen();
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -        assertThrows(client().prepareDelete("test", "1").setIfSeqNo(17).setIfPrimaryTerm(10).execute(),
 |  | 
 | 
											
												
													
														|  | 
 |  | +        assertFutureThrows(client().prepareDelete("test", "1").setIfSeqNo(17).setIfPrimaryTerm(10).execute(),
 | 
											
												
													
														|  |                  VersionConflictEngineException.class);
 |  |                  VersionConflictEngineException.class);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          IndexResponse indexResponse = client().prepareIndex("test").setId("1").setSource("field1", "value1_1")
 |  |          IndexResponse indexResponse = client().prepareIndex("test").setId("1").setSource("field1", "value1_1")
 | 
											
										
											
												
													
														|  | @@ -237,22 +238,25 @@ public class SimpleVersioningIT extends ESIntegTestCase {
 | 
											
												
													
														|  |          assertThat(indexResponse.getSeqNo(), equalTo(1L));
 |  |          assertThat(indexResponse.getSeqNo(), equalTo(1L));
 | 
											
												
													
														|  |          assertThat(indexResponse.getPrimaryTerm(), equalTo(1L));
 |  |          assertThat(indexResponse.getPrimaryTerm(), equalTo(1L));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -        assertThrows(
 |  | 
 | 
											
												
													
														|  | 
 |  | +        assertFutureThrows(
 | 
											
												
													
														|  |              client().prepareIndex("test").setId("1").setSource("field1", "value1_1").setIfSeqNo(10).setIfPrimaryTerm(1).execute(),
 |  |              client().prepareIndex("test").setId("1").setSource("field1", "value1_1").setIfSeqNo(10).setIfPrimaryTerm(1).execute(),
 | 
											
												
													
														|  |              VersionConflictEngineException.class);
 |  |              VersionConflictEngineException.class);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -        assertThrows(
 |  | 
 | 
											
												
													
														|  | 
 |  | +        assertFutureThrows(
 | 
											
												
													
														|  |              client().prepareIndex("test").setId("1").setSource("field1", "value1_1").setIfSeqNo(10).setIfPrimaryTerm(2).execute(),
 |  |              client().prepareIndex("test").setId("1").setSource("field1", "value1_1").setIfSeqNo(10).setIfPrimaryTerm(2).execute(),
 | 
											
												
													
														|  |              VersionConflictEngineException.class);
 |  |              VersionConflictEngineException.class);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -        assertThrows(
 |  | 
 | 
											
												
													
														|  | 
 |  | +        assertFutureThrows(
 | 
											
												
													
														|  |              client().prepareIndex("test").setId("1").setSource("field1", "value1_1").setIfSeqNo(1).setIfPrimaryTerm(2).execute(),
 |  |              client().prepareIndex("test").setId("1").setSource("field1", "value1_1").setIfSeqNo(1).setIfPrimaryTerm(2).execute(),
 | 
											
												
													
														|  |              VersionConflictEngineException.class);
 |  |              VersionConflictEngineException.class);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -        assertThrows(client().prepareDelete("test", "1").setIfSeqNo(10).setIfPrimaryTerm(1), VersionConflictEngineException.class);
 |  | 
 | 
											
												
													
														|  | -        assertThrows(client().prepareDelete("test", "1").setIfSeqNo(10).setIfPrimaryTerm(2), VersionConflictEngineException.class);
 |  | 
 | 
											
												
													
														|  | -        assertThrows(client().prepareDelete("test", "1").setIfSeqNo(1).setIfPrimaryTerm(2), VersionConflictEngineException.class);
 |  | 
 | 
											
												
													
														|  | 
 |  | +        assertRequestBuilderThrows(
 | 
											
												
													
														|  | 
 |  | +            client().prepareDelete("test", "1").setIfSeqNo(10).setIfPrimaryTerm(1), VersionConflictEngineException.class);
 | 
											
												
													
														|  | 
 |  | +        assertRequestBuilderThrows(
 | 
											
												
													
														|  | 
 |  | +            client().prepareDelete("test", "1").setIfSeqNo(10).setIfPrimaryTerm(2), VersionConflictEngineException.class);
 | 
											
												
													
														|  | 
 |  | +        assertRequestBuilderThrows(
 | 
											
												
													
														|  | 
 |  | +            client().prepareDelete("test", "1").setIfSeqNo(1).setIfPrimaryTerm(2), VersionConflictEngineException.class);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          client().admin().indices().prepareRefresh().execute().actionGet();
 |  |          client().admin().indices().prepareRefresh().execute().actionGet();
 | 
											
												
													
														|  |          for (int i = 0; i < 10; i++) {
 |  |          for (int i = 0; i < 10; i++) {
 | 
											
										
											
												
													
														|  | @@ -279,12 +283,16 @@ public class SimpleVersioningIT extends ESIntegTestCase {
 | 
											
												
													
														|  |          assertThat(deleteResponse.getSeqNo(), equalTo(2L));
 |  |          assertThat(deleteResponse.getSeqNo(), equalTo(2L));
 | 
											
												
													
														|  |          assertThat(deleteResponse.getPrimaryTerm(), equalTo(1L));
 |  |          assertThat(deleteResponse.getPrimaryTerm(), equalTo(1L));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -        assertThrows(client().prepareDelete("test", "1").setIfSeqNo(1).setIfPrimaryTerm(1), VersionConflictEngineException.class);
 |  | 
 | 
											
												
													
														|  | -        assertThrows(client().prepareDelete("test", "1").setIfSeqNo(3).setIfPrimaryTerm(12), VersionConflictEngineException.class);
 |  | 
 | 
											
												
													
														|  | -        assertThrows(client().prepareDelete("test", "1").setIfSeqNo(1).setIfPrimaryTerm(2), VersionConflictEngineException.class);
 |  | 
 | 
											
												
													
														|  | 
 |  | +        assertRequestBuilderThrows(
 | 
											
												
													
														|  | 
 |  | +            client().prepareDelete("test", "1").setIfSeqNo(1).setIfPrimaryTerm(1), VersionConflictEngineException.class);
 | 
											
												
													
														|  | 
 |  | +        assertRequestBuilderThrows(
 | 
											
												
													
														|  | 
 |  | +            client().prepareDelete("test", "1").setIfSeqNo(3).setIfPrimaryTerm(12), VersionConflictEngineException.class);
 | 
											
												
													
														|  | 
 |  | +        assertRequestBuilderThrows(
 | 
											
												
													
														|  | 
 |  | +            client().prepareDelete("test", "1").setIfSeqNo(1).setIfPrimaryTerm(2), VersionConflictEngineException.class);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          // the doc is deleted. Even when we hit the deleted seqNo, a conditional delete should fail.
 |  |          // the doc is deleted. Even when we hit the deleted seqNo, a conditional delete should fail.
 | 
											
												
													
														|  | -        assertThrows(client().prepareDelete("test", "1").setIfSeqNo(2).setIfPrimaryTerm(1), VersionConflictEngineException.class);
 |  | 
 | 
											
												
													
														|  | 
 |  | +        assertRequestBuilderThrows(
 | 
											
												
													
														|  | 
 |  | +            client().prepareDelete("test", "1").setIfSeqNo(2).setIfPrimaryTerm(1), VersionConflictEngineException.class);
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      public void testSimpleVersioningWithFlush() throws Exception {
 |  |      public void testSimpleVersioningWithFlush() throws Exception {
 | 
											
										
											
												
													
														|  | @@ -299,13 +307,15 @@ public class SimpleVersioningIT extends ESIntegTestCase {
 | 
											
												
													
														|  |          assertThat(indexResponse.getSeqNo(), equalTo(1L));
 |  |          assertThat(indexResponse.getSeqNo(), equalTo(1L));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          client().admin().indices().prepareFlush().execute().actionGet();
 |  |          client().admin().indices().prepareFlush().execute().actionGet();
 | 
											
												
													
														|  | -        assertThrows(client().prepareIndex("test").setId("1").setSource("field1", "value1_1").setIfSeqNo(0).setIfPrimaryTerm(1),
 |  | 
 | 
											
												
													
														|  | 
 |  | +        assertRequestBuilderThrows(
 | 
											
												
													
														|  | 
 |  | +            client().prepareIndex("test").setId("1").setSource("field1", "value1_1").setIfSeqNo(0).setIfPrimaryTerm(1),
 | 
											
												
													
														|  |                  VersionConflictEngineException.class);
 |  |                  VersionConflictEngineException.class);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -        assertThrows(client().prepareIndex("test").setId("1").setCreate(true).setSource("field1", "value1_1"),
 |  | 
 | 
											
												
													
														|  | 
 |  | +        assertRequestBuilderThrows(client().prepareIndex("test").setId("1").setCreate(true).setSource("field1", "value1_1"),
 | 
											
												
													
														|  |                  VersionConflictEngineException.class);
 |  |                  VersionConflictEngineException.class);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -        assertThrows(client().prepareDelete("test", "1").setIfSeqNo(0).setIfPrimaryTerm(1), VersionConflictEngineException.class);
 |  | 
 | 
											
												
													
														|  | 
 |  | +        assertRequestBuilderThrows(
 | 
											
												
													
														|  | 
 |  | +            client().prepareDelete("test", "1").setIfSeqNo(0).setIfPrimaryTerm(1), VersionConflictEngineException.class);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          for (int i = 0; i < 10; i++) {
 |  |          for (int i = 0; i < 10; i++) {
 | 
											
												
													
														|  |              assertThat(client().prepareGet("test", "1").execute().actionGet().getVersion(), equalTo(2L));
 |  |              assertThat(client().prepareGet("test", "1").execute().actionGet().getVersion(), equalTo(2L));
 |