Remove "force" version type (#47228)

It's been deprecated long ago and can be removed.

Relates to #20377

Closes #19769
This commit is contained in:
Yannick Welsch 2019-09-30 11:58:11 +02:00
parent b270f70be1
commit 9dc90e41fc
8 changed files with 4 additions and 71 deletions

View File

@ -191,8 +191,6 @@ final class RequestConverters {
metadata.field("version_type", "external"); metadata.field("version_type", "external");
} else if (versionType == VersionType.EXTERNAL_GTE) { } else if (versionType == VersionType.EXTERNAL_GTE) {
metadata.field("version_type", "external_gte"); metadata.field("version_type", "external_gte");
} else if (versionType == VersionType.FORCE) {
metadata.field("version_type", "force");
} }
} }

View File

@ -131,9 +131,7 @@ better GET scaling we will have.
===== Versioning support ===== Versioning support
You can use the `version` parameter to retrieve the document only if You can use the `version` parameter to retrieve the document only if
its current version is equal to the specified one. This behavior is the same its current version is equal to the specified one.
for all version types with the exception of version type `FORCE` which always
retrieves the document. Note that `FORCE` version type is deprecated.
Internally, Elasticsearch has marked the old document as deleted and added an Internally, Elasticsearch has marked the old document as deleted and added an
entirely new document. The old version of the document doesnt disappear entirely new document. The old version of the document doesnt disappear

View File

@ -72,8 +72,7 @@ public interface DocWriteRequest<T> extends IndicesRequest {
* @return the Request * @return the Request
*/ */
T defaultTypeIfNull(String defaultType); T defaultTypeIfNull(String defaultType);
/** /**
* Get the id of the document for this request * Get the id of the document for this request
* @return the id * @return the id
@ -257,9 +256,6 @@ public interface DocWriteRequest<T> extends IndicesRequest {
validationException = addValidationError("illegal version value [" + version + "] for version type [" validationException = addValidationError("illegal version value [" + version + "] for version type ["
+ versionType.name() + "]", validationException); + versionType.name() + "]", validationException);
} }
if (versionType == VersionType.FORCE) {
validationException = addValidationError("version type [force] may no longer be used", validationException);
}
if (versionType == VersionType.INTERNAL && version != Versions.MATCH_ANY && version != Versions.MATCH_DELETED) { if (versionType == VersionType.INTERNAL && version != Versions.MATCH_ANY && version != Versions.MATCH_DELETED) {
validationException = addValidationError("internal versioning can not be used for optimistic concurrency control. " + validationException = addValidationError("internal versioning can not be used for optimistic concurrency control. " +

View File

@ -136,9 +136,6 @@ public class GetRequest extends SingleShardRequest<GetRequest> implements Realti
validationException = ValidateActions.addValidationError("illegal version value [" + version + "] for version type [" validationException = ValidateActions.addValidationError("illegal version value [" + version + "] for version type ["
+ versionType.name() + "]", validationException); + versionType.name() + "]", validationException);
} }
if (versionType == VersionType.FORCE) {
validationException = ValidateActions.addValidationError("version type [force] may no longer be used", validationException);
}
return validationException; return validationException;
} }

View File

@ -201,55 +201,6 @@ public enum VersionType implements Writeable {
return version >= 0L || version == Versions.MATCH_ANY; return version >= 0L || version == Versions.MATCH_ANY;
} }
},
/**
* Warning: this version type should be used with care. Concurrent indexing may result in loss of data on replicas
*
* @deprecated this will be removed in 7.0 and should not be used! It is *ONLY* for backward compatibility with 5.0 indices
*/
@Deprecated
FORCE((byte) 3) {
@Override
public boolean isVersionConflictForWrites(long currentVersion, long expectedVersion, boolean deleted) {
if (currentVersion == Versions.NOT_FOUND) {
return false;
}
if (expectedVersion == Versions.MATCH_ANY) {
throw new IllegalStateException("you must specify a version when use VersionType.FORCE");
}
return false;
}
@Override
public String explainConflictForWrites(long currentVersion, long expectedVersion, boolean deleted) {
throw new AssertionError("VersionType.FORCE should never result in a write conflict");
}
@Override
public boolean isVersionConflictForReads(long currentVersion, long expectedVersion) {
return false;
}
@Override
public String explainConflictForReads(long currentVersion, long expectedVersion) {
throw new AssertionError("VersionType.FORCE should never result in a read conflict");
}
@Override
public long updateVersion(long currentVersion, long expectedVersion) {
return expectedVersion;
}
@Override
public boolean validateVersionForWrites(long version) {
return version >= 0L;
}
@Override
public boolean validateVersionForReads(long version) {
return version >= 0L || version == Versions.MATCH_ANY;
}
}; };
private final byte value; private final byte value;
@ -335,8 +286,6 @@ public enum VersionType implements Writeable {
return EXTERNAL; return EXTERNAL;
} else if ("external_gte".equals(versionType)) { } else if ("external_gte".equals(versionType)) {
return EXTERNAL_GTE; return EXTERNAL_GTE;
} else if ("force".equals(versionType)) {
return FORCE;
} }
throw new IllegalArgumentException("No version type match [" + versionType + "]"); throw new IllegalArgumentException("No version type match [" + versionType + "]");
} }
@ -359,8 +308,6 @@ public enum VersionType implements Writeable {
return EXTERNAL; return EXTERNAL;
} else if (value == 2) { } else if (value == 2) {
return EXTERNAL_GTE; return EXTERNAL_GTE;
} else if (value == 3) {
return FORCE;
} }
throw new IllegalArgumentException("No version type match [" + value + "]"); throw new IllegalArgumentException("No version type match [" + value + "]");
} }

