Randomly run CCR tests with _source disabled (#49922)
Makes sure that CCR also properly works with _source disabled. Changes one exception in LuceneChangesSnapshot as the case of missing _recovery_source because of a missing lease was not properly properly bubbled up to CCR (testIndexFallBehind was failing).
This commit is contained in:
parent
f768f8ddab
commit
01d36afa4b
|
@ -256,7 +256,7 @@ final class LuceneChangesSnapshot implements Translog.Snapshot {
|
||||||
// TODO: Callers should ask for the range that source should be retained. Thus we should always
|
// TODO: Callers should ask for the range that source should be retained. Thus we should always
|
||||||
// check for the existence source once we make peer-recovery to send ops after the local checkpoint.
|
// check for the existence source once we make peer-recovery to send ops after the local checkpoint.
|
||||||
if (requiredFullRange) {
|
if (requiredFullRange) {
|
||||||
throw new IllegalStateException("source not found for seqno=" + seqNo +
|
throw new MissingHistoryOperationsException("source not found for seqno=" + seqNo +
|
||||||
" from_seqno=" + fromSeqNo + " to_seqno=" + toSeqNo);
|
" from_seqno=" + fromSeqNo + " to_seqno=" + toSeqNo);
|
||||||
} else {
|
} else {
|
||||||
skippedOperations++;
|
skippedOperations++;
|
||||||
|
|
|
@ -415,6 +415,14 @@ public abstract class CcrIntegTestCase extends ESTestCase {
|
||||||
}, 30, TimeUnit.SECONDS);
|
}, 30, TimeUnit.SECONDS);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setupSourceEnabledOrDisabled() {
|
||||||
|
sourceEnabled = randomBoolean();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected boolean sourceEnabled;
|
||||||
|
|
||||||
protected String getIndexSettings(final int numberOfShards, final int numberOfReplicas,
|
protected String getIndexSettings(final int numberOfShards, final int numberOfReplicas,
|
||||||
final Map<String, String> additionalIndexSettings) throws IOException {
|
final Map<String, String> additionalIndexSettings) throws IOException {
|
||||||
final String settings;
|
final String settings;
|
||||||
|
@ -445,6 +453,11 @@ public abstract class CcrIntegTestCase extends ESTestCase {
|
||||||
builder.endObject();
|
builder.endObject();
|
||||||
}
|
}
|
||||||
builder.endObject();
|
builder.endObject();
|
||||||
|
if (sourceEnabled == false) {
|
||||||
|
builder.startObject("_source");
|
||||||
|
builder.field("enabled", false);
|
||||||
|
builder.endObject();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
builder.endObject();
|
builder.endObject();
|
||||||
}
|
}
|
||||||
|
|
|
@ -447,8 +447,10 @@ public class CcrRepositoryIT extends CcrIntegTestCase {
|
||||||
private void assertExpectedDocument(String followerIndex, final int value) {
|
private void assertExpectedDocument(String followerIndex, final int value) {
|
||||||
final GetResponse getResponse = followerClient().prepareGet(followerIndex, "doc", Integer.toString(value)).get();
|
final GetResponse getResponse = followerClient().prepareGet(followerIndex, "doc", Integer.toString(value)).get();
|
||||||
assertTrue("Doc with id [" + value + "] is missing", getResponse.isExists());
|
assertTrue("Doc with id [" + value + "] is missing", getResponse.isExists());
|
||||||
|
if (sourceEnabled) {
|
||||||
assertTrue((getResponse.getSource().containsKey("f")));
|
assertTrue((getResponse.getSource().containsKey("f")));
|
||||||
assertThat(getResponse.getSource().get("f"), equalTo(value));
|
assertThat(getResponse.getSource().get("f"), equalTo(value));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1075,8 +1075,10 @@ public class CcrRetentionLeaseIT extends CcrIntegTestCase {
|
||||||
private void assertExpectedDocument(final String followerIndex, final int value) {
|
private void assertExpectedDocument(final String followerIndex, final int value) {
|
||||||
final GetResponse getResponse = followerClient().prepareGet(followerIndex, "doc", Integer.toString(value)).get();
|
final GetResponse getResponse = followerClient().prepareGet(followerIndex, "doc", Integer.toString(value)).get();
|
||||||
assertTrue("doc with id [" + value + "] is missing", getResponse.isExists());
|
assertTrue("doc with id [" + value + "] is missing", getResponse.isExists());
|
||||||
|
if (sourceEnabled) {
|
||||||
assertTrue((getResponse.getSource().containsKey("f")));
|
assertTrue((getResponse.getSource().containsKey("f")));
|
||||||
assertThat(getResponse.getSource().get("f"), equalTo(value));
|
assertThat(getResponse.getSource().get("f"), equalTo(value));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1523,8 +1523,10 @@ public class IndexFollowingIT extends CcrIntegTestCase {
|
||||||
return () -> {
|
return () -> {
|
||||||
final GetResponse getResponse = followerClient().prepareGet("index2", "doc", Integer.toString(key)).get();
|
final GetResponse getResponse = followerClient().prepareGet("index2", "doc", Integer.toString(key)).get();
|
||||||
assertTrue("Doc with id [" + key + "] is missing", getResponse.isExists());
|
assertTrue("Doc with id [" + key + "] is missing", getResponse.isExists());
|
||||||
|
if (sourceEnabled) {
|
||||||
assertTrue((getResponse.getSource().containsKey("f")));
|
assertTrue((getResponse.getSource().containsKey("f")));
|
||||||
assertThat(getResponse.getSource().get("f"), equalTo(value));
|
assertThat(getResponse.getSource().get("f"), equalTo(value));
|
||||||
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue