Skip to content

Commit 6d07389

Browse files
authored
adds class check for discarded values (#1091)
1 parent 308e4c3 commit 6d07389

File tree

4 files changed

+70
-12
lines changed

4 files changed

+70
-12
lines changed

rsocket-core/src/main/java/io/rsocket/core/DefaultRSocketClient.java

+10-7
Original file line numberDiff line numberDiff line change
@@ -46,13 +46,16 @@
4646
*/
4747
class DefaultRSocketClient extends ResolvingOperator<RSocket>
4848
implements CoreSubscriber<RSocket>, CorePublisher<RSocket>, RSocketClient {
49-
static final Consumer<ReferenceCounted> DISCARD_ELEMENTS_CONSUMER =
50-
referenceCounted -> {
51-
if (referenceCounted.refCnt() > 0) {
52-
try {
53-
referenceCounted.release();
54-
} catch (IllegalReferenceCountException e) {
55-
// ignored
49+
static final Consumer<?> DISCARD_ELEMENTS_CONSUMER =
50+
data -> {
51+
if (data instanceof ReferenceCounted) {
52+
ReferenceCounted referenceCounted = ((ReferenceCounted) data);
53+
if (referenceCounted.refCnt() > 0) {
54+
try {
55+
referenceCounted.release();
56+
} catch (IllegalReferenceCountException e) {
57+
// ignored
58+
}
5659
}
5760
}
5861
};

rsocket-core/src/main/java/io/rsocket/core/SendUtils.java

+7-5
Original file line numberDiff line numberDiff line change
@@ -40,11 +40,13 @@
4040
final class SendUtils {
4141
private static final Consumer<?> DROPPED_ELEMENTS_CONSUMER =
4242
data -> {
43-
try {
44-
ReferenceCounted referenceCounted = (ReferenceCounted) data;
45-
referenceCounted.release();
46-
} catch (Throwable e) {
47-
// ignored
43+
if (data instanceof ReferenceCounted) {
44+
try {
45+
ReferenceCounted referenceCounted = (ReferenceCounted) data;
46+
referenceCounted.release();
47+
} catch (Throwable e) {
48+
// ignored
49+
}
4850
}
4951
};
5052

rsocket-core/src/test/java/io/rsocket/core/DefaultRSocketClientTests.java

+22
Original file line numberDiff line numberDiff line change
@@ -39,6 +39,7 @@
3939
import java.util.concurrent.CancellationException;
4040
import java.util.concurrent.atomic.AtomicBoolean;
4141
import java.util.function.BiFunction;
42+
import java.util.function.Consumer;
4243
import java.util.stream.Collectors;
4344
import java.util.stream.Stream;
4445
import org.assertj.core.api.Assertions;
@@ -49,6 +50,7 @@
4950
import org.junit.jupiter.params.ParameterizedTest;
5051
import org.junit.jupiter.params.provider.Arguments;
5152
import org.junit.jupiter.params.provider.MethodSource;
53+
import org.mockito.Mockito;
5254
import org.reactivestreams.Publisher;
5355
import reactor.core.Disposable;
5456
import reactor.core.publisher.Flux;
@@ -79,6 +81,26 @@ public void setUp() throws Throwable {
7981
public void tearDown() {
8082
Hooks.resetOnErrorDropped();
8183
Hooks.resetOnNextDropped();
84+
rule.allocator.assertHasNoLeaks();
85+
}
86+
87+
@Test
88+
@SuppressWarnings("unchecked")
89+
void discardElementsConsumerShouldAcceptOtherTypesThanReferenceCounted() {
90+
Consumer discardElementsConsumer = DefaultRSocketClient.DISCARD_ELEMENTS_CONSUMER;
91+
discardElementsConsumer.accept(new Object());
92+
}
93+
94+
@Test
95+
void droppedElementsConsumerReleaseReference() {
96+
ReferenceCounted referenceCounted = Mockito.mock(ReferenceCounted.class);
97+
Mockito.when(referenceCounted.release()).thenReturn(true);
98+
Mockito.when(referenceCounted.refCnt()).thenReturn(1);
99+
100+
Consumer discardElementsConsumer = DefaultRSocketClient.DISCARD_ELEMENTS_CONSUMER;
101+
discardElementsConsumer.accept(referenceCounted);
102+
103+
Mockito.verify(referenceCounted).release();
82104
}
83105

84106
static Stream<Arguments> interactions() {
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,31 @@
1+
package io.rsocket.core;
2+
3+
import static org.mockito.Mockito.*;
4+
5+
import io.netty.util.ReferenceCounted;
6+
import java.util.function.Consumer;
7+
import org.junit.jupiter.api.Test;
8+
9+
public class SendUtilsTest {
10+
11+
@Test
12+
void droppedElementsConsumerShouldAcceptOtherTypesThanReferenceCounted() {
13+
Consumer value = extractDroppedElementConsumer();
14+
value.accept(new Object());
15+
}
16+
17+
@Test
18+
void droppedElementsConsumerReleaseReference() {
19+
ReferenceCounted referenceCounted = mock(ReferenceCounted.class);
20+
when(referenceCounted.release()).thenReturn(true);
21+
22+
Consumer value = extractDroppedElementConsumer();
23+
value.accept(referenceCounted);
24+
25+
verify(referenceCounted).release();
26+
}
27+
28+
private static Consumer<?> extractDroppedElementConsumer() {
29+
return (Consumer<?>) SendUtils.DISCARD_CONTEXT.stream().findAny().get().getValue();
30+
}
31+
}

0 commit comments

Comments
 (0)