View File

@ -1805,7 +1805,7 @@ public class InternalEngineTests extends EngineTestCase {
public void testOutOfOrderDocsOnReplica() throws IOException { public void testOutOfOrderDocsOnReplica() throws IOException {
final List<Engine.Operation> ops = generateSingleDocHistory(true, final List<Engine.Operation> ops = generateSingleDocHistory(true,
randomFrom(VersionType.INTERNAL, VersionType.EXTERNAL, VersionType.EXTERNAL_GTE, VersionType.FORCE), randomFrom(VersionType.INTERNAL, VersionType.EXTERNAL, VersionType.EXTERNAL_GTE),
2, 2, 20, "1"); 2, 2, 20, "1");
assertOpsOnReplica(ops, replicaEngine, true, logger); assertOpsOnReplica(ops, replicaEngine, true, logger);
} }

View File

@ -804,9 +804,6 @@ public abstract class EngineTestCase extends ESTestCase {
case EXTERNAL_GTE: case EXTERNAL_GTE:
version = randomBoolean() ? Math.max(i - 1, 0) : i; version = randomBoolean() ? Math.max(i - 1, 0) : i;
break; break;
case FORCE:
version = randomNonNegativeLong();
break;
default: default:
throw new UnsupportedOperationException("unknown version type: " + versionType); throw new UnsupportedOperationException("unknown version type: " + versionType);
} }

View File

@ -139,7 +139,7 @@ public class FollowingEngineTests extends ESTestCase {
final EngineConfig engineConfig = engineConfig(shardId, indexSettings, threadPool, store, logger, xContentRegistry()); final EngineConfig engineConfig = engineConfig(shardId, indexSettings, threadPool, store, logger, xContentRegistry());
try (FollowingEngine followingEngine = createEngine(store, engineConfig)) { try (FollowingEngine followingEngine = createEngine(store, engineConfig)) {
final VersionType versionType = final VersionType versionType =
randomFrom(VersionType.INTERNAL, VersionType.EXTERNAL, VersionType.EXTERNAL_GTE, VersionType.FORCE); randomFrom(VersionType.INTERNAL, VersionType.EXTERNAL, VersionType.EXTERNAL_GTE);
final List<Engine.Operation> ops = EngineTestCase.generateSingleDocHistory(true, versionType, 2, 2, 20, "id"); final List<Engine.Operation> ops = EngineTestCase.generateSingleDocHistory(true, versionType, 2, 2, 20, "id");
ops.stream().mapToLong(op -> op.seqNo()).max().ifPresent(followingEngine::advanceMaxSeqNoOfUpdatesOrDeletes); ops.stream().mapToLong(op -> op.seqNo()).max().ifPresent(followingEngine::advanceMaxSeqNoOfUpdatesOrDeletes);
EngineTestCase.assertOpsOnReplica(ops, followingEngine, true, logger); EngineTestCase.assertOpsOnReplica(ops, followingEngine, true, logger);