/**
* Copyright (c) 2016-present, RxJava Contributors.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in
* compliance with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License is
* distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See
* the License for the specific language governing permissions and limitations under the License.
*/
package io.reactivex.internal.operators.maybe;
import static org.junit.Assert.*;
import java.util.List;
import org.junit.Test;
import io.reactivex.*;
import io.reactivex.disposables.Disposables;
import io.reactivex.exceptions.*;
import io.reactivex.functions.*;
import io.reactivex.internal.functions.Functions;
import io.reactivex.observers.TestObserver;
import io.reactivex.plugins.RxJavaPlugins;
import io.reactivex.processors.PublishProcessor;
public class MaybePeekTest {
@Test
public void disposed() {
TestHelper.checkDisposed(PublishProcessor.create().singleElement().doOnSuccess(Functions.emptyConsumer()));
}
@Test
public void doubleOnSubscribe() {
TestHelper.checkDoubleOnSubscribeMaybe(new Function<Maybe<Object>, MaybeSource<Object>>() {
@Override
public MaybeSource<Object> apply(Maybe<Object> m) throws Exception {
return m.doOnSuccess(Functions.emptyConsumer());
}
});
}
@Test
public void doubleError() {
List<Throwable> errors = TestHelper.trackPluginErrors();
final Throwable[] err = { null };
try {
TestObserver<Integer> to = new Maybe<Integer>() {
@Override
protected void subscribeActual(MaybeObserver<? super Integer> observer) {
observer.onSubscribe(Disposables.empty());
observer.onError(new TestException("First"));
observer.onError(new TestException("Second"));
}
}
.doOnError(new Consumer<Throwable>() {
@Override
public void accept(Throwable e) throws Exception {
err[0] = e;
}
})
.test();
TestHelper.assertUndeliverable(errors, 0, TestException.class, "Second");
assertTrue("" + err, err[0] instanceof TestException);
assertEquals("First", err[0].getMessage());
to.assertFailureAndMessage(TestException.class, "First");
} finally {
RxJavaPlugins.reset();
}
}
@Test
public void doubleComplete() {
final int[] compl = { 0 };
TestObserver<Integer> to = new Maybe<Integer>() {
@Override
protected void subscribeActual(MaybeObserver<? super Integer> observer) {
observer.onSubscribe(Disposables.empty());
observer.onComplete();
observer.onComplete();
}
}
.doOnComplete(new Action() {
@Override
public void run() throws Exception {
compl[0]++;
}
})
.test();
assertEquals(1, compl[0]);
to.assertResult();
}
@Test
public void doOnErrorThrows() {
TestObserver<Object> to = Maybe.error(new TestException("Main"))
.doOnError(new Consumer<Object>() {
@Override
public void accept(Object t) throws Exception {
throw new TestException("Inner");
}
})
.test();
to.assertFailure(CompositeException.class);
List<Throwable> errors = TestHelper.compositeList(to.errors().get(0));
TestHelper.assertError(errors, 0, TestException.class, "Main");
TestHelper.assertError(errors, 1, TestException.class, "Inner");
}
@Test
public void afterTerminateThrows() {
List<Throwable> errors = TestHelper.trackPluginErrors();
try {
Maybe.just(1)
.doAfterTerminate(new Action() {
@Override
public void run() throws Exception {
throw new TestException();
}
})
.test()
.assertResult(1);
TestHelper.assertUndeliverable(errors, 0, TestException.class);
} finally {
RxJavaPlugins.reset();
}
}
}