jdk/test/java/net/URLConnection/DisconnectAfterEOF.java
author duke
Sat, 01 Dec 2007 00:00:00 +0000
changeset 2 90ce3da70b43
child 5506 202f599c92aa
permissions -rw-r--r--
Initial load
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     1
/*
90ce3da70b43 Initial load
duke
parents:
diff changeset
     2
 * Copyright 2002 Sun Microsystems, Inc.  All Rights Reserved.
90ce3da70b43 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
90ce3da70b43 Initial load
duke
parents:
diff changeset
     4
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
90ce3da70b43 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
90ce3da70b43 Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.
90ce3da70b43 Initial load
duke
parents:
diff changeset
     8
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
90ce3da70b43 Initial load
duke
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
90ce3da70b43 Initial load
duke
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
90ce3da70b43 Initial load
duke
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
90ce3da70b43 Initial load
duke
parents:
diff changeset
    13
 * accompanied this code).
90ce3da70b43 Initial load
duke
parents:
diff changeset
    14
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
90ce3da70b43 Initial load
duke
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    18
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    19
 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    20
 * CA 95054 USA or visit www.sun.com if you need additional information or
90ce3da70b43 Initial load
duke
parents:
diff changeset
    21
 * have any questions.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    22
 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    23
90ce3da70b43 Initial load
duke
parents:
diff changeset
    24
/**
90ce3da70b43 Initial load
duke
parents:
diff changeset
    25
 * @test
90ce3da70b43 Initial load
duke
parents:
diff changeset
    26
 * @bug 4774503
90ce3da70b43 Initial load
duke
parents:
diff changeset
    27
 * @summary Calling HttpURLConnection's disconnect method after the
90ce3da70b43 Initial load
duke
parents:
diff changeset
    28
 *          response has been received causes havoc with persistent
90ce3da70b43 Initial load
duke
parents:
diff changeset
    29
 *          connections.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    30
 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    31
import java.net.*;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    32
import java.io.*;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    33
import java.util.*;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    34
90ce3da70b43 Initial load
duke
parents:
diff changeset
    35
public class DisconnectAfterEOF {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    36
90ce3da70b43 Initial load
duke
parents:
diff changeset
    37
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
    38
     * Worker thread to service single connection - can service
90ce3da70b43 Initial load
duke
parents:
diff changeset
    39
     * multiple http requests on same connection.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    40
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    41
    static class Worker extends Thread {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    42
        Socket s;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    43
90ce3da70b43 Initial load
duke
parents:
diff changeset
    44
        Worker(Socket s) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    45
            this.s = s;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    46
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    47
90ce3da70b43 Initial load
duke
parents:
diff changeset
    48
        public void run() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    49
            try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    50
                InputStream in = s.getInputStream();
90ce3da70b43 Initial load
duke
parents:
diff changeset
    51
                PrintStream out = new PrintStream(
90ce3da70b43 Initial load
duke
parents:
diff changeset
    52
                                        new BufferedOutputStream(
90ce3da70b43 Initial load
duke
parents:
diff changeset
    53
                                                s.getOutputStream() ));
90ce3da70b43 Initial load
duke
parents:
diff changeset
    54
                byte b[] = new byte[1024];
90ce3da70b43 Initial load
duke
parents:
diff changeset
    55
                int n = -1;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    56
                int cl = -1;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    57
                int remaining = -1;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    58
                StringBuffer sb = new StringBuffer();
90ce3da70b43 Initial load
duke
parents:
diff changeset
    59
                Random r = new Random();
90ce3da70b43 Initial load
duke
parents:
diff changeset
    60
                boolean close = false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    61
90ce3da70b43 Initial load
duke
parents:
diff changeset
    62
                boolean inBody = false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    63
                for (;;) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    64
                    boolean sendResponse = false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    65
90ce3da70b43 Initial load
duke
parents:
diff changeset
    66
                    try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    67
                        n = in.read(b);
90ce3da70b43 Initial load
duke
parents:
diff changeset
    68
                    } catch (IOException ioe) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    69
                        n = -1;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    70
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    71
                    if (n <= 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    72
                        if (inBody) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    73
                            System.err.println("ERROR: Client closed before before " +
90ce3da70b43 Initial load
duke
parents:
diff changeset
    74
                                "entire request received.");
90ce3da70b43 Initial load
duke
parents:
diff changeset
    75
                        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    76
                        return;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    77
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    78
90ce3da70b43 Initial load
duke
parents:
diff changeset
    79
                    // reading entity-body
90ce3da70b43 Initial load
duke
parents:
diff changeset
    80
                    if (inBody) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    81
                        if (n > remaining) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    82
                            System.err.println("Receiving more than expected!!!");
90ce3da70b43 Initial load
duke
parents:
diff changeset
    83
                            return;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    84
                        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    85
                        remaining -= n;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    86
90ce3da70b43 Initial load
duke
parents:
diff changeset
    87
                        if (remaining == 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    88
                            sendResponse = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    89
                            n = 0;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    90
                        } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    91
                            continue;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    92
                        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    93
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    94
90ce3da70b43 Initial load
duke
parents:
diff changeset
    95
                    // reading headers
90ce3da70b43 Initial load
duke
parents:
diff changeset
    96
                    for (int i=0; i<n; i++) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    97
                        char c = (char)b[i];
90ce3da70b43 Initial load
duke
parents:
diff changeset
    98
90ce3da70b43 Initial load
duke
parents:
diff changeset
    99
                        if (c != '\n') {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   100
                            sb.append(c);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   101
                            continue;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   102
                        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   103
90ce3da70b43 Initial load
duke
parents:
diff changeset
   104
90ce3da70b43 Initial load
duke
parents:
diff changeset
   105
                        // Got end-of-line
90ce3da70b43 Initial load
duke
parents:
diff changeset
   106
                        int len = sb.length();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   107
                        if (len > 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   108
                            if (sb.charAt(len-1) != '\r') {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   109
                                System.err.println("Unexpected CR in header!!");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   110
                                return;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   111
                            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   112
                        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   113
                        sb.setLength(len-1);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   114
90ce3da70b43 Initial load
duke
parents:
diff changeset
   115
                        // empty line
90ce3da70b43 Initial load
duke
parents:
diff changeset
   116
                        if (sb.length() == 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   117
                            if (cl < 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   118
                                System.err.println("Content-Length not found!!!");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   119
                                return;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   120
                            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   121
90ce3da70b43 Initial load
duke
parents:
diff changeset
   122
                            // the surplus is body data
90ce3da70b43 Initial load
duke
parents:
diff changeset
   123
                            int dataRead = n - (i+1);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   124
                            remaining = cl - dataRead;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   125
                            if (remaining > 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   126
                                inBody = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   127
                                break;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   128
                            } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   129
                                // entire body has been read
90ce3da70b43 Initial load
duke
parents:
diff changeset
   130
                                sendResponse = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   131
                            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   132
                        } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   133
                            // non-empty line - check for Content-Length
90ce3da70b43 Initial load
duke
parents:
diff changeset
   134
                            String line = sb.toString().toLowerCase();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   135
                            if (line.startsWith("content-length")) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   136
                                StringTokenizer st = new StringTokenizer(line, ":");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   137
                                st.nextToken();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   138
                                cl = Integer.parseInt(st.nextToken().trim());
90ce3da70b43 Initial load
duke
parents:
diff changeset
   139
                            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   140
                            if (line.startsWith("connection")) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   141
                                StringTokenizer st = new StringTokenizer(line, ":");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   142
                                st.nextToken();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   143
                                if (st.nextToken().trim().equals("close")) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   144
                                    close =true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   145
                                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   146
                            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   147
                        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   148
                        sb = new StringBuffer();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   149
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   150
90ce3da70b43 Initial load
duke
parents:
diff changeset
   151
90ce3da70b43 Initial load
duke
parents:
diff changeset
   152
                   if (sendResponse) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   153
                        // send a large response
90ce3da70b43 Initial load
duke
parents:
diff changeset
   154
                        int rspLen = 32000;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   155
90ce3da70b43 Initial load
duke
parents:
diff changeset
   156
                        out.print("HTTP/1.1 200 OK\r\n");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   157
                        out.print("Content-Length: " + rspLen + "\r\n");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   158
                        out.print("\r\n");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   159
90ce3da70b43 Initial load
duke
parents:
diff changeset
   160
                        if (rspLen > 0)
90ce3da70b43 Initial load
duke
parents:
diff changeset
   161
                            out.write(new byte[rspLen]);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   162
90ce3da70b43 Initial load
duke
parents:
diff changeset
   163
                        out.flush();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   164
90ce3da70b43 Initial load
duke
parents:
diff changeset
   165
                        if (close)
90ce3da70b43 Initial load
duke
parents:
diff changeset
   166
                            return;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   167
90ce3da70b43 Initial load
duke
parents:
diff changeset
   168
                        sendResponse = false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   169
                        inBody = false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   170
                        cl = -1;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   171
                   }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   172
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   173
90ce3da70b43 Initial load
duke
parents:
diff changeset
   174
            } catch (IOException ioe) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   175
            } finally {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   176
                try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   177
                    s.close();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   178
                } catch (Exception e) { }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   179
                System.out.println("+ Worker thread shutdown.");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   180
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   181
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   182
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   183
90ce3da70b43 Initial load
duke
parents:
diff changeset
   184
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   185
     * Server thread to accept connection and create worker threads
90ce3da70b43 Initial load
duke
parents:
diff changeset
   186
     * to service each connection.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   187
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   188
    static class Server extends Thread {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   189
        ServerSocket ss;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   190
90ce3da70b43 Initial load
duke
parents:
diff changeset
   191
        Server(ServerSocket ss) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   192
            this.ss = ss;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   193
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   194
90ce3da70b43 Initial load
duke
parents:
diff changeset
   195
        public void run() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   196
            try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   197
                for (;;) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   198
                    Socket s = ss.accept();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   199
                    Worker w = new Worker(s);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   200
                    w.start();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   201
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   202
90ce3da70b43 Initial load
duke
parents:
diff changeset
   203
            } catch (IOException ioe) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   204
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   205
90ce3da70b43 Initial load
duke
parents:
diff changeset
   206
            System.out.println("+ Server shutdown.");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   207
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   208
90ce3da70b43 Initial load
duke
parents:
diff changeset
   209
        public void shutdown() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   210
            try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   211
                ss.close();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   212
            } catch (IOException ioe) { }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   213
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   214
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   215
90ce3da70b43 Initial load
duke
parents:
diff changeset
   216
    static URLConnection doRequest(String uri) throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   217
        URLConnection uc = (new URL(uri)).openConnection();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   218
        uc.setDoOutput(true);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   219
        OutputStream out = uc.getOutputStream();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   220
        out.write(new byte[16000]);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   221
90ce3da70b43 Initial load
duke
parents:
diff changeset
   222
        // force the request to be sent
90ce3da70b43 Initial load
duke
parents:
diff changeset
   223
        uc.getInputStream();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   224
        return uc;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   225
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   226
90ce3da70b43 Initial load
duke
parents:
diff changeset
   227
    static URLConnection doResponse(URLConnection uc) throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   228
        int cl = ((HttpURLConnection)uc).getContentLength();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   229
        byte b[] = new byte[4096];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   230
        int n;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   231
        do {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   232
            n = uc.getInputStream().read(b);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   233
            if (n > 0) cl -= n;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   234
        } while (n > 0);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   235
        if (cl != 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   236
            throw new RuntimeException("ERROR: content-length mismatch");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   237
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   238
        return uc;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   239
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   240
90ce3da70b43 Initial load
duke
parents:
diff changeset
   241
    public static void main(String args[]) throws Exception {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   242
        Random r = new Random();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   243
90ce3da70b43 Initial load
duke
parents:
diff changeset
   244
        // start server
90ce3da70b43 Initial load
duke
parents:
diff changeset
   245
        ServerSocket ss = new ServerSocket(0);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   246
        Server svr = new Server(ss);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   247
        svr.start();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   248
90ce3da70b43 Initial load
duke
parents:
diff changeset
   249
        String uri = "http://localhost:" +
90ce3da70b43 Initial load
duke
parents:
diff changeset
   250
                     Integer.toString(ss.getLocalPort()) +
90ce3da70b43 Initial load
duke
parents:
diff changeset
   251
                     "/foo.html";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   252
90ce3da70b43 Initial load
duke
parents:
diff changeset
   253
        /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   254
         * The following is the test scenario we create here :-
90ce3da70b43 Initial load
duke
parents:
diff changeset
   255
         *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   256
         * 1. We do a http request/response and read the response
90ce3da70b43 Initial load
duke
parents:
diff changeset
   257
         *    to EOF. As it's a persistent connection the idle
90ce3da70b43 Initial load
duke
parents:
diff changeset
   258
         *    connection should go into the keep-alive cache for a
90ce3da70b43 Initial load
duke
parents:
diff changeset
   259
         *    few seconds.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   260
         *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   261
         * 2. We start a second request but don't read the response.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   262
         *    As the request is to the same server we can assume it
90ce3da70b43 Initial load
duke
parents:
diff changeset
   263
         *    (for our implementation anyway) that it will use the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   264
         *    same TCP connection.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   265
         *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   266
         * 3. We "disconnect" the first HttpURLConnection. This
90ce3da70b43 Initial load
duke
parents:
diff changeset
   267
         *    should be no-op because the connection is in use
90ce3da70b43 Initial load
duke
parents:
diff changeset
   268
         *    but another request. However with 1.3.1 and 1.4/1.4.1
90ce3da70b43 Initial load
duke
parents:
diff changeset
   269
         *    this causes the TCP connection for the second request
90ce3da70b43 Initial load
duke
parents:
diff changeset
   270
         *    to be closed.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   271
         *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   272
         */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   273
        URLConnection uc1 = doRequest(uri);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   274
        doResponse(uc1);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   275
90ce3da70b43 Initial load
duke
parents:
diff changeset
   276
        Thread.currentThread().sleep(2000);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   277
90ce3da70b43 Initial load
duke
parents:
diff changeset
   278
        URLConnection uc2 = doRequest(uri);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   279
90ce3da70b43 Initial load
duke
parents:
diff changeset
   280
        ((HttpURLConnection)uc1).disconnect();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   281
90ce3da70b43 Initial load
duke
parents:
diff changeset
   282
        IOException ioe = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   283
        try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   284
            doResponse(uc2);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   285
        } catch (IOException x) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   286
            ioe = x;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   287
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   288
90ce3da70b43 Initial load
duke
parents:
diff changeset
   289
        ((HttpURLConnection)uc2).disconnect();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   290
90ce3da70b43 Initial load
duke
parents:
diff changeset
   291
        /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   292
         * Shutdown server as we are done. Worker threads created
90ce3da70b43 Initial load
duke
parents:
diff changeset
   293
         * by the server will shutdown automatically when the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   294
         * client connection closes.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   295
         */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   296
        svr.shutdown();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   297
90ce3da70b43 Initial load
duke
parents:
diff changeset
   298
        if (ioe != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   299
            throw ioe;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   300
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   301
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   302
}