test/jdk/java/util/spi/ToolProviderTest.java
author lancea
Tue, 26 Feb 2019 13:14:26 -0500
changeset 53927 03924ad3f4d0
parent 47216 71c04702a3d5
permissions -rw-r--r--
8219548: Better Null paramenter checking in ToolProvider Reviewed-by: lancea, alanb, jjg Contributed-by: Philipp Kunz <philipp.kunz@paratix.ch>
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
41376
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
     1
/*
53927
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
     2
 * Copyright (c) 2016, 2019, Oracle and/or its affiliates. All rights reserved.
41376
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
     4
 *
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
     7
 * published by the Free Software Foundation.
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
     8
 *
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    13
 * accompanied this code).
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    14
 *
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    18
 *
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    21
 * questions.
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    22
 */
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    23
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    24
/*
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    25
 * @test
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    26
 * @bug 8159855
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    27
 * @summary test ToolProvider SPI
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    28
 * @run main/othervm ToolProviderTest
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    29
 */
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    30
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    31
import java.io.IOException;
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    32
import java.io.PrintWriter;
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    33
import java.nio.file.Files;
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    34
import java.nio.file.Path;
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    35
import java.nio.file.Paths;
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    36
import java.util.Arrays;
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    37
import java.util.spi.ToolProvider;
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    38
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    39
public class ToolProviderTest {
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    40
    public static void main(String... args) throws Exception {
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    41
        ToolProviderTest t = new ToolProviderTest();
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    42
        t.run();
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    43
    }
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    44
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    45
    void run() throws Exception {
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    46
        initServices();
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    47
53927
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    48
        System.out.println("Validate an NPE is thrown with null arguments");
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    49
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    50
        testNullArgs();
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    51
41376
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    52
        System.out.println("test without security manager present:");
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    53
        test();
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    54
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    55
        System.setSecurityManager(new SecurityManager());
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    56
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    57
        System.out.println("test with security manager present:");
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    58
        test();
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    59
    }
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    60
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    61
    private void test() throws Exception {
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    62
        ToolProvider testProvider = ToolProvider.findFirst("test").get();
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    63
        int rc = testProvider.run(System.out, System.err, "hello test");
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    64
        if (rc != 0) {
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    65
            throw new Exception("unexpected exit code: " + rc);
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    66
        }
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    67
    }
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    68
53927
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    69
    private void testNullArgs() {
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    70
        ToolProvider testProvider = ToolProvider.findFirst("test").get();
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    71
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    72
        // out null check
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    73
        expectNullPointerException(() -> testProvider.run(null, System.err));
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    74
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    75
        // err null check
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    76
        expectNullPointerException(() -> testProvider.run(System.out, null));
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    77
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    78
        // args array null check
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    79
        expectNullPointerException(() ->
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    80
                testProvider.run(System.out, System.err, (String[]) null));
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    81
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    82
        // args array elements null check
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    83
        expectNullPointerException(() ->
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    84
                testProvider.run(System.out, System.err, (String) null));
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    85
    }
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    86
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    87
    private static void expectNullPointerException(Runnable test) {
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    88
        try {
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    89
            test.run();
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    90
            throw new Error("NullPointerException not thrown");
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    91
        } catch (NullPointerException e) {
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    92
            // expected
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    93
        }
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    94
    }
03924ad3f4d0 8219548: Better Null paramenter checking in ToolProvider
lancea
parents: 47216
diff changeset
    95
41376
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    96
    private void initServices() throws IOException {
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    97
        Path testClasses = Paths.get(System.getProperty("test.classes"));
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    98
        Path services = testClasses.resolve(Paths.get("META-INF", "services"));
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
    99
        Files.createDirectories(services);
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   100
        Files.write(services.resolve(ToolProvider.class.getName()),
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   101
                Arrays.asList(TestProvider.class.getName()));
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   102
    }
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   103
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   104
    public static class TestProvider implements ToolProvider {
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   105
        public TestProvider() {
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   106
            checkPrivileges();
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   107
        }
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   108
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   109
        public String name() {
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   110
            return "test";
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   111
        }
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   112
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   113
        public int run(PrintWriter out, PrintWriter err, String... args) {
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   114
            out.println("Test: " + Arrays.toString(args));
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   115
            return 0;
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   116
        }
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   117
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   118
        private void checkPrivileges() {
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   119
            boolean haveSecurityManager = (System.getSecurityManager() != null);
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   120
            try {
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   121
                // validate appropriate privileges by checking access to a
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   122
                // system property
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   123
                System.getProperty("java.home");
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   124
                if (haveSecurityManager) {
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   125
                    throw new Error("exception exception not thrown");
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   126
                }
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   127
            } catch (SecurityException e) {
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   128
                if (!haveSecurityManager) {
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   129
                    throw new Error("unexpected exception: " + e);
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   130
                }
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   131
            }
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   132
        }
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   133
    }
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   134
}
0908484888a7 8159855: Create an SPI for tools
jjg
parents:
diff changeset
   135