2019-07-02 13:25:51 +01:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved.
|
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
|
|
*
|
|
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
|
|
* accompanied this code).
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License version
|
|
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*
|
|
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
|
|
* questions.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @test
|
|
|
|
* @bug 8226602
|
|
|
|
* @summary Tests convenience reactive primitives with RS TCK
|
|
|
|
*
|
|
|
|
* @library ../reactivestreams-tck
|
|
|
|
* @build S
|
|
|
|
*
|
|
|
|
* @compile -encoding UTF-8 SPublisherOfStream.java
|
|
|
|
*
|
|
|
|
* @compile -encoding UTF-8 BodyPublishersFromPublisher.java
|
|
|
|
* @compile -encoding UTF-8 BodyPublishersNoBody.java
|
|
|
|
* @compile -encoding UTF-8 BodyPublishersOfByteArray.java
|
|
|
|
* @compile -encoding UTF-8 BodyPublishersOfByteArrays.java
|
|
|
|
* @compile -encoding UTF-8 BodyPublishersOfFile.java
|
|
|
|
* @compile -encoding UTF-8 BodyPublishersOfInputStream.java
|
|
|
|
* @compile -encoding UTF-8 BodyPublishersOfSubByteArray.java
|
2020-10-12 12:52:55 +00:00
|
|
|
* @compile -encoding UTF-8 BodyPublishersConcat.java
|
2019-07-02 13:25:51 +01:00
|
|
|
*
|
|
|
|
* @compile -encoding UTF-8 BodySubscribersBuffering.java
|
|
|
|
* @compile -encoding UTF-8 BodySubscribersDiscarding.java
|
|
|
|
* @compile -encoding UTF-8 BodySubscribersFromLineSubscriber.java
|
|
|
|
* @compile -encoding UTF-8 BodySubscribersFromSubscriber.java
|
|
|
|
* @compile -encoding UTF-8 BodySubscribersMapping.java
|
|
|
|
* @compile -encoding UTF-8 BodySubscribersOfByteArray.java
|
|
|
|
* @compile -encoding UTF-8 BodySubscribersOfByteArrayConsumer.java
|
|
|
|
* @compile -encoding UTF-8 BodySubscribersOfFile.java
|
|
|
|
* @compile -encoding UTF-8 BodySubscribersOfInputStream.java
|
|
|
|
* @compile -encoding UTF-8 BodySubscribersOfLines.java
|
|
|
|
* @compile -encoding UTF-8 BodySubscribersOfPublisher.java
|
|
|
|
* @compile -encoding UTF-8 BodySubscribersOfPublisher1.java
|
|
|
|
* @compile -encoding UTF-8 BodySubscribersOfPublisherPublisher.java
|
|
|
|
* @compile -encoding UTF-8 BodySubscribersOfString.java
|
|
|
|
* @compile -encoding UTF-8 BodySubscribersReplacing.java
|
|
|
|
*
|
|
|
|
* @run testng/othervm STest
|
|
|
|
* @run testng/othervm SPublisherOfStream
|
|
|
|
*
|
|
|
|
* @run testng/othervm BodyPublishersFromPublisher
|
|
|
|
* @run testng/othervm BodyPublishersNoBody
|
|
|
|
* @run testng/othervm BodyPublishersOfByteArray
|
|
|
|
* @run testng/othervm BodyPublishersOfByteArrays
|
|
|
|
* @run testng/othervm BodyPublishersOfFile
|
|
|
|
* @run testng/othervm BodyPublishersOfInputStream
|
|
|
|
* @run testng/othervm BodyPublishersOfSubByteArray
|
2020-10-12 12:52:55 +00:00
|
|
|
* @run testng/othervm BodyPublishersConcat
|
2019-07-02 13:25:51 +01:00
|
|
|
*
|
|
|
|
* @run testng/othervm BodySubscribersBuffering
|
|
|
|
* @run testng/othervm BodySubscribersDiscarding
|
|
|
|
* @run testng/othervm BodySubscribersFromLineSubscriber
|
|
|
|
* @run testng/othervm BodySubscribersFromSubscriber
|
|
|
|
* @run testng/othervm BodySubscribersMapping
|
|
|
|
* @run testng/othervm BodySubscribersOfByteArray
|
|
|
|
* @run testng/othervm BodySubscribersOfByteArrayConsumer
|
|
|
|
* @run testng/othervm BodySubscribersOfFile
|
|
|
|
* @run testng/othervm BodySubscribersOfInputStream
|
|
|
|
* @run testng/othervm BodySubscribersOfLines
|
|
|
|
* @run testng/othervm BodySubscribersOfPublisher
|
|
|
|
* @run testng/othervm BodySubscribersOfPublisher1
|
|
|
|
* @run testng/othervm BodySubscribersOfPublisherPublisher
|
|
|
|
* @run testng/othervm BodySubscribersOfString
|
|
|
|
* @run testng/othervm BodySubscribersReplacing
|
|
|
|
*
|
|
|
|
* @key randomness
|
|
|
|
*/
|
|
|
|
public class TckDriver {
|
|
|
|
/*
|
|
|
|
#### General Information
|
|
|
|
|
|
|
|
1. This JTREG test aggregates multiple TestNG tests. This is because
|
|
|
|
these tests share a common library (reactivestreams-tck), and we don't
|
|
|
|
want this library to be compiled separately for each of those tests.
|
|
|
|
|
|
|
|
2. Tests that use RS TCK are compiled with the UTF-8 encoding. This is
|
|
|
|
performed for the sake of reactivestreams-tck. We don't want to patch
|
|
|
|
the TCK because of the extra merging work in the future, should we bring
|
|
|
|
update(s) from the RS repo.
|
|
|
|
|
|
|
|
#### Tests
|
|
|
|
|
|
|
|
1. The purpose of each test should be easily digestible. The name of the
|
|
|
|
test is derived from the very entity the test exercises. For example,
|
|
|
|
|
|
|
|
the BodyPublishersOfFile test exercises the BodyPublisher obtained
|
|
|
|
by calling BodyPublishers.ofFile(Path)
|
|
|
|
|
|
|
|
the BodySubscribersOfFile test exercises the BodySubscriber obtained
|
|
|
|
by calling BodySubscribers.ofFile(Path)
|
|
|
|
|
|
|
|
2. RS TCK requires PublisherVerification tests to produce publishers
|
|
|
|
capable of emitting a certain number of elements. In order to achieve
|
|
|
|
this, we use some knowledge of the internal workings of our publishers.
|
|
|
|
An example would be a chunk size a publisher uses to deliver a portion
|
|
|
|
of data. Without knowing that it is not possible to guarantee that the
|
|
|
|
publisher will emit a particular number of elements.
|
|
|
|
|
|
|
|
3. Typically our publishers cannot be created in a known failed state.
|
|
|
|
In this case the corresponding `createFailedFlowPublisher` method
|
|
|
|
returns `null`.
|
|
|
|
|
|
|
|
4. SubscriberBlackBoxVerification uses the `createElement(int element)`
|
|
|
|
method. Our implementations usually cap the amount of data created by
|
|
|
|
this method, because it's not known beforehand how big the `element`
|
|
|
|
value is. Hence, sometimes there's code like as follows:
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public List<ByteBuffer> createElement(int element) {
|
|
|
|
return scatterBuffer(
|
|
|
|
bufferOfNRandomASCIIBytes(element % 17));
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^
|
|
|
|
}
|
|
|
|
|
|
|
|
5. The amount of testing RS TCK performs on a publisher seems to depend
|
|
|
|
on the number of elements this publisher reports it can emit. Sometimes
|
|
|
|
a code like the following can be seen in the tests:
|
|
|
|
|
|
|
|
@Override public long maxElementsFromPublisher() {
|
|
|
|
return 21;
|
|
|
|
~~~~~~~~~~~^
|
|
|
|
}
|
|
|
|
|
|
|
|
This magic number is a result of trial and error and seems to unlock
|
|
|
|
most of the tests. Reporting big values (e.g. Long.MAX_VALUE - 1) is
|
|
|
|
not an option for most of our publishers because they require to have
|
|
|
|
all the elements upfront.
|
|
|
|
|
|
|
|
6. It doesn't seem currently feasible to provide SubscriberWhiteboxVerification
|
|
|
|
tests as a) it's not clear how much better the coverage is and b) it's
|
|
|
|
significantly harder to code that.
|
|
|
|
|
|
|
|
#### S (Support)
|
|
|
|
|
|
|
|
Support utilities are being tested (STest) too.
|
|
|
|
*/
|
|
|
|
}
|