aboutsummaryrefslogtreecommitdiff
path: root/test/transform
diff options
context:
space:
mode:
authorRoel Spilker <Roels@topdesk.com>2019-07-08 22:00:03 +0200
committerRoel Spilker <Roels@topdesk.com>2019-07-08 23:17:38 +0200
commit2ccd3f5f5d089f5525f6b219df35a1200596f0a8 (patch)
tree76f11afe3648b22520a65a115058dd7fd4fe61fe /test/transform
parent11065b564f3fc1cee2c540a33b7ed1b3774816e2 (diff)
downloadlombok-2ccd3f5f5d089f5525f6b219df35a1200596f0a8.tar.gz
lombok-2ccd3f5f5d089f5525f6b219df35a1200596f0a8.tar.bz2
lombok-2ccd3f5f5d089f5525f6b219df35a1200596f0a8.zip
Fixes #2165: Generated equals fails on annotated array type
Diffstat (limited to 'test/transform')
-rw-r--r--test/transform/resource/after-delombok/EqualsAndHashCodeAnnotated.java51
-rw-r--r--test/transform/resource/before/EqualsAndHashCodeAnnotated.java19
2 files changed, 70 insertions, 0 deletions
diff --git a/test/transform/resource/after-delombok/EqualsAndHashCodeAnnotated.java b/test/transform/resource/after-delombok/EqualsAndHashCodeAnnotated.java
new file mode 100644
index 00000000..64b6f4d3
--- /dev/null
+++ b/test/transform/resource/after-delombok/EqualsAndHashCodeAnnotated.java
@@ -0,0 +1,51 @@
+import java.lang.annotation.*;
+
+class EqualsAndHashCodeAnnotated {
+ @Annotated
+ int primitive;
+ @Annotated
+ Object object;
+ int @Annotated [] primitiveValues;
+ int @Annotated [] @Annotated [] morePrimitiveValues;
+ Integer @Annotated [] objectValues;
+ Integer @Annotated [] @Annotated [] moreObjectValues;
+ @Target(ElementType.TYPE_USE)
+ @Retention(RetentionPolicy.SOURCE)
+ @interface Annotated {
+ }
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ public boolean equals(final java.lang.Object o) {
+ if (o == this) return true;
+ if (!(o instanceof EqualsAndHashCodeAnnotated)) return false;
+ final EqualsAndHashCodeAnnotated other = (EqualsAndHashCodeAnnotated) o;
+ if (!other.canEqual((java.lang.Object) this)) return false;
+ if (this.primitive != other.primitive) return false;
+ final java.lang.Object this$object = this.object;
+ final java.lang.Object other$object = other.object;
+ if (this$object == null ? other$object != null : !this$object.equals(other$object)) return false;
+ if (!java.util.Arrays.equals(this.primitiveValues, other.primitiveValues)) return false;
+ if (!java.util.Arrays.deepEquals(this.morePrimitiveValues, other.morePrimitiveValues)) return false;
+ if (!java.util.Arrays.deepEquals(this.objectValues, other.objectValues)) return false;
+ if (!java.util.Arrays.deepEquals(this.moreObjectValues, other.moreObjectValues)) return false;
+ return true;
+ }
+ @java.lang.SuppressWarnings("all")
+ protected boolean canEqual(final java.lang.Object other) {
+ return other instanceof EqualsAndHashCodeAnnotated;
+ }
+ @java.lang.Override
+ @java.lang.SuppressWarnings("all")
+ public int hashCode() {
+ final int PRIME = 59;
+ int result = 1;
+ result = result * PRIME + this.primitive;
+ final java.lang.Object $object = this.object;
+ result = result * PRIME + ($object == null ? 43 : $object.hashCode());
+ result = result * PRIME + java.util.Arrays.hashCode(this.primitiveValues);
+ result = result * PRIME + java.util.Arrays.deepHashCode(this.morePrimitiveValues);
+ result = result * PRIME + java.util.Arrays.deepHashCode(this.objectValues);
+ result = result * PRIME + java.util.Arrays.deepHashCode(this.moreObjectValues);
+ return result;
+ }
+} \ No newline at end of file
diff --git a/test/transform/resource/before/EqualsAndHashCodeAnnotated.java b/test/transform/resource/before/EqualsAndHashCodeAnnotated.java
new file mode 100644
index 00000000..d672b982
--- /dev/null
+++ b/test/transform/resource/before/EqualsAndHashCodeAnnotated.java
@@ -0,0 +1,19 @@
+//version 8
+import java.lang.annotation.*;
+
+@lombok.EqualsAndHashCode
+class EqualsAndHashCodeAnnotated {
+ @Annotated int primitive;
+ @Annotated Object object;
+
+ int @Annotated [] primitiveValues;
+ int @Annotated [] @Annotated [] morePrimitiveValues;
+
+ Integer @Annotated [] objectValues;
+ Integer @Annotated [] @Annotated [] moreObjectValues;
+
+ @Target(ElementType.TYPE_USE)
+ @Retention(RetentionPolicy.SOURCE)
+ @interface Annotated {
+ }
+}