From 3facf303bf6946a01e9584ac21b0478d60b9e69d Mon Sep 17 00:00:00 2001 From: chenylee-aws <122478603+chenylee-aws@users.noreply.github.com> Date: Thu, 14 Nov 2024 14:50:22 -0700 Subject: [PATCH] Fix checkpointOwner copy issue for multistream lease (#1401) --- .../software/amazon/kinesis/leases/Lease.java | 5 ++--- .../amazon/kinesis/leases/LeaseTest.java | 10 ++++++++++ .../kinesis/leases/MultiStreamLeaseTest.java | 19 +++++++++++++++++++ 3 files changed, 31 insertions(+), 3 deletions(-) create mode 100644 amazon-kinesis-client/src/test/java/software/amazon/kinesis/leases/MultiStreamLeaseTest.java diff --git a/amazon-kinesis-client/src/main/java/software/amazon/kinesis/leases/Lease.java b/amazon-kinesis-client/src/main/java/software/amazon/kinesis/leases/Lease.java index 9d44a7554..2f4c5f36a 100644 --- a/amazon-kinesis-client/src/main/java/software/amazon/kinesis/leases/Lease.java +++ b/amazon-kinesis-client/src/main/java/software/amazon/kinesis/leases/Lease.java @@ -163,6 +163,7 @@ protected Lease(Lease lease) { lease.childShardIds(), lease.pendingCheckpointState(), lease.hashKeyRangeForLease()); + checkpointOwner(lease.checkpointOwner); } @Deprecated @@ -458,8 +459,6 @@ public void leaseOwner(String leaseOwner) { * @return A deep copy of this object. */ public Lease copy() { - final Lease lease = new Lease(this); - lease.checkpointOwner(this.checkpointOwner); - return lease; + return new Lease(this); } } diff --git a/amazon-kinesis-client/src/test/java/software/amazon/kinesis/leases/LeaseTest.java b/amazon-kinesis-client/src/test/java/software/amazon/kinesis/leases/LeaseTest.java index c4d076801..c70476fc7 100644 --- a/amazon-kinesis-client/src/test/java/software/amazon/kinesis/leases/LeaseTest.java +++ b/amazon-kinesis-client/src/test/java/software/amazon/kinesis/leases/LeaseTest.java @@ -10,6 +10,7 @@ import org.mockito.runners.MockitoJUnitRunner; import software.amazon.kinesis.retrieval.kpl.ExtendedSequenceNumber; +import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertTrue; @@ -109,6 +110,15 @@ public void testIsEligibleForGracefulShutdownFalse_shutdownRequested_assertFalse assertFalse(shutdownRequestedLease.isEligibleForGracefulShutdown()); } + @Test + public void testCopyingLease() { + final String checkpointOwner = "checkpointOwner"; + final Lease original = new Lease(); + original.checkpointOwner(checkpointOwner); + final Lease copy = original.copy(); + assertEquals(checkpointOwner, copy.checkpointOwner()); + } + private static Lease createLease(String leaseOwner, String leaseKey, long lastCounterIncrementNanos) { final Lease lease = new Lease(); lease.checkpoint(new ExtendedSequenceNumber("checkpoint")); diff --git a/amazon-kinesis-client/src/test/java/software/amazon/kinesis/leases/MultiStreamLeaseTest.java b/amazon-kinesis-client/src/test/java/software/amazon/kinesis/leases/MultiStreamLeaseTest.java new file mode 100644 index 000000000..0538817af --- /dev/null +++ b/amazon-kinesis-client/src/test/java/software/amazon/kinesis/leases/MultiStreamLeaseTest.java @@ -0,0 +1,19 @@ +package software.amazon.kinesis.leases; + +import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; + +class MultiStreamLeaseTest { + + @Test + void testCopyingMultiStreamLease() { + final String checkpointOwner = "checkpointOwner"; + final MultiStreamLease original = new MultiStreamLease(); + original.checkpointOwner(checkpointOwner); + original.streamIdentifier("identifier"); + original.shardId("shardId"); + final MultiStreamLease copy = original.copy(); + assertEquals(checkpointOwner, copy.checkpointOwner()); + } +}