All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.reactivestreams.tck.flow.support.SubscriberBlackboxVerificationRules Maven / Gradle / Ivy

/************************************************************************
 * Licensed under Public Domain (CC0)                                    *
 *                                                                       *
 * To the extent possible under law, the person who associated CC0 with  *
 * this code has waived all copyright and related or neighboring         *
 * rights to this code.                                                  *
 *                                                                       *
 * You should have received a copy of the CC0 legalcode along with this  *
 * work. If not, see .*
 ************************************************************************/

package org.reactivestreams.tck.flow.support;

import org.reactivestreams.tck.SubscriberBlackboxVerification;

/**
 * Internal TCK use only.
 * Add / Remove tests for SubscriberBlackboxVerification here to make sure that they arre added/removed in the other places.
 */
public interface SubscriberBlackboxVerificationRules {
  /**
   * Asks for a {@code Subscriber} instance, expects it to call {@code request()} in 
   * a timely manner and signals as many {@code onNext} items as the very first request 
   * amount specified by the {@code Subscriber}.
   * 

* Verifies rule: 2.1 *

* Notes: *

    *
  • This test emits the number of items requested thus the {@code Subscriber} implementation * should not request too much.
  • *
  • Only the very first {@code request} amount is considered.
  • *
  • This test doesn't signal {@code onComplete} after the first set of {@code onNext} signals * has been emitted and may cause resource leak in * {@code Subscriber}s that expect a finite {@code Publisher}.
  • *
  • The test ignores cancellation from the {@code Subscriber} and emits the requested amount regardless.
  • *
*

* If this test fails, the following could be checked within the {@code Subscriber} implementation: *

    *
  • if the {@code Subscriber} requires external stimulus to begin requesting; override the * {@link SubscriberBlackboxVerification#triggerRequest(org.reactivestreams.Subscriber)} method * in this case,
  • *
  • the {@code TestEnvironment} has large enough timeout specified in case the {@code Subscriber} has some time-delay behavior,
  • *
  • if the {@code Subscriber} requests zero or a negative value in some circumstances,
  • *
  • if the {@code Subscriber} throws an unchecked exception from its {@code onSubscribe} or * {@code onNext} methods. *
*/ void required_spec201_blackbox_mustSignalDemandViaSubscriptionRequest() throws Throwable; /** * Currently, this test is skipped because there is no agreed upon approach how * to detect if the {@code Subscriber} really goes async or just responds in * a timely manner. *

* Verifies rule: 2.2 */ void untested_spec202_blackbox_shouldAsynchronouslyDispatch() throws Exception; /** * Asks for a {@code Subscriber}, signals an {@code onSubscribe} followed by an {@code onComplete} synchronously, * and checks if neither {@code request} nor {@code cancel} was called from within the {@code Subscriber}'s * {@code onComplete} implementation. *

* Verifies rule: 2.3 *

* Notes: *

    *
  • The test checks for the presensce of method named "onComplete" in the current stacktrace when handling * the {@code request} or {@code cancel} calls in the test's own {@code Subscription}. *
*

* If this test fails, the following could be checked within the {@code Subscriber} implementation: *

    *
  • no calls happen to {@code request} or {@code cancel} in response to an {@code onComplete} * directly or indirectly,
  • *
  • if the {@code Subscriber} throws an unchecked exception from its {@code onSubscribe} or * {@code onComplete} methods. *
*/ void required_spec203_blackbox_mustNotCallMethodsOnSubscriptionOrPublisherInOnComplete() throws Throwable; /** * Asks for a {@code Subscriber}, signals an {@code onSubscribe} followed by an {@code onError} synchronously, * and checks if neither {@code request} nor {@code cancel} was called from within the {@code Subscriber}'s * {@code onComplete} implementation. *

* Verifies rule: 2.3 *

* Notes: *

    *
  • The test checks for the presensce of method named "onError" in the current stacktrace when handling * the {@code request} or {@code cancel} calls in the test's own {@code Subscription}. *
*

* If this test fails, the following could be checked within the {@code Subscriber} implementation: *

    *
  • no calls happen to {@code request} or {@code cancel} in response to an {@code onError} * directly or indirectly,
  • *
  • if the {@code Subscriber} throws an unchecked exception from its {@code onSubscribe} or * {@code onError} methods. *
*/ void required_spec203_blackbox_mustNotCallMethodsOnSubscriptionOrPublisherInOnError() throws Throwable; /** * Currently, this test is skipped because there is no way to check what the {@code Subscriber} "considers" * since rule §2.3 forbids interaction from within the {@code onError} and {@code onComplete} methods. *

* Verifies rule: 2.4 *

* Notes: *

    *
  • It would be possible to check if there was an async interaction with the test's {@code Subscription} * within a grace period but such check is still not generally decisive.
  • *
*/ void untested_spec204_blackbox_mustConsiderTheSubscriptionAsCancelledInAfterRecievingOnCompleteOrOnError() throws Exception; /** * Asks for a {@code Subscriber}, signals {@code onSubscribe} twice synchronously and expects the second {@code Subscription} gets * cancelled in a timely manner and without any calls to its {@code request} method. *

* Verifies rule: 2.5 *

* Notes: *

    *
  • The test doesn't signal any other events than {@code onSubscribe} and may cause resource leak in * {@code Subscriber}s that expect a finite {@code Publisher}. *
*

* If this test fails, the following could be checked within the {@code Subscriber} implementation: *

    *
  • if the {@code Subscribe.onSubscribe} implementation actually tries to detect multiple calls to it,
  • *
  • if the second {@code Subscription} is cancelled asynchronously and that takes longer time than * the {@code TestEnvironment}'s timeout permits.
  • *
*/ void required_spec205_blackbox_mustCallSubscriptionCancelIfItAlreadyHasAnSubscriptionAndReceivesAnotherOnSubscribeSignal() throws Exception; /** * Currently, this test is skipped because it requires more control over the {@code Subscriber} implementation * to make it cancel the {@code Subscription} for some external condition. *

* Verifies rule: 2.6 */ void untested_spec206_blackbox_mustCallSubscriptionCancelIfItIsNoLongerValid() throws Exception; /** * Currently, this test is skipped because it requires more control over the {@code Subscriber} implementation * to issue requests based on external stimulus. *

* Verifies rule: 2.7 */ void untested_spec207_blackbox_mustEnsureAllCallsOnItsSubscriptionTakePlaceFromTheSameThreadOrTakeCareOfSynchronization() throws Exception; /** * Currently, this test is skipped because there is no way to make the {@code Subscriber} implementation * cancel the test's {@code Subscription} and check the outcome of sending {@code onNext}s after such * cancel. *

* Verifies rule: 2.8 */ void untested_spec208_blackbox_mustBePreparedToReceiveOnNextSignalsAfterHavingCalledSubscriptionCancel() throws Throwable; /** * Asks for a {@code Subscriber}, expects it to request some amount and in turn be able to receive an {@code onComplete} * synchronously from the {@code request} call without any {@code onNext} signals before that. *

* Verifies rule: 2.9 *

* Notes: *

    *
  • The test ignores cancellation from the {@code Subscriber}.
  • *
  • Invalid request amounts are ignored by this test.
  • *
  • Concurrent calls to the test's {@code Subscription.request()} must be externally synchronized, otherwise * such case results probabilistically in multiple {@code onComplete} calls by the test.
  • *
*

* If this test fails, the following could be checked within the {@code Subscriber} implementation: *

    *
  • if the {@code Subscriber} throws an unchecked exception from its {@code onSubscribe} or * {@code onComplete} methods. *
  • if the {@code Subscriber} requires external stimulus to begin requesting; override the * {@link SubscriberBlackboxVerification#triggerRequest(org.reactivestreams.Subscriber)} method * in this case,
  • *
*/ void required_spec209_blackbox_mustBePreparedToReceiveAnOnCompleteSignalWithPrecedingRequestCall() throws Throwable; /** * Asks for a {@code Subscriber} and expects it to handle {@code onComplete} independent of whether the {@code Subscriber} * requests items or not. *

* Verifies rule: 2.9 *

* Notes: *

    *
  • Currently, the test doesn't call {@code onSubscribe} on the {@code Subscriber} which violates §1.9. *
*

* If this test fails, the following could be checked within the {@code Subscriber} implementation: *

    *
  • if the {@code Subscriber} throws an unchecked exception from its {@code onSubscribe} or * {@code onComplete} methods. *
*/ void required_spec209_blackbox_mustBePreparedToReceiveAnOnCompleteSignalWithoutPrecedingRequestCall() throws Throwable; /** * Asks for a {@code Subscriber}, signals {@code onSubscribe} followed by an {@code onError} synchronously. *

* Verifies rule: 2.10 *

* Notes: *

    *
  • Despite the method name, the test doesn't expect a request signal from {@code Subscriber} and emits the * {@code onError} signal anyway. *
*

* If this test fails, the following could be checked within the {@code Subscriber} implementation: *

    *
  • if the {@code Subscriber} throws an unchecked exception from its {@code onSubscribe} or * {@code onError} methods. *
*/ void required_spec210_blackbox_mustBePreparedToReceiveAnOnErrorSignalWithPrecedingRequestCall() throws Throwable; /** * Asks for a {@code Subscriber}, signals {@code onSubscribe} followed by an {@code onError} synchronously. *

* Verifies rule: 2.10 *

* If this test fails, the following could be checked within the {@code Subscriber} implementation: *

    *
  • if the {@code Subscriber} throws an unchecked exception from its {@code onSubscribe} or * {@code onError} methods. *
*/ void required_spec210_blackbox_mustBePreparedToReceiveAnOnErrorSignalWithoutPrecedingRequestCall() throws Throwable; /** * Currently, this test is skipped because it would require analyzing what the {@code Subscriber} implementation * does. *

* Verifies rule: 2.11 */ void untested_spec211_blackbox_mustMakeSureThatAllCallsOnItsMethodsHappenBeforeTheProcessingOfTheRespectiveEvents() throws Exception; /** * Currently, this test is skipped because the test for * {@link #required_spec205_blackbox_mustCallSubscriptionCancelIfItAlreadyHasAnSubscriptionAndReceivesAnotherOnSubscribeSignal §2.5} * is in a better position to test for handling the reuse of the same {@code Subscriber}. *

* Verifies rule: 2.12 *

* Notes: *

    *
  • In addition to §2.5, this rule could be better verified when testing a {@code Publisher}'s subscription behavior. *
*/ void untested_spec212_blackbox_mustNotCallOnSubscribeMoreThanOnceBasedOnObjectEquality() throws Throwable; /** * Currently, this test is skipped because it would require more control over the {@code Subscriber} to * fail internally in response to a set of legal event emissions, not throw any exception from the {@code Subscriber} * methods and have it cancel the {@code Subscription}. *

* Verifies rule: 2.13 */ void untested_spec213_blackbox_failingOnSignalInvocation() throws Exception; /** * Asks for a {@code Subscriber} and signals an {@code onSubscribe} event with {@code null} as a parameter and * expects an immediate {@code NullPointerException} to be thrown by the {@code Subscriber.onSubscribe} method. *

* Verifies rule: 2.13 *

* If this test fails, the following could be checked within the {@code Subscriber} implementation: *

    *
  • if the {@code Subscriber} throws a {@code NullPointerException} from its {@code onSubscribe} method * in response to a {@code null} parameter and not some other unchecked exception or no exception at all. *
*/ void required_spec213_blackbox_onSubscribe_mustThrowNullPointerExceptionWhenParametersAreNull() throws Throwable; /** * Asks for a {@code Subscriber}, signals an {@code onSubscribe} event followed by a * {@code onNext} with {@code null} as a parameter and * expects an immediate {@code NullPointerException} to be thrown by the {@code Subscriber.onNext} method. *

* Verifies rule: 2.13 *

* Notes: *

    *
  • The test ignores cancellation and requests from the {@code Subscriber} and emits the {@code onNext} * signal with a {@code null} parameter anyway.
  • *
*

* If this test fails, the following could be checked within the {@code Subscriber} implementation: *

    *
  • if the {@code Subscriber} throws a {@code NullPointerException} from its {@code onNext} method * in response to a {@code null} parameter and not some other unchecked exception or no exception at all. *
*/ void required_spec213_blackbox_onNext_mustThrowNullPointerExceptionWhenParametersAreNull() throws Throwable; /** * Asks for a {@code Subscriber}, signals an {@code onSubscribe} event followed by a * {@code onError} with {@code null} as a parameter and * expects an immediate {@code NullPointerException} to be thrown by the {@code Subscriber.onError} method. *

* Verifies rule: 2.13 *

* Notes: *

    *
  • The test ignores cancellation from the {@code Subscriber} and emits the {@code onError} * signal with a {@code null} parameter anyway.
  • *
*

* If this test fails, the following could be checked within the {@code Subscriber} implementation: *

    *
  • if the {@code Subscriber} throws a {@code NullPointerException} from its {@code onNext} method * in response to a {@code null} parameter and not some other unchecked exception or no exception at all. *
*/ void required_spec213_blackbox_onError_mustThrowNullPointerExceptionWhenParametersAreNull() throws Throwable; /** * Currently, this test is skipped because there is no agreed upon way for specifying, enforcing and testing * a {@code Subscriber} with an arbitrary context. *

* Verifies rule: 3.1 */ void untested_spec301_blackbox_mustNotBeCalledOutsideSubscriberContext() throws Exception; /** * Currently, this test is skipped because element production is the responsibility of the {@code Publisher} and * a {@code Subscription} is not expected to be the active element in an established subscription. *

* Verifies rule: 3.8 */ void untested_spec308_blackbox_requestMustRegisterGivenNumberElementsToBeProduced() throws Throwable; /** * Currently, this test is skipped because element production is the responsibility of the {@code Publisher} and * a {@code Subscription} is not expected to be the active element in an established subscription. *

* Verifies rule: 3.10 *

* Notes: *

    *
  • This could be tested with a synchronous source currently not available within the TCK.
  • *
*/ void untested_spec310_blackbox_requestMaySynchronouslyCallOnNextOnSubscriber() throws Exception; /** * Currently, this test is skipped because signal production is the responsibility of the {@code Publisher} and * a {@code Subscription} is not expected to be the active element in an established subscription. *

* Verifies rule: 3.11 *

* Notes: *

    *
  • Tests {@link #required_spec209_blackbox_mustBePreparedToReceiveAnOnCompleteSignalWithPrecedingRequestCall() §2.9} * and {@link #required_spec210_blackbox_mustBePreparedToReceiveAnOnErrorSignalWithPrecedingRequestCall() §2.10} are * supposed to cover this case from the {@code Subscriber's} perspective.
  • *
*/ void untested_spec311_blackbox_requestMaySynchronouslyCallOnCompleteOrOnError() throws Exception; /** * Currently, this test is skipped because it is the responsibility of the {@code Publisher} deal with the case * that all subscribers have cancelled their subscription. *

* Verifies rule: 3.14 *

* Notes: *

    *
  • The specification lists this as an optional behavior because only some {@code Publisher} implementations * (most likely {@code Processor}s) would coordinate with multiple {@code Subscriber}s.
  • *
*/ void untested_spec314_blackbox_cancelMayCauseThePublisherToShutdownIfNoOtherSubscriptionExists() throws Exception; /** * Currently, this test is skipped because it requires more control over the {@code Subscriber} implementation * thus there is no way to detect that the {@code Subscriber} called its own {@code onError} method in response * to an exception thrown from {@code Subscription.cancel}. *

* Verifies rule: 3.15 */ void untested_spec315_blackbox_cancelMustNotThrowExceptionAndMustSignalOnError() throws Exception; /** * Currently, this test is skipped because it requires more control over the {@code Subscriber} implementation * thus there is no way to detect that the {@code Subscriber} called its own {@code onError} method in response * to an exception thrown from {@code Subscription.request}. *

* Verifies rule: 3.16 */ void untested_spec316_blackbox_requestMustNotThrowExceptionAndMustOnErrorTheSubscriber() throws Exception; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy