Interface SubscriberBlackboxVerificationRules
- All Known Implementing Classes:
FlowSubscriberBlackboxVerification, SubscriberBlackboxVerification
-
Method Summary
Modifier and TypeMethodDescriptionvoidAsks for aSubscriberinstance, expects it to callrequest()in a timely manner and signals as manyonNextitems as the very first request amount specified by theSubscriber.voidAsks for aSubscriber, signals anonSubscribefollowed by anonCompletesynchronously, and checks if neitherrequestnorcancelwas called from within theSubscriber'sonCompleteimplementation.voidAsks for aSubscriber, signals anonSubscribefollowed by anonErrorsynchronously, and checks if neitherrequestnorcancelwas called from within theSubscriber'sonCompleteimplementation.voidAsks for aSubscriber, signalsonSubscribetwice synchronously and expects the secondSubscriptiongets cancelled in a timely manner and without any calls to itsrequestmethod.voidAsks for aSubscriberand expects it to handleonCompleteindependent of whether theSubscriberrequests items or not.voidAsks for aSubscriber, expects it to request some amount and in turn be able to receive anonCompletesynchronously from therequestcall without anyonNextsignals before that.voidAsks for aSubscriber, signalsonSubscribefollowed by anonErrorsynchronously.voidAsks for aSubscriber, signalsonSubscribefollowed by anonErrorsynchronously.voidAsks for aSubscriber, signals anonSubscribeevent followed by aonErrorwithnullas a parameter and expects an immediateNullPointerExceptionto be thrown by theSubscriber.onErrormethod.voidAsks for aSubscriber, signals anonSubscribeevent followed by aonNextwithnullas a parameter and expects an immediateNullPointerExceptionto be thrown by theSubscriber.onNextmethod.voidAsks for aSubscriberand signals anonSubscribeevent withnullas a parameter and expects an immediateNullPointerExceptionto be thrown by theSubscriber.onSubscribemethod.voidCurrently, this test is skipped because there is no agreed upon approach how to detect if theSubscriberreally goes async or just responds in a timely manner.voiduntested_spec204_blackbox_mustConsiderTheSubscriptionAsCancelledInAfterRecievingOnCompleteOrOnError()Currently, this test is skipped because there is no way to check what theSubscriber"considers" since rule §2.3 forbids interaction from within theonErrorandonCompletemethods.voidCurrently, this test is skipped because it requires more control over theSubscriberimplementation to make it cancel theSubscriptionfor some external condition.voidCurrently, this test is skipped because it requires more control over theSubscriberimplementation to issue requests based on external stimulus.voidCurrently, this test is skipped because there is no way to make theSubscriberimplementation cancel the test'sSubscriptionand check the outcome of sendingonNexts after such cancel.voidCurrently, this test is skipped because it would require analyzing what theSubscriberimplementation does.voidCurrently, this test is skipped because the test for§2.5is in a better position to test for handling the reuse of the sameSubscriber.voidCurrently, this test is skipped because it would require more control over theSubscriberto fail internally in response to a set of legal event emissions, not throw any exception from theSubscribermethods and have it cancel theSubscription.voidCurrently, this test is skipped because there is no agreed upon way for specifying, enforcing and testing aSubscriberwith an arbitrary context.voidCurrently, this test is skipped because element production is the responsibility of thePublisherand aSubscriptionis not expected to be the active element in an established subscription.voidCurrently, this test is skipped because element production is the responsibility of thePublisherand aSubscriptionis not expected to be the active element in an established subscription.voidCurrently, this test is skipped because signal production is the responsibility of thePublisherand aSubscriptionis not expected to be the active element in an established subscription.voidCurrently, this test is skipped because it is the responsibility of thePublisherdeal with the case that all subscribers have cancelled their subscription.voidCurrently, this test is skipped because it requires more control over theSubscriberimplementation thus there is no way to detect that theSubscribercalled its ownonErrormethod in response to an exception thrown fromSubscription.cancel.voidCurrently, this test is skipped because it requires more control over theSubscriberimplementation thus there is no way to detect that theSubscribercalled its ownonErrormethod in response to an exception thrown fromSubscription.request.
-
Method Details
-
required_spec201_blackbox_mustSignalDemandViaSubscriptionRequest
Asks for aSubscriberinstance, expects it to callrequest()in a timely manner and signals as manyonNextitems as the very first request amount specified by theSubscriber.Verifies rule: 2.1
Notes:
- This test emits the number of items requested thus the
Subscriberimplementation should not request too much. - Only the very first
requestamount is considered. - This test doesn't signal
onCompleteafter the first set ofonNextsignals has been emitted and may cause resource leak inSubscribers that expect a finitePublisher. - The test ignores cancellation from the
Subscriberand emits the requested amount regardless.
If this test fails, the following could be checked within the
Subscriberimplementation:- if the
Subscriberrequires external stimulus to begin requesting; override theSubscriberBlackboxVerification.triggerRequest(org.reactivestreams.Subscriber)method in this case, - the
TestEnvironmenthas large enough timeout specified in case theSubscriberhas some time-delay behavior, - if the
Subscriberrequests zero or a negative value in some circumstances, - if the
Subscriberthrows an unchecked exception from itsonSubscribeoronNextmethods.
- Throws:
Throwable
- This test emits the number of items requested thus the
-
untested_spec202_blackbox_shouldAsynchronouslyDispatch
-
required_spec203_blackbox_mustNotCallMethodsOnSubscriptionOrPublisherInOnComplete
void required_spec203_blackbox_mustNotCallMethodsOnSubscriptionOrPublisherInOnComplete() throws ThrowableAsks for aSubscriber, signals anonSubscribefollowed by anonCompletesynchronously, and checks if neitherrequestnorcancelwas called from within theSubscriber'sonCompleteimplementation.Verifies rule: 2.3
Notes:
- The test checks for the presensce of method named "onComplete" in the current stacktrace when handling
the
requestorcancelcalls in the test's ownSubscription.
If this test fails, the following could be checked within the
Subscriberimplementation:- no calls happen to
requestorcancelin response to anonCompletedirectly or indirectly, - if the
Subscriberthrows an unchecked exception from itsonSubscribeoronCompletemethods.
- Throws:
Throwable
- The test checks for the presensce of method named "onComplete" in the current stacktrace when handling
the
-
required_spec203_blackbox_mustNotCallMethodsOnSubscriptionOrPublisherInOnError
void required_spec203_blackbox_mustNotCallMethodsOnSubscriptionOrPublisherInOnError() throws ThrowableAsks for aSubscriber, signals anonSubscribefollowed by anonErrorsynchronously, and checks if neitherrequestnorcancelwas called from within theSubscriber'sonCompleteimplementation.Verifies rule: 2.3
Notes:
- The test checks for the presensce of method named "onError" in the current stacktrace when handling
the
requestorcancelcalls in the test's ownSubscription.
If this test fails, the following could be checked within the
Subscriberimplementation:- no calls happen to
requestorcancelin response to anonErrordirectly or indirectly, - if the
Subscriberthrows an unchecked exception from itsonSubscribeoronErrormethods.
- Throws:
Throwable
- The test checks for the presensce of method named "onError" in the current stacktrace when handling
the
-
untested_spec204_blackbox_mustConsiderTheSubscriptionAsCancelledInAfterRecievingOnCompleteOrOnError
void untested_spec204_blackbox_mustConsiderTheSubscriptionAsCancelledInAfterRecievingOnCompleteOrOnError() throws ExceptionCurrently, this test is skipped because there is no way to check what theSubscriber"considers" since rule §2.3 forbids interaction from within theonErrorandonCompletemethods.Verifies rule: 2.4
Notes:
- It would be possible to check if there was an async interaction with the test's
Subscriptionwithin a grace period but such check is still not generally decisive.
- Throws:
Exception
- It would be possible to check if there was an async interaction with the test's
-
required_spec205_blackbox_mustCallSubscriptionCancelIfItAlreadyHasAnSubscriptionAndReceivesAnotherOnSubscribeSignal
void required_spec205_blackbox_mustCallSubscriptionCancelIfItAlreadyHasAnSubscriptionAndReceivesAnotherOnSubscribeSignal() throws ExceptionAsks for aSubscriber, signalsonSubscribetwice synchronously and expects the secondSubscriptiongets cancelled in a timely manner and without any calls to itsrequestmethod.Verifies rule: 2.5
Notes:
- The test doesn't signal any other events than
onSubscribeand may cause resource leak inSubscribers that expect a finitePublisher.
If this test fails, the following could be checked within the
Subscriberimplementation:- if the
Subscribe.onSubscribeimplementation actually tries to detect multiple calls to it, - if the second
Subscriptionis cancelled asynchronously and that takes longer time than theTestEnvironment's timeout permits.
- Throws:
Exception
- The test doesn't signal any other events than
-
untested_spec206_blackbox_mustCallSubscriptionCancelIfItIsNoLongerValid
-
untested_spec207_blackbox_mustEnsureAllCallsOnItsSubscriptionTakePlaceFromTheSameThreadOrTakeCareOfSynchronization
void untested_spec207_blackbox_mustEnsureAllCallsOnItsSubscriptionTakePlaceFromTheSameThreadOrTakeCareOfSynchronization() throws ExceptionCurrently, this test is skipped because it requires more control over theSubscriberimplementation to issue requests based on external stimulus.Verifies rule: 2.7
- Throws:
Exception
-
untested_spec208_blackbox_mustBePreparedToReceiveOnNextSignalsAfterHavingCalledSubscriptionCancel
void untested_spec208_blackbox_mustBePreparedToReceiveOnNextSignalsAfterHavingCalledSubscriptionCancel() throws ThrowableCurrently, this test is skipped because there is no way to make theSubscriberimplementation cancel the test'sSubscriptionand check the outcome of sendingonNexts after such cancel.Verifies rule: 2.8
- Throws:
Throwable
-
required_spec209_blackbox_mustBePreparedToReceiveAnOnCompleteSignalWithPrecedingRequestCall
void required_spec209_blackbox_mustBePreparedToReceiveAnOnCompleteSignalWithPrecedingRequestCall() throws ThrowableAsks for aSubscriber, expects it to request some amount and in turn be able to receive anonCompletesynchronously from therequestcall without anyonNextsignals before that.Verifies rule: 2.9
Notes:
- The test ignores cancellation from the
Subscriber. - Invalid request amounts are ignored by this test.
- Concurrent calls to the test's
Subscription.request()must be externally synchronized, otherwise such case results probabilistically in multipleonCompletecalls by the test.
If this test fails, the following could be checked within the
Subscriberimplementation:- if the
Subscriberthrows an unchecked exception from itsonSubscribeoronCompletemethods. - if the
Subscriberrequires external stimulus to begin requesting; override theSubscriberBlackboxVerification.triggerRequest(org.reactivestreams.Subscriber)method in this case,
- Throws:
Throwable
- The test ignores cancellation from the
-
required_spec209_blackbox_mustBePreparedToReceiveAnOnCompleteSignalWithoutPrecedingRequestCall
void required_spec209_blackbox_mustBePreparedToReceiveAnOnCompleteSignalWithoutPrecedingRequestCall() throws ThrowableAsks for aSubscriberand expects it to handleonCompleteindependent of whether theSubscriberrequests items or not.Verifies rule: 2.9
Notes:
- Currently, the test doesn't call
onSubscribeon theSubscriberwhich violates §1.9.
If this test fails, the following could be checked within the
Subscriberimplementation:- if the
Subscriberthrows an unchecked exception from itsonSubscribeoronCompletemethods.
- Throws:
Throwable
- Currently, the test doesn't call
-
required_spec210_blackbox_mustBePreparedToReceiveAnOnErrorSignalWithPrecedingRequestCall
void required_spec210_blackbox_mustBePreparedToReceiveAnOnErrorSignalWithPrecedingRequestCall() throws ThrowableAsks for aSubscriber, signalsonSubscribefollowed by anonErrorsynchronously.Verifies rule: 2.10
Notes:
- Despite the method name, the test doesn't expect a request signal from
Subscriberand emits theonErrorsignal anyway.
If this test fails, the following could be checked within the
Subscriberimplementation:- if the
Subscriberthrows an unchecked exception from itsonSubscribeoronErrormethods.
- Throws:
Throwable
- Despite the method name, the test doesn't expect a request signal from
-
required_spec210_blackbox_mustBePreparedToReceiveAnOnErrorSignalWithoutPrecedingRequestCall
void required_spec210_blackbox_mustBePreparedToReceiveAnOnErrorSignalWithoutPrecedingRequestCall() throws ThrowableAsks for aSubscriber, signalsonSubscribefollowed by anonErrorsynchronously.Verifies rule: 2.10
If this test fails, the following could be checked within the
Subscriberimplementation:- if the
Subscriberthrows an unchecked exception from itsonSubscribeoronErrormethods.
- Throws:
Throwable
- if the
-
untested_spec211_blackbox_mustMakeSureThatAllCallsOnItsMethodsHappenBeforeTheProcessingOfTheRespectiveEvents
-
untested_spec212_blackbox_mustNotCallOnSubscribeMoreThanOnceBasedOnObjectEquality
void untested_spec212_blackbox_mustNotCallOnSubscribeMoreThanOnceBasedOnObjectEquality() throws ThrowableCurrently, this test is skipped because the test for§2.5is in a better position to test for handling the reuse of the sameSubscriber.Verifies rule: 2.12
Notes:
- In addition to §2.5, this rule could be better verified when testing a
Publisher's subscription behavior.
- Throws:
Throwable
- In addition to §2.5, this rule could be better verified when testing a
-
untested_spec213_blackbox_failingOnSignalInvocation
-
required_spec213_blackbox_onSubscribe_mustThrowNullPointerExceptionWhenParametersAreNull
void required_spec213_blackbox_onSubscribe_mustThrowNullPointerExceptionWhenParametersAreNull() throws ThrowableAsks for aSubscriberand signals anonSubscribeevent withnullas a parameter and expects an immediateNullPointerExceptionto be thrown by theSubscriber.onSubscribemethod.Verifies rule: 2.13
If this test fails, the following could be checked within the
Subscriberimplementation:- if the
Subscriberthrows aNullPointerExceptionfrom itsonSubscribemethod in response to anullparameter and not some other unchecked exception or no exception at all.
- Throws:
Throwable
- if the
-
required_spec213_blackbox_onNext_mustThrowNullPointerExceptionWhenParametersAreNull
void required_spec213_blackbox_onNext_mustThrowNullPointerExceptionWhenParametersAreNull() throws ThrowableAsks for aSubscriber, signals anonSubscribeevent followed by aonNextwithnullas a parameter and expects an immediateNullPointerExceptionto be thrown by theSubscriber.onNextmethod.Verifies rule: 2.13
Notes:
- The test ignores cancellation and requests from the
Subscriberand emits theonNextsignal with anullparameter anyway.
If this test fails, the following could be checked within the
Subscriberimplementation:- if the
Subscriberthrows aNullPointerExceptionfrom itsonNextmethod in response to anullparameter and not some other unchecked exception or no exception at all.
- Throws:
Throwable
- The test ignores cancellation and requests from the
-
required_spec213_blackbox_onError_mustThrowNullPointerExceptionWhenParametersAreNull
void required_spec213_blackbox_onError_mustThrowNullPointerExceptionWhenParametersAreNull() throws ThrowableAsks for aSubscriber, signals anonSubscribeevent followed by aonErrorwithnullas a parameter and expects an immediateNullPointerExceptionto be thrown by theSubscriber.onErrormethod.Verifies rule: 2.13
Notes:
- The test ignores cancellation from the
Subscriberand emits theonErrorsignal with anullparameter anyway.
If this test fails, the following could be checked within the
Subscriberimplementation:- if the
Subscriberthrows aNullPointerExceptionfrom itsonNextmethod in response to anullparameter and not some other unchecked exception or no exception at all.
- Throws:
Throwable
- The test ignores cancellation from the
-
untested_spec301_blackbox_mustNotBeCalledOutsideSubscriberContext
-
untested_spec308_blackbox_requestMustRegisterGivenNumberElementsToBeProduced
void untested_spec308_blackbox_requestMustRegisterGivenNumberElementsToBeProduced() throws ThrowableCurrently, this test is skipped because element production is the responsibility of thePublisherand aSubscriptionis not expected to be the active element in an established subscription.Verifies rule: 3.8
- Throws:
Throwable
-
untested_spec310_blackbox_requestMaySynchronouslyCallOnNextOnSubscriber
Currently, this test is skipped because element production is the responsibility of thePublisherand aSubscriptionis 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.
- Throws:
Exception
-
untested_spec311_blackbox_requestMaySynchronouslyCallOnCompleteOrOnError
-
untested_spec314_blackbox_cancelMayCauseThePublisherToShutdownIfNoOtherSubscriptionExists
void untested_spec314_blackbox_cancelMayCauseThePublisherToShutdownIfNoOtherSubscriptionExists() throws ExceptionCurrently, this test is skipped because it is the responsibility of thePublisherdeal 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
Publisherimplementations (most likelyProcessors) would coordinate with multipleSubscribers.
- Throws:
Exception
- The specification lists this as an optional behavior because only some
-
untested_spec315_blackbox_cancelMustNotThrowExceptionAndMustSignalOnError
-
untested_spec316_blackbox_requestMustNotThrowExceptionAndMustOnErrorTheSubscriber
void untested_spec316_blackbox_requestMustNotThrowExceptionAndMustOnErrorTheSubscriber() throws ExceptionCurrently, this test is skipped because it requires more control over theSubscriberimplementation thus there is no way to detect that theSubscribercalled its ownonErrormethod in response to an exception thrown fromSubscription.request.Verifies rule: 3.16
- Throws:
Exception
-