use of io.reactivex.rxjava3.internal.subscriptions.BooleanSubscription in project RxJava by ReactiveX.
the class FlowableUnsubscribeOnTest method signalAfterDispose.
@Test
public void signalAfterDispose() {
List<Throwable> errors = TestHelper.trackPluginErrors();
try {
new Flowable<Integer>() {
@Override
protected void subscribeActual(Subscriber<? super Integer> subscriber) {
subscriber.onSubscribe(new BooleanSubscription());
subscriber.onNext(1);
subscriber.onNext(2);
subscriber.onError(new TestException());
subscriber.onComplete();
}
}.unsubscribeOn(Schedulers.single()).take(1).test().assertResult(1);
TestHelper.assertUndeliverable(errors, 0, TestException.class);
} finally {
RxJavaPlugins.reset();
}
}
use of io.reactivex.rxjava3.internal.subscriptions.BooleanSubscription in project RxJava by ReactiveX.
the class FlowableWindowWithFlowableTest method takeOneAnotherBoundary.
@Test
public void takeOneAnotherBoundary() {
final AtomicReference<Subscriber<? super Object>> refMain = new AtomicReference<>();
final AtomicReference<Subscriber<? super Object>> ref = new AtomicReference<>();
TestSubscriberEx<Flowable<Object>> ts = new Flowable<Object>() {
@Override
protected void subscribeActual(Subscriber<? super Object> subscriber) {
subscriber.onSubscribe(new BooleanSubscription());
refMain.set(subscriber);
}
}.window(new Flowable<Object>() {
@Override
protected void subscribeActual(Subscriber<? super Object> subscriber) {
subscriber.onSubscribe(new BooleanSubscription());
ref.set(subscriber);
}
}).to(TestHelper.<Flowable<Object>>testConsumer());
ts.assertValueCount(1).assertNotTerminated().cancel();
ref.get().onNext(1);
ts.assertValueCount(1).assertNotTerminated();
}
use of io.reactivex.rxjava3.internal.subscriptions.BooleanSubscription in project RxJava by ReactiveX.
the class FlowableWindowWithFlowableTest method mainCompleteBoundaryErrorRace.
@Test
public void mainCompleteBoundaryErrorRace() {
final TestException ex = new TestException();
for (int i = 0; i < TestHelper.RACE_LONG_LOOPS; i++) {
List<Throwable> errors = TestHelper.trackPluginErrors();
try {
final AtomicReference<Subscriber<? super Object>> refMain = new AtomicReference<>();
final AtomicReference<Subscriber<? super Object>> ref = new AtomicReference<>();
TestSubscriberEx<Flowable<Object>> ts = new Flowable<Object>() {
@Override
protected void subscribeActual(Subscriber<? super Object> subscriber) {
subscriber.onSubscribe(new BooleanSubscription());
refMain.set(subscriber);
}
}.window(new Flowable<Object>() {
@Override
protected void subscribeActual(Subscriber<? super Object> subscriber) {
subscriber.onSubscribe(new BooleanSubscription());
ref.set(subscriber);
}
}).to(TestHelper.<Flowable<Object>>testConsumer());
Runnable r1 = new Runnable() {
@Override
public void run() {
refMain.get().onComplete();
}
};
Runnable r2 = new Runnable() {
@Override
public void run() {
ref.get().onError(ex);
}
};
TestHelper.race(r1, r2);
ts.assertValueCount(1).assertTerminated();
if (!errors.isEmpty()) {
TestHelper.assertUndeliverable(errors, 0, TestException.class);
}
} finally {
RxJavaPlugins.reset();
}
}
}
use of io.reactivex.rxjava3.internal.subscriptions.BooleanSubscription in project RxJava by ReactiveX.
the class FlowablePublishTest method badSource.
@Test
public void badSource() {
List<Throwable> errors = TestHelper.trackPluginErrors();
try {
new Flowable<Integer>() {
@Override
protected void subscribeActual(Subscriber<? super Integer> subscriber) {
subscriber.onSubscribe(new BooleanSubscription());
subscriber.onNext(1);
subscriber.onComplete();
subscriber.onNext(2);
subscriber.onError(new TestException());
subscriber.onComplete();
}
}.publish().autoConnect().test().assertResult(1);
TestHelper.assertUndeliverable(errors, 0, TestException.class);
} finally {
RxJavaPlugins.reset();
}
}
use of io.reactivex.rxjava3.internal.subscriptions.BooleanSubscription in project RxJava by ReactiveX.
the class FlowablePublishTest method publish.
@Test
public void publish() throws InterruptedException {
final AtomicInteger counter = new AtomicInteger();
ConnectableFlowable<String> f = Flowable.unsafeCreate(new Publisher<String>() {
@Override
public void subscribe(final Subscriber<? super String> subscriber) {
subscriber.onSubscribe(new BooleanSubscription());
new Thread(new Runnable() {
@Override
public void run() {
counter.incrementAndGet();
subscriber.onNext("one");
subscriber.onComplete();
}
}).start();
}
}).publish();
final CountDownLatch latch = new CountDownLatch(2);
// subscribe once
f.subscribe(new Consumer<String>() {
@Override
public void accept(String v) {
assertEquals("one", v);
latch.countDown();
}
});
// subscribe again
f.subscribe(new Consumer<String>() {
@Override
public void accept(String v) {
assertEquals("one", v);
latch.countDown();
}
});
Disposable connection = f.connect();
try {
if (!latch.await(1000, TimeUnit.MILLISECONDS)) {
fail("subscriptions did not receive values");
}
assertEquals(1, counter.get());
} finally {
connection.dispose();
}
}
Aggregations