diff --git a/conjure-java-core/src/integrationInput/java/com/palantir/insensitive/InsensitiveEnum.java b/conjure-java-core/src/integrationInput/java/com/palantir/insensitive/InsensitiveEnum.java index 34c087da5..44e40d602 100644 --- a/conjure-java-core/src/integrationInput/java/com/palantir/insensitive/InsensitiveEnum.java +++ b/conjure-java-core/src/integrationInput/java/com/palantir/insensitive/InsensitiveEnum.java @@ -2,7 +2,6 @@ import com.fasterxml.jackson.annotation.JsonCreator; import com.fasterxml.jackson.annotation.JsonValue; -import com.palantir.conjure.java.lib.internal.ConjureEnums; import com.palantir.logsafe.Preconditions; import java.util.Locale; import javax.annotation.Generated; @@ -75,7 +74,6 @@ public static InsensitiveEnum valueOf(String value) { case "ONE_HUNDRED": return ONE_HUNDRED; default: - ConjureEnums.validate(value); return new InsensitiveEnum(Value.UNKNOWN, value); } } diff --git a/conjure-java-core/src/main/java/com/palantir/conjure/java/types/EnumGenerator.java b/conjure-java-core/src/main/java/com/palantir/conjure/java/types/EnumGenerator.java index 965439285..ddfea145f 100644 --- a/conjure-java-core/src/main/java/com/palantir/conjure/java/types/EnumGenerator.java +++ b/conjure-java-core/src/main/java/com/palantir/conjure/java/types/EnumGenerator.java @@ -224,11 +224,12 @@ private static MethodSpec createValueOf( .addStatement("return $L", value.getValue()) .unindent(); } - parser.add("default:\n") - .indent() - // Only validate unknown values, matches are validated at build time. - .addStatement("$T.validate($N)", ConjureEnums.class, param) - .addStatement("return new $T(Value.UNKNOWN, $N)", thisClass, param) + parser.add("default:\n").indent(); + if (!featureFlags.contains(FeatureFlags.CaseInsensitiveEnums)) { + // Only validate unknown values, matches are validated at build time. + parser.addStatement("$T.validate($N)", ConjureEnums.class, param); + } + parser.addStatement("return new $T(Value.UNKNOWN, $N)", thisClass, param) .unindent() .endControlFlow(); diff --git a/conjure-java-core/src/test/java/com/palantir/conjure/java/types/EnumTests.java b/conjure-java-core/src/test/java/com/palantir/conjure/java/types/EnumTests.java index a4268d4c3..e3a906afc 100644 --- a/conjure-java-core/src/test/java/com/palantir/conjure/java/types/EnumTests.java +++ b/conjure-java-core/src/test/java/com/palantir/conjure/java/types/EnumTests.java @@ -60,6 +60,18 @@ public void testInsensitiveEnum_lowerCaseUnknown() { assertThat(value.get()).isEqualTo(InsensitiveEnum.Value.UNKNOWN); } + @Test + public void testInsensitiveEnum_unknownToleratesEmptyStringsForHistoricalReasons() { + InsensitiveEnum value = InsensitiveEnum.valueOf(""); + assertThat(value.get()).isEqualTo(InsensitiveEnum.Value.UNKNOWN); + } + + @Test + public void testInsensitiveEnum_unknownToleratesStrangeCharactersForHistoricalReasons() { + InsensitiveEnum value = InsensitiveEnum.valueOf("!@£$%^&*()"); + assertThat(value.get()).isEqualTo(InsensitiveEnum.Value.UNKNOWN); + } + @Test public void testNullValidationUsesSafeLoggable() { assertThatLoggableExceptionThrownBy(() -> EnumExample.valueOf(null)).hasLogMessage("value cannot be null");