From 24af91dc02502ebc1e4ae9664957d0fc29f14165 Mon Sep 17 00:00:00 2001 From: Philipp Kunz Date: Tue, 26 Feb 2019 13:14:26 -0500 Subject: [PATCH] 8219548: Better Null paramenter checking in ToolProvider Reviewed-by: lancea, alanb, jjg --- .../classes/java/util/spi/ToolProvider.java | 5 +-- test/jdk/java/util/spi/ToolProviderTest.java | 34 +++++++++++++++++-- 2 files changed, 35 insertions(+), 4 deletions(-) diff --git a/src/java.base/share/classes/java/util/spi/ToolProvider.java b/src/java.base/share/classes/java/util/spi/ToolProvider.java index 1d96cd1f326..b5099758572 100644 --- a/src/java.base/share/classes/java/util/spi/ToolProvider.java +++ b/src/java.base/share/classes/java/util/spi/ToolProvider.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 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 @@ -126,8 +126,9 @@ public interface ToolProvider { default int run(PrintStream out, PrintStream err, String... args) { Objects.requireNonNull(out); Objects.requireNonNull(err); + Objects.requireNonNull(args); for (String arg : args) { - Objects.requireNonNull(args); + Objects.requireNonNull(arg); } PrintWriter outWriter = new PrintWriter(out); diff --git a/test/jdk/java/util/spi/ToolProviderTest.java b/test/jdk/java/util/spi/ToolProviderTest.java index f10593d4e25..9a337bc6ce2 100644 --- a/test/jdk/java/util/spi/ToolProviderTest.java +++ b/test/jdk/java/util/spi/ToolProviderTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 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 @@ -28,7 +28,6 @@ * @run main/othervm ToolProviderTest */ -import java.io.File; import java.io.IOException; import java.io.PrintWriter; import java.nio.file.Files; @@ -46,6 +45,10 @@ public class ToolProviderTest { void run() throws Exception { initServices(); + System.out.println("Validate an NPE is thrown with null arguments"); + + testNullArgs(); + System.out.println("test without security manager present:"); test(); @@ -63,6 +66,33 @@ public class ToolProviderTest { } } + private void testNullArgs() { + ToolProvider testProvider = ToolProvider.findFirst("test").get(); + + // out null check + expectNullPointerException(() -> testProvider.run(null, System.err)); + + // err null check + expectNullPointerException(() -> testProvider.run(System.out, null)); + + // args array null check + expectNullPointerException(() -> + testProvider.run(System.out, System.err, (String[]) null)); + + // args array elements null check + expectNullPointerException(() -> + testProvider.run(System.out, System.err, (String) null)); + } + + private static void expectNullPointerException(Runnable test) { + try { + test.run(); + throw new Error("NullPointerException not thrown"); + } catch (NullPointerException e) { + // expected + } + } + private void initServices() throws IOException { Path testClasses = Paths.get(System.getProperty("test.classes")); Path services = testClasses.resolve(Paths.get("META-INF", "services"));