rx.observers.AssertableSubscriber Maven / Gradle / Ivy
/**
* Copyright 2016 Netflix, Inc.
*
* 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 rx.observers;
import java.util.List;
import java.util.concurrent.TimeUnit;
import rx.*;
import rx.functions.Action0;
/**
* Interface for asserting the state of a sequence under testing with a {@code test()}
* method of a reactive base class.
*
* This interface is not intended to be implemented outside of RxJava.
*
* This interface extends {@link Observer} and allows injecting onXXX signals into
* the testing process.
*
History: 1.2.3 - experimental
* @param the value type consumed by this Observer
* @since 1.3
*/
public interface AssertableSubscriber extends Observer, Subscription {
/**
* Allows manually calling the {@code onStart} method of the underlying Subscriber.
*/
void onStart();
/**
* Allows manually calling the {@code setProducer} method of the underlying Subscriber.
* @param p the producer to use, not null
*/
void setProducer(Producer p);
/**
* Returns the number of {@code onCompleted} signals received by this Observer.
* @return the number of {@code onCompleted} signals received
*/
int getCompletions();
/**
* Returns a list of received {@code onError} signals.
* @return this
*/
List getOnErrorEvents();
/**
* Returns the number of {@code onNext} signals received by this Observer in
* a thread-safe manner; one can read up to this number of elements from
* the {@code List} returned by {@link #getOnNextEvents()}.
* @return the number of {@code onNext} signals received.
*/
int getValueCount();
/**
* Requests the specified amount of items from upstream.
* @param n the amount requested, non-negative
* @return this
*/
AssertableSubscriber requestMore(long n);
/**
* Returns the list of received {@code onNext} events.
* If the sequence hasn't completed yet and is asynchronous, use the
* {@link #getValueCount()} method to determine how many elements are safe
* to be read from the list returned by this method.
* @return the List of received {@code onNext} events.
*/
List getOnNextEvents();
/**
* Assert that this Observer received the given list of items as {@code onNext} signals
* in the same order and with the default null-safe object equals comparison.
* @param items the List of items expected
* @return this
*/
AssertableSubscriber assertReceivedOnNext(List items);
/**
* Assert that this Observer receives at least the given number of {@code onNext}
* signals within the specified timeout period.
*
* Note that it is possible the AssertionError thrown by this method will
* contain an actual value >= to the expected one in case there is an emission
* race or unexpected delay on the emitter side. In this case, increase the timeout
* amount to avoid false positives.
*
* @param expected the expected (at least) number of {@code onNext} signals
* @param timeout the timeout to wait to receive the given number of {@code onNext} events
* @param unit the time unit
* @return this
*/
AssertableSubscriber awaitValueCount(int expected, long timeout, TimeUnit unit);
/**
* Assert that this Observer received either an {@code onError} or {@code onCompleted} signal.
* @return this
*/
AssertableSubscriber assertTerminalEvent();
/**
* Assert that this Observer has been unsubscribed via {@code unsubscribe()} or by a wrapping
* {@code SafeSubscriber}.
* @return this
*/
AssertableSubscriber assertUnsubscribed();
/**
* Assert that this Observer has not received any {@code onError} signal.
* @return this
*/
AssertableSubscriber assertNoErrors();
/**
* Waits for an {@code onError} or {code onCompleted} terminal event indefinitely.
* @return this
*/
AssertableSubscriber awaitTerminalEvent();
/**
* Waits for an {@code onError} or {code onCompleted} terminal event for the given
* amount of timeout.
* @param timeout the time to wait for the terminal event
* @param unit the time unit of the wait time
* @return this
*/
AssertableSubscriber awaitTerminalEvent(long timeout, TimeUnit unit);
/**
* Waits for an {@code onError} or {code onCompleted} terminal event for the given
* amount of timeout and unsubscribes the sequence if the timeout passed or the
* wait itself is interrupted.
* @param timeout the time to wait for the terminal event
* @param unit the time unit of the wait time
* @return this
*/
AssertableSubscriber awaitTerminalEventAndUnsubscribeOnTimeout(long timeout,
TimeUnit unit);
/**
* Returns the Thread that has called the last {@code onNext}, {@code onError} or
* {@code onCompleted} methods of this Observer.
* @return this
*/
Thread getLastSeenThread();
/**
* Assert that this Observer received exaclty one {@code onCompleted} signal.
* @return this
*/
AssertableSubscriber assertCompleted();
/**
* Assert that this Observer received no {@code onCompleted} signal.
* @return this
*/
AssertableSubscriber assertNotCompleted();
/**
* Assert that this Observer received one {@code onError} signal with
* the given subclass of a Throwable as type.
* @param clazz the expected type of the {@code onError} signal received
* @return this
*/
AssertableSubscriber assertError(Class extends Throwable> clazz);
/**
* Assert that this Observer received one {@code onError} signal with the
* object-equals of the given Throwable instance
* @param throwable the Throwable instance expected
* @return this
*/
AssertableSubscriber assertError(Throwable throwable);
/**
* Assert that no {@code onError} or {@code onCompleted} signals were received so far.
* @return this
*/
AssertableSubscriber assertNoTerminalEvent();
/**
* Assert that no {@code onNext} signals were received so far.
* @return this
*/
AssertableSubscriber assertNoValues();
/**
* Assert that this Observer received exactly the given count of
* {@code onNext} signals.
* @param count the expected number of {@code onNext} signals
* @return this
*/
AssertableSubscriber assertValueCount(int count);
/**
* Assert that this Observer received exactly the given expected values
* (compared via null-safe object equals) in the given order.
* @param values the expected values
* @return this
*/
AssertableSubscriber assertValues(T... values);
/**
* Assert that this Observer received exactly the given single expected value
* (compared via null-safe object equals).
* @param value the single value expected
* @return this
*/
AssertableSubscriber assertValue(T value);
/**
* Assert that this Observer received exactly the given values (compared via
* null-safe object equals) and if so, clears the internal buffer of the
* underlying Subscriber of these values.
* @param expectedFirstValue the first value expected
* @param expectedRestValues the rest of the values expected
* @return this
*/
AssertableSubscriber assertValuesAndClear(T expectedFirstValue,
T... expectedRestValues);
/**
* Performs an action given by the Action0 callback in a fluent manner.
* @param action the action to perform, not null
* @return this
*/
AssertableSubscriber perform(Action0 action);
@Override
void unsubscribe();
@Override
boolean isUnsubscribed();
/**
* Assert that this Observer received the specified items in the given order followed
* by a completion signal and no errors.
* @param values the values expected
* @return this
*/
AssertableSubscriber assertResult(T... values);
/**
* Assert that this Observer received the specified items in the given order followed
* by an error signal of the given type (but no completion signal).
* @param errorClass the expected Throwable subclass type
* @param values the expected values
* @return this
*/
AssertableSubscriber assertFailure(Class extends Throwable> errorClass, T... values);
/**
* Assert that this Observer received the specified items in the given order followed
* by an error signal of the given type and with the exact error message (but no completion signal).
* @param errorClass the expected Throwable subclass type
* @param message the expected error message returned by {@link Throwable#getMessage()}
* @param values the expected values
* @return this
*/
AssertableSubscriber assertFailureAndMessage(Class extends Throwable> errorClass, String message, T... values);
}