jdk-24/test/jdk/java/net/httpclient/SubscriberPublisherAPIExceptions.java
Chris Hegarty a3b61fd4c7 8197564: HTTP Client implementation
Co-authored-by: Daniel Fuchs <daniel.fuchs@oracle.com>
Co-authored-by: Michael McMahon <michael.x.mcmahon@oracle.com>
Co-authored-by: Pavel Rappo <pavel.rappo@oracle.com>
Reviewed-by: chegar, dfuchs, michaelm, prappo
2018-04-17 08:54:17 -07:00

174 lines
9.0 KiB
Java

/*
* Copyright (c) 2017, 2018, 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.
*/
import java.io.FileNotFoundException;
import java.nio.ByteBuffer;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.nio.file.OpenOption;
import java.util.List;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.Flow;
import java.net.http.HttpHeaders;
import java.net.http.HttpRequest.BodyPublishers;
import java.net.http.HttpResponse.BodyHandler;
import java.net.http.HttpResponse.ResponseInfo;
import java.net.http.HttpResponse.BodyHandlers;
import java.net.http.HttpResponse.BodySubscriber;
import java.net.http.HttpResponse.BodySubscribers;
import java.util.function.Function;
import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;
import static java.nio.charset.StandardCharsets.UTF_8;
import static java.nio.file.StandardOpenOption.CREATE;
import static java.nio.file.StandardOpenOption.DELETE_ON_CLOSE;
import static java.nio.file.StandardOpenOption.WRITE;
import static java.nio.file.StandardOpenOption.READ;
import static org.testng.Assert.assertThrows;
/*
* @test
* @summary Basic tests for API specified exceptions from Publisher, Handler,
* and Subscriber convenience static factory methods.
* @run testng SubscriberPublisherAPIExceptions
*/
public class SubscriberPublisherAPIExceptions {
static final Class<NullPointerException> NPE = NullPointerException.class;
static final Class<IllegalArgumentException> IAE = IllegalArgumentException.class;
static final Class<IndexOutOfBoundsException> IOB = IndexOutOfBoundsException.class;
@Test
public void publisherAPIExceptions() {
assertThrows(NPE, () -> BodyPublishers.ofByteArray(null));
assertThrows(NPE, () -> BodyPublishers.ofByteArray(null, 0, 1));
assertThrows(IOB, () -> BodyPublishers.ofByteArray(new byte[100], 0, 101));
assertThrows(IOB, () -> BodyPublishers.ofByteArray(new byte[100], 1, 100));
assertThrows(IOB, () -> BodyPublishers.ofByteArray(new byte[100], -1, 10));
assertThrows(IOB, () -> BodyPublishers.ofByteArray(new byte[100], 99, 2));
assertThrows(IOB, () -> BodyPublishers.ofByteArray(new byte[1], -100, 1));
assertThrows(NPE, () -> BodyPublishers.ofByteArray(null));
assertThrows(NPE, () -> BodyPublishers.ofFile(null));
assertThrows(NPE, () -> BodyPublishers.ofInputStream(null));
assertThrows(NPE, () -> BodyPublishers.ofString(null));
assertThrows(NPE, () -> BodyPublishers.ofString("A", null));
assertThrows(NPE, () -> BodyPublishers.ofString(null, UTF_8));
assertThrows(NPE, () -> BodyPublishers.ofString(null, null));
}
@DataProvider(name = "nonExistentFiles")
public Object[][] nonExistentFiles() {
List<Path> paths = List.of(Paths.get("doesNotExist"),
Paths.get("tsixEtoNseod"),
Paths.get("doesNotExist2"));
paths.forEach(p -> {
if (Files.exists(p))
throw new AssertionError("Unexpected " + p);
});
return paths.stream().map(p -> new Object[] { p }).toArray(Object[][]::new);
}
@Test(dataProvider = "nonExistentFiles", expectedExceptions = FileNotFoundException.class)
public void fromFileCheck(Path path) throws Exception {
BodyPublishers.ofFile(path);
}
@Test
public void handlerAPIExceptions() throws Exception {
Path path = Paths.get(".").resolve("tt");
Path file = Files.createFile(Paths.get(".").resolve("aFile"));
Path doesNotExist = Paths.get(".").resolve("doneNotExist");
if (Files.exists(doesNotExist))
throw new AssertionError("Unexpected " + doesNotExist);
assertThrows(NPE, () -> BodyHandlers.ofByteArrayConsumer(null));
assertThrows(NPE, () -> BodyHandlers.ofFile(null));
assertThrows(NPE, () -> BodyHandlers.ofFile(null, CREATE, WRITE));
assertThrows(NPE, () -> BodyHandlers.ofFile(path, (OpenOption[])null));
assertThrows(NPE, () -> BodyHandlers.ofFile(path, new OpenOption[] {null}));
assertThrows(NPE, () -> BodyHandlers.ofFile(path, new OpenOption[] {CREATE, null}));
assertThrows(NPE, () -> BodyHandlers.ofFile(path, new OpenOption[] {null, CREATE}));
assertThrows(NPE, () -> BodyHandlers.ofFile(null, (OpenOption[])null));
assertThrows(NPE, () -> BodyHandlers.ofFileDownload(null, CREATE, WRITE));
assertThrows(NPE, () -> BodyHandlers.ofFileDownload(path, (OpenOption[])null));
assertThrows(NPE, () -> BodyHandlers.ofFileDownload(path, new OpenOption[] {null}));
assertThrows(NPE, () -> BodyHandlers.ofFileDownload(path, new OpenOption[] {CREATE, null}));
assertThrows(NPE, () -> BodyHandlers.ofFileDownload(path, new OpenOption[] {null, CREATE}));
assertThrows(NPE, () -> BodyHandlers.ofFileDownload(null, (OpenOption[])null));
assertThrows(IAE, () -> BodyHandlers.ofFileDownload(file, CREATE, WRITE));
assertThrows(IAE, () -> BodyHandlers.ofFileDownload(doesNotExist, CREATE, WRITE));
assertThrows(NPE, () -> BodyHandlers.ofString(null));
assertThrows(NPE, () -> BodyHandlers.buffering(null, 1));
assertThrows(IAE, () -> BodyHandlers.buffering(new NoOpHandler(), 0));
assertThrows(IAE, () -> BodyHandlers.buffering(new NoOpHandler(), -1));
assertThrows(IAE, () -> BodyHandlers.buffering(new NoOpHandler(), Integer.MIN_VALUE));
// implementation specific exceptions
assertThrows(IAE, () -> BodyHandlers.ofFile(path, READ));
assertThrows(IAE, () -> BodyHandlers.ofFile(path, DELETE_ON_CLOSE));
assertThrows(IAE, () -> BodyHandlers.ofFile(path, READ, DELETE_ON_CLOSE));
assertThrows(IAE, () -> BodyHandlers.ofFileDownload(path, DELETE_ON_CLOSE));
}
@Test
public void subscriberAPIExceptions() {
Path path = Paths.get(".").resolve("tt");
assertThrows(NPE, () -> BodySubscribers.ofByteArrayConsumer(null));
assertThrows(NPE, () -> BodySubscribers.ofFile(null));
assertThrows(NPE, () -> BodySubscribers.ofFile(null, CREATE, WRITE));
assertThrows(NPE, () -> BodySubscribers.ofFile(path, (OpenOption[])null));
assertThrows(NPE, () -> BodySubscribers.ofFile(path, new OpenOption[] {null}));
assertThrows(NPE, () -> BodySubscribers.ofFile(path, new OpenOption[] {CREATE, null}));
assertThrows(NPE, () -> BodySubscribers.ofFile(path, new OpenOption[] {null, CREATE}));
assertThrows(NPE, () -> BodySubscribers.ofFile(null, (OpenOption[])null));
assertThrows(NPE, () -> BodySubscribers.ofString(null));
assertThrows(NPE, () -> BodySubscribers.buffering(null, 1));
assertThrows(IAE, () -> BodySubscribers.buffering(new NoOpSubscriber(), 0));
assertThrows(IAE, () -> BodySubscribers.buffering(new NoOpSubscriber(), -1));
assertThrows(IAE, () -> BodySubscribers.buffering(new NoOpSubscriber(), Integer.MIN_VALUE));
assertThrows(NPE, () -> BodySubscribers.mapping(null, Function.identity()));
assertThrows(NPE, () -> BodySubscribers.mapping(BodySubscribers.ofByteArray(), null));
assertThrows(NPE, () -> BodySubscribers.mapping(null, null));
// implementation specific exceptions
assertThrows(IAE, () -> BodySubscribers.ofFile(path, READ));
assertThrows(IAE, () -> BodySubscribers.ofFile(path, DELETE_ON_CLOSE));
assertThrows(IAE, () -> BodySubscribers.ofFile(path, READ, DELETE_ON_CLOSE));
}
static class NoOpHandler implements BodyHandler<Void> {
@Override public BodySubscriber<Void> apply(ResponseInfo rinfo) { return null; }
}
static class NoOpSubscriber implements BodySubscriber<Void> {
@Override public void onSubscribe(Flow.Subscription subscription) { }
@Override public void onNext(List<ByteBuffer> item) { }
@Override public void onError(Throwable throwable) { }
@Override public void onComplete() { }
@Override public CompletableFuture<Void> getBody() { return null; }
}
}