test/jdk/java/net/httpclient/websocket/security/WSURLPermissionTest.java
author chegar
Sun, 05 Nov 2017 21:19:55 +0000
branchhttp-client-branch
changeset 55764 34d7cc00f87a
child 55838 12a64276cc96
permissions -rw-r--r--
http-client-branch: WebSocket permission checks, test updates, and more
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
55764
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
     1
/*
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
     2
 * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved.
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
     4
 *
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
     7
 * published by the Free Software Foundation.
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
     8
 *
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    13
 * accompanied this code).
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    14
 *
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    18
 *
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    21
 * questions.
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    22
 */
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    23
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    24
/*
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    25
 * @test
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    26
 * @summary Basic security checks for WebSocket URI from the Builder
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    27
 * @compile ../DummyWebSocketServer.java ../../ProxyServer.java
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    28
 * @run testng/othervm/java.security.policy=httpclient.policy WSURLPermissionTest
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    29
 */
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    30
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    31
import java.io.IOException;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    32
import java.net.InetSocketAddress;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    33
import java.net.Proxy;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    34
import java.net.ProxySelector;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    35
import java.net.SocketAddress;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    36
import java.net.URI;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    37
import java.net.URLPermission;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    38
import java.security.AccessControlContext;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    39
import java.security.AccessController;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    40
import java.security.Permission;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    41
import java.security.Permissions;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    42
import java.security.PrivilegedActionException;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    43
import java.security.PrivilegedExceptionAction;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    44
import java.security.ProtectionDomain;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    45
import java.util.List;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    46
import java.util.concurrent.ExecutionException;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    47
import jdk.incubator.http.HttpClient;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    48
import jdk.incubator.http.WebSocket;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    49
import org.testng.annotations.AfterTest;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    50
import org.testng.annotations.BeforeTest;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    51
import org.testng.annotations.DataProvider;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    52
import org.testng.annotations.Test;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    53
import static org.testng.Assert.*;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    54
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    55
public class WSURLPermissionTest {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    56
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    57
    static AccessControlContext withPermissions(Permission... perms) {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    58
        Permissions p = new Permissions();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    59
        for (Permission perm : perms) {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    60
            p.add(perm);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    61
        }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    62
        ProtectionDomain pd = new ProtectionDomain(null, p);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    63
        return new AccessControlContext(new ProtectionDomain[]{ pd });
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    64
    }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    65
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    66
    static AccessControlContext noPermissions() {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    67
        return withPermissions(/*empty*/);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    68
    }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    69
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    70
    URI wsURI;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    71
    DummyWebSocketServer webSocketServer;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    72
    InetSocketAddress proxyAddress;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    73
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    74
    @BeforeTest
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    75
    public void setup() throws Exception {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    76
        ProxyServer proxyServer = new ProxyServer(0, true);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    77
        proxyAddress = new InetSocketAddress("127.0.0.1", proxyServer.getPort());
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    78
        webSocketServer = new DummyWebSocketServer();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    79
        webSocketServer.open();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    80
        wsURI = webSocketServer.getURI();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    81
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    82
        System.out.println("Proxy Server: " + proxyAddress);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    83
        System.out.println("DummyWebSocketServer: " + wsURI);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    84
    }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    85
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    86
    @AfterTest
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    87
    public void teardown() {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    88
        webSocketServer.close();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    89
    }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    90
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    91
    static class NoOpListener implements WebSocket.Listener {}
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    92
    static final WebSocket.Listener noOpListener = new NoOpListener();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    93
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    94
    @DataProvider(name = "passingScenarios")
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    95
    public Object[][] passingScenarios() {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    96
        HttpClient noProxyClient = HttpClient.newHttpClient();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    97
        return new Object[][]{
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    98
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
    99
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   100
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   101
                 return null; },                                       // no actions
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   102
              new URLPermission[] { new URLPermission(wsURI.toString()) },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   103
              "0"  /* for log file identification */ },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   104
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   105
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   106
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   107
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   108
                 return null; },                                       // scheme wildcard
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   109
              new URLPermission[] { new URLPermission("ws://*") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   110
              "0.1" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   111
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   112
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   113
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   114
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   115
                 return null; },                                       // port wildcard
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   116
              new URLPermission[] { new URLPermission("ws://"+wsURI.getHost()+":*") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   117
              "0.2" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   118
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   119
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   120
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   121
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   122
                 return null; },                                        // empty actions
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   123
              new URLPermission[] { new URLPermission(wsURI.toString(), "") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   124
              "1" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   125
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   126
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   127
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   128
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   129
                 return null; },                                         // colon
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   130
              new URLPermission[] { new URLPermission(wsURI.toString(), ":") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   131
              "2" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   132
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   133
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   134
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   135
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   136
                 return null; },                                        // wildcard
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   137
              new URLPermission[] { new URLPermission(wsURI.toString(), "*:*") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   138
              "3" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   139
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   140
            // WS permission checking is agnostic of method, any/none will do
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   141
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   142
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   143
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   144
                 return null; },                                        // specific method
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   145
              new URLPermission[] { new URLPermission(wsURI.toString(), "GET") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   146
              "3.1" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   147
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   148
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   149
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   150
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   151
                 return null; },                                        // specific method
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   152
              new URLPermission[] { new URLPermission(wsURI.toString(), "POST") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   153
              "3.2" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   154
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   155
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   156
                URI uriWithPath = wsURI.resolve("/path/x");
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   157
                 noProxyClient.newWebSocketBuilder(uriWithPath, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   158
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   159
                 return null; },                                       // path
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   160
              new URLPermission[] { new URLPermission(wsURI.resolve("/path/x").toString()) },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   161
              "4" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   162
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   163
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   164
                URI uriWithPath = wsURI.resolve("/path/x");
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   165
                 noProxyClient.newWebSocketBuilder(uriWithPath, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   166
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   167
                 return null; },                                       // same dir wildcard
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   168
              new URLPermission[] { new URLPermission(wsURI.resolve("/path/*").toString()) },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   169
              "5" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   170
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   171
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   172
                URI uriWithPath = wsURI.resolve("/path/x");
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   173
                 noProxyClient.newWebSocketBuilder(uriWithPath, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   174
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   175
                 return null; },                                       // recursive
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   176
              new URLPermission[] { new URLPermission(wsURI.resolve("/path/-").toString()) },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   177
              "6" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   178
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   179
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   180
                URI uriWithPath = wsURI.resolve("/path/x");
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   181
                 noProxyClient.newWebSocketBuilder(uriWithPath, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   182
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   183
                 return null; },                                       // recursive top
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   184
              new URLPermission[] { new URLPermission(wsURI.resolve("/-").toString()) },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   185
              "7" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   186
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   187
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   188
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   189
                              .header("A-Header", "A-Value")  // header
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   190
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   191
                 return null; },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   192
              new URLPermission[] { new URLPermission(wsURI.toString(), ":A-Header") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   193
              "8" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   194
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   195
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   196
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   197
                              .header("A-Header", "A-Value")  // header
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   198
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   199
                 return null; },                                        // wildcard
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   200
              new URLPermission[] { new URLPermission(wsURI.toString(), ":*") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   201
              "9" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   202
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   203
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   204
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   205
                              .header("A-Header", "A-Value")  // headers
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   206
                              .header("B-Header", "B-Value")  // headers
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   207
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   208
                 return null; },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   209
              new URLPermission[] { new URLPermission(wsURI.toString(), ":A-Header,B-Header") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   210
              "10" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   211
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   212
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   213
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   214
                              .header("A-Header", "A-Value")  // headers
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   215
                              .header("B-Header", "B-Value")  // headers
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   216
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   217
                 return null; },                                        // wildcard
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   218
              new URLPermission[] { new URLPermission(wsURI.toString(), ":*") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   219
              "11" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   220
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   221
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   222
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   223
                              .header("A-Header", "A-Value")  // headers
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   224
                              .header("B-Header", "B-Value")  // headers
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   225
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   226
                 return null; },                                        // wildcards
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   227
              new URLPermission[] { new URLPermission(wsURI.toString(), "*:*") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   228
              "12" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   229
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   230
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   231
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   232
                              .header("A-Header", "A-Value")  // multi-value
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   233
                              .header("A-Header", "B-Value")  // headers
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   234
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   235
                 return null; },                                        // wildcard
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   236
              new URLPermission[] { new URLPermission(wsURI.toString(), ":*") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   237
              "13" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   238
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   239
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   240
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   241
                              .header("A-Header", "A-Value")  // multi-value
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   242
                              .header("A-Header", "B-Value")  // headers
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   243
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   244
                 return null; },                                        // single grant
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   245
              new URLPermission[] { new URLPermission(wsURI.toString(), ":A-Header") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   246
              "14" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   247
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   248
            // client with a DIRECT proxy
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   249
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   250
                 ProxySelector ps = ProxySelector.of(null);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   251
                 HttpClient client = HttpClient.newBuilder().proxy(ps).build();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   252
                 client.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   253
                       .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   254
                 return null; },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   255
              new URLPermission[] { new URLPermission(wsURI.toString()) },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   256
              "15" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   257
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   258
            // client with a SOCKS proxy! ( expect implementation to ignore SOCKS )
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   259
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   260
                 ProxySelector ps = new ProxySelector() {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   261
                     @Override public List<Proxy> select(URI uri) {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   262
                         return List.of(new Proxy(Proxy.Type.SOCKS, proxyAddress)); }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   263
                     @Override
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   264
                     public void connectFailed(URI uri, SocketAddress sa, IOException ioe) { }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   265
                 };
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   266
                 HttpClient client = HttpClient.newBuilder().proxy(ps).build();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   267
                 client.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   268
                       .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   269
                 return null; },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   270
              new URLPermission[] { new URLPermission(wsURI.toString()) },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   271
              "16" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   272
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   273
            // client with a HTTP/HTTPS proxy
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   274
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   275
                 assert proxyAddress != null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   276
                 ProxySelector ps = ProxySelector.of(proxyAddress);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   277
                 HttpClient client = HttpClient.newBuilder().proxy(ps).build();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   278
                 client.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   279
                       .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   280
                 return null; },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   281
              new URLPermission[] {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   282
                    new URLPermission(wsURI.toString()),            // CONNECT action string
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   283
                    new URLPermission("socket://"+proxyAddress.getHostName()
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   284
                                      +":"+proxyAddress.getPort(), "CONNECT")},
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   285
              "17" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   286
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   287
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   288
                 assert proxyAddress != null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   289
                 ProxySelector ps = ProxySelector.of(proxyAddress);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   290
                 HttpClient client = HttpClient.newBuilder().proxy(ps).build();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   291
                 client.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   292
                       .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   293
                 return null; },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   294
              new URLPermission[] {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   295
                    new URLPermission(wsURI.toString()),            // no action string
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   296
                    new URLPermission("socket://"+proxyAddress.getHostName()
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   297
                                      +":"+proxyAddress.getPort())},
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   298
              "18" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   299
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   300
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   301
                 assert proxyAddress != null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   302
                 ProxySelector ps = ProxySelector.of(proxyAddress);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   303
                 HttpClient client = HttpClient.newBuilder().proxy(ps).build();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   304
                 client.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   305
                       .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   306
                 return null; },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   307
              new URLPermission[] {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   308
                    new URLPermission(wsURI.toString()),            // wildcard headers
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   309
                    new URLPermission("socket://"+proxyAddress.getHostName()
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   310
                                      +":"+proxyAddress.getPort(), "CONNECT:*")},
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   311
              "19" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   312
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   313
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   314
                 assert proxyAddress != null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   315
                 CountingProxySelector ps = CountingProxySelector.of(proxyAddress);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   316
                 HttpClient client = HttpClient.newBuilder().proxy(ps).build();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   317
                 client.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   318
                       .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   319
                 assertEquals(ps.count(), 1);  // ps.select only invoked once
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   320
                 return null; },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   321
              new URLPermission[] {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   322
                    new URLPermission(wsURI.toString()),            // empty headers
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   323
                    new URLPermission("socket://"+proxyAddress.getHostName()
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   324
                                      +":"+proxyAddress.getPort(), "CONNECT:")},
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   325
              "20" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   326
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   327
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   328
                 assert proxyAddress != null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   329
                 ProxySelector ps = ProxySelector.of(proxyAddress);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   330
                 HttpClient client = HttpClient.newBuilder().proxy(ps).build();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   331
                 client.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   332
                       .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   333
                 return null; },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   334
              new URLPermission[] {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   335
                    new URLPermission(wsURI.toString()),
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   336
                    new URLPermission("socket://*")},               // wildcard socket URL
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   337
              "21" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   338
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   339
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   340
                 assert proxyAddress != null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   341
                 ProxySelector ps = ProxySelector.of(proxyAddress);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   342
                 HttpClient client = HttpClient.newBuilder().proxy(ps).build();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   343
                 client.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   344
                       .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   345
                 return null; },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   346
              new URLPermission[] {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   347
                    new URLPermission("ws://*"),                    // wildcard ws URL
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   348
                    new URLPermission("socket://*")},               // wildcard socket URL
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   349
              "22" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   350
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   351
        };
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   352
    }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   353
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   354
    @Test(dataProvider = "passingScenarios")
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   355
    public void testWithNoSecurityManager(PrivilegedExceptionAction<?> action,
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   356
                                          URLPermission[] unused,
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   357
                                          String dataProviderId)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   358
        throws Exception
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   359
    {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   360
        // sanity ( no security manager )
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   361
        System.setSecurityManager(null);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   362
        try {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   363
            AccessController.doPrivileged(action);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   364
        } finally {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   365
            System.setSecurityManager(new SecurityManager());
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   366
        }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   367
    }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   368
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   369
    @Test(dataProvider = "passingScenarios")
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   370
    public void testWithAllPermissions(PrivilegedExceptionAction<?> action,
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   371
                                       URLPermission[] unused,
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   372
                                       String dataProviderId)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   373
        throws Exception
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   374
    {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   375
        // Run with all permissions, i.e. no further restrictions than test's AllPermission
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   376
        assert System.getSecurityManager() != null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   377
        AccessController.doPrivileged(action);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   378
    }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   379
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   380
    @Test(dataProvider = "passingScenarios")
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   381
    public void testWithMinimalPermissions(PrivilegedExceptionAction<?> action,
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   382
                                           URLPermission[] perms,
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   383
                                           String dataProviderId)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   384
        throws Exception
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   385
    {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   386
        // Run with minimal permissions, i.e. just what is required
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   387
        assert System.getSecurityManager() != null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   388
        AccessControlContext minimalACC = withPermissions(perms);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   389
        AccessController.doPrivileged(action, minimalACC);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   390
    }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   391
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   392
    @Test(dataProvider = "passingScenarios")
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   393
    public void testWithNoPermissions(PrivilegedExceptionAction<?> action,
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   394
                                      URLPermission[] unused,
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   395
                                      String dataProviderId)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   396
        throws Exception
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   397
    {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   398
        // Run with NO permissions, i.e. expect SecurityException
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   399
        assert System.getSecurityManager() != null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   400
        try {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   401
            AccessController.doPrivileged(action, noPermissions());
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   402
            fail("EXPECTED SecurityException");
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   403
        } catch (PrivilegedActionException expected) {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   404
            Throwable t = expected.getCause();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   405
            if (t instanceof ExecutionException)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   406
                t = t.getCause();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   407
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   408
            if (t instanceof SecurityException)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   409
                System.out.println("Caught expected SE:" + expected);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   410
            else
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   411
                fail("Expected SecurityException, but got: " + t);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   412
        }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   413
    }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   414
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   415
    // --- Negative tests ---
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   416
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   417
    @DataProvider(name = "failingScenarios")
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   418
    public Object[][] failingScenarios() {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   419
        HttpClient noProxyClient = HttpClient.newHttpClient();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   420
        return new Object[][]{
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   421
            { (PrivilegedExceptionAction<?>) () -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   422
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   423
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   424
                 return null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   425
              },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   426
              new URLPermission[]{ /* no permissions */ },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   427
              "50"  /* for log file identification */},
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   428
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   429
            { (PrivilegedExceptionAction<?>) () -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   430
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   431
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   432
                 return null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   433
              },                                        // wrong scheme
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   434
              new URLPermission[]{ new URLPermission("http://*") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   435
              "51" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   436
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   437
            { (PrivilegedExceptionAction<?>) () -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   438
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   439
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   440
                 return null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   441
              },                                        // wrong scheme
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   442
              new URLPermission[]{ new URLPermission("socket://*") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   443
              "52" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   444
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   445
            { (PrivilegedExceptionAction<?>) () -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   446
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   447
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   448
                 return null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   449
              },                                        // wrong host
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   450
              new URLPermission[]{ new URLPermission("ws://foo.com/") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   451
              "53" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   452
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   453
            { (PrivilegedExceptionAction<?>) () -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   454
                 noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   455
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   456
                 return null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   457
              },                                        // wrong port
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   458
              new URLPermission[]{ new URLPermission("ws://"+ wsURI.getHost()+":5") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   459
              "54" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   460
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   461
            { (PrivilegedExceptionAction<?>) () -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   462
                  noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   463
                               .header("A-Header", "A-Value")
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   464
                               .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   465
                  return null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   466
              },                                                    // only perm to set B not A
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   467
              new URLPermission[] { new URLPermission(wsURI.toString(), "*:B-Header") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   468
              "55" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   469
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   470
            { (PrivilegedExceptionAction<?>) () -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   471
                  noProxyClient.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   472
                               .header("A-Header", "A-Value")
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   473
                               .header("B-Header", "B-Value")
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   474
                               .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   475
                  return null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   476
              },                                                    // only perm to set B not A
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   477
              new URLPermission[] { new URLPermission(wsURI.toString(), "*:B-Header") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   478
              "56" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   479
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   480
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   481
                URI uriWithPath = wsURI.resolve("/path/x");
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   482
                 noProxyClient.newWebSocketBuilder(uriWithPath, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   483
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   484
                 return null; },                                    // wrong path
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   485
              new URLPermission[] { new URLPermission(wsURI.resolve("/aDiffPath/").toString()) },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   486
              "57" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   487
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   488
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   489
                URI uriWithPath = wsURI.resolve("/path/x");
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   490
                 noProxyClient.newWebSocketBuilder(uriWithPath, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   491
                              .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   492
                 return null; },                                    // more specific path
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   493
              new URLPermission[] { new URLPermission(wsURI.resolve("/path/x/y").toString()) },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   494
              "58" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   495
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   496
            // client with a HTTP/HTTPS proxy
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   497
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   498
                 assert proxyAddress != null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   499
                 ProxySelector ps = ProxySelector.of(proxyAddress);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   500
                 HttpClient client = HttpClient.newBuilder().proxy(ps).build();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   501
                 client.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   502
                       .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   503
                 return null; },                                    // missing proxy perm
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   504
              new URLPermission[] { new URLPermission(wsURI.toString()) },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   505
              "100" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   506
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   507
            // client with a HTTP/HTTPS proxy
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   508
            { (PrivilegedExceptionAction<?>)() -> {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   509
                 assert proxyAddress != null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   510
                 ProxySelector ps = ProxySelector.of(proxyAddress);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   511
                 HttpClient client = HttpClient.newBuilder().proxy(ps).build();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   512
                 client.newWebSocketBuilder(wsURI, noOpListener)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   513
                       .buildAsync().get().abort();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   514
                 return null; },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   515
              new URLPermission[] {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   516
                    new URLPermission(wsURI.toString()),            // missing proxy CONNECT
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   517
                    new URLPermission("socket://*", "GET") },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   518
              "101" },
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   519
        };
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   520
    }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   521
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   522
    @Test(dataProvider = "failingScenarios")
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   523
    public void testWithoutEnoughPermissions(PrivilegedExceptionAction<?> action,
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   524
                                             URLPermission[] perms,
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   525
                                             String dataProviderId)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   526
        throws Exception
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   527
    {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   528
        // Run without Enough permissions, i.e. expect SecurityException
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   529
        assert System.getSecurityManager() != null;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   530
        AccessControlContext notEnoughPermsACC = withPermissions(perms);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   531
        try {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   532
            AccessController.doPrivileged(action, notEnoughPermsACC);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   533
            fail("EXPECTED SecurityException");
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   534
        } catch (PrivilegedActionException expected) {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   535
            Throwable t = expected.getCause();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   536
            if (t instanceof ExecutionException)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   537
                t = t.getCause();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   538
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   539
            if (t instanceof SecurityException)
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   540
                System.out.println("Caught expected SE:" + expected);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   541
            else
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   542
                fail("Expected SecurityException, but got: " + t);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   543
        }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   544
    }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   545
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   546
    /**
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   547
     * A Proxy Selector that wraps a ProxySelector.of(), and counts the number
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   548
     * of times its select method has been invoked. This can be used to ensure
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   549
     * that the Proxy Selector is invoked only once per WebSocket.Builder::buildAsync
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   550
     * invocation.
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   551
     */
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   552
    static class CountingProxySelector extends ProxySelector {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   553
        private final ProxySelector proxySelector;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   554
        private volatile int count; // 0
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   555
        private CountingProxySelector(InetSocketAddress proxyAddress) {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   556
            proxySelector = ProxySelector.of(proxyAddress);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   557
        }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   558
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   559
        public static CountingProxySelector of(InetSocketAddress proxyAddress) {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   560
            return new CountingProxySelector(proxyAddress);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   561
        }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   562
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   563
        int count() { return count; }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   564
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   565
        @Override
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   566
        public List<Proxy> select(URI uri) {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   567
            System.out.println("PS: uri");
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   568
            Throwable t = new Throwable();
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   569
            t.printStackTrace(System.out);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   570
            count++;
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   571
            return proxySelector.select(uri);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   572
        }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   573
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   574
        @Override
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   575
        public void connectFailed(URI uri, SocketAddress sa, IOException ioe) {
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   576
            proxySelector.connectFailed(uri, sa, ioe);
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   577
        }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   578
    }
34d7cc00f87a http-client-branch: WebSocket permission checks, test updates, and more
chegar
parents:
diff changeset
   579
}