jdk/test/sun/net/www/http/HttpClient/StreamingRetry.java
author mchung
Thu, 28 May 2015 10:54:48 -0700
changeset 30820 0d4717a011d3
parent 27759 8f9827afe8d0
permissions -rw-r--r--
8081347: Add @modules to jdk_core tests Reviewed-by: alanb, joehw, lancea Contributed-by: alexander.kulyakhtin@oracle.com, alan.bateman@oracle.com, mandy.chung@oracle.com
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
6673
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
     1
/*
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
     2
 * Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved.
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
     4
 *
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
     7
 * published by the Free Software Foundation.
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
     8
 *
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    13
 * accompanied this code).
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    14
 *
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    18
 *
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    21
 * questions.
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    22
 */
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    23
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    24
/*
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    25
 * @test
27717
9d29bef916e1 8050983: Misplaced parentheses in sun.net.www.http.HttpClient break HTTP PUT streaming
chegar
parents: 6673
diff changeset
    26
 * @bug 6672144 8050983
9d29bef916e1 8050983: Misplaced parentheses in sun.net.www.http.HttpClient break HTTP PUT streaming
chegar
parents: 6673
diff changeset
    27
 * @summary Do not retry failed request with a streaming body.
6673
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    28
 */
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    29
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    30
import java.net.HttpURLConnection;
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    31
import java.net.ServerSocket;
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    32
import java.net.URL;
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    33
import java.io.IOException;
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    34
import java.io.InputStream;
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    35
import java.io.OutputStream;
27717
9d29bef916e1 8050983: Misplaced parentheses in sun.net.www.http.HttpClient break HTTP PUT streaming
chegar
parents: 6673
diff changeset
    36
import static java.lang.System.out;
6673
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    37
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    38
public class StreamingRetry implements Runnable {
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    39
    static final int ACCEPT_TIMEOUT = 20 * 1000; // 20 seconds
27759
8f9827afe8d0 8065072: sun/net/www/http/HttpClient/StreamingRetry.java failed intermittently
chegar
parents: 27717
diff changeset
    40
    volatile ServerSocket ss;
6673
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    41
27759
8f9827afe8d0 8065072: sun/net/www/http/HttpClient/StreamingRetry.java failed intermittently
chegar
parents: 27717
diff changeset
    42
    public static void main(String[] args) throws Exception {
6673
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    43
        (new StreamingRetry()).instanceMain();
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    44
    }
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    45
27759
8f9827afe8d0 8065072: sun/net/www/http/HttpClient/StreamingRetry.java failed intermittently
chegar
parents: 27717
diff changeset
    46
    void instanceMain() throws Exception {
27717
9d29bef916e1 8050983: Misplaced parentheses in sun.net.www.http.HttpClient break HTTP PUT streaming
chegar
parents: 6673
diff changeset
    47
        out.println("Test with default method");
9d29bef916e1 8050983: Misplaced parentheses in sun.net.www.http.HttpClient break HTTP PUT streaming
chegar
parents: 6673
diff changeset
    48
        test(null);
9d29bef916e1 8050983: Misplaced parentheses in sun.net.www.http.HttpClient break HTTP PUT streaming
chegar
parents: 6673
diff changeset
    49
        out.println("Test with POST method");
9d29bef916e1 8050983: Misplaced parentheses in sun.net.www.http.HttpClient break HTTP PUT streaming
chegar
parents: 6673
diff changeset
    50
        test("POST");
9d29bef916e1 8050983: Misplaced parentheses in sun.net.www.http.HttpClient break HTTP PUT streaming
chegar
parents: 6673
diff changeset
    51
        out.println("Test with PUT method");
9d29bef916e1 8050983: Misplaced parentheses in sun.net.www.http.HttpClient break HTTP PUT streaming
chegar
parents: 6673
diff changeset
    52
        test("PUT");
9d29bef916e1 8050983: Misplaced parentheses in sun.net.www.http.HttpClient break HTTP PUT streaming
chegar
parents: 6673
diff changeset
    53
6673
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    54
        if (failed > 0) throw new RuntimeException("Some tests failed");
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    55
    }
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    56
27759
8f9827afe8d0 8065072: sun/net/www/http/HttpClient/StreamingRetry.java failed intermittently
chegar
parents: 27717
diff changeset
    57
    void test(String method) throws Exception {
6673
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    58
        ss = new ServerSocket(0);
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    59
        ss.setSoTimeout(ACCEPT_TIMEOUT);
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    60
        int port = ss.getLocalPort();
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    61
27759
8f9827afe8d0 8065072: sun/net/www/http/HttpClient/StreamingRetry.java failed intermittently
chegar
parents: 27717
diff changeset
    62
        Thread otherThread = new Thread(this);
8f9827afe8d0 8065072: sun/net/www/http/HttpClient/StreamingRetry.java failed intermittently
chegar
parents: 27717
diff changeset
    63
        otherThread.start();
6673
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    64
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    65
        try {
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    66
            URL url = new URL("http://localhost:" + port + "/");
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    67
            HttpURLConnection uc = (HttpURLConnection) url.openConnection();
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    68
            uc.setDoOutput(true);
27717
9d29bef916e1 8050983: Misplaced parentheses in sun.net.www.http.HttpClient break HTTP PUT streaming
chegar
parents: 6673
diff changeset
    69
            if (method != null)
9d29bef916e1 8050983: Misplaced parentheses in sun.net.www.http.HttpClient break HTTP PUT streaming
chegar
parents: 6673
diff changeset
    70
                uc.setRequestMethod(method);
6673
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    71
            uc.setChunkedStreamingMode(4096);
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    72
            OutputStream os = uc.getOutputStream();
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    73
            os.write("Hello there".getBytes());
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    74
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    75
            InputStream is = uc.getInputStream();
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    76
            is.close();
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    77
        } catch (IOException expected) {
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    78
            //expected.printStackTrace();
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    79
        } finally {
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    80
            ss.close();
27759
8f9827afe8d0 8065072: sun/net/www/http/HttpClient/StreamingRetry.java failed intermittently
chegar
parents: 27717
diff changeset
    81
            otherThread.join();
6673
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    82
        }
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    83
    }
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    84
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    85
    // Server
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    86
    public void run() {
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    87
        try {
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    88
            (ss.accept()).close();
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    89
            (ss.accept()).close();
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    90
            ss.close();
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    91
            fail("The server shouldn't accept a second connection");
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    92
         } catch (IOException e) {
27717
9d29bef916e1 8050983: Misplaced parentheses in sun.net.www.http.HttpClient break HTTP PUT streaming
chegar
parents: 6673
diff changeset
    93
            //OK, the client will close the server socket if successful
6673
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    94
        }
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    95
    }
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    96
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    97
    volatile int failed = 0;
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    98
    void fail() {failed++; Thread.dumpStack();}
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
    99
    void fail(String msg) {System.err.println(msg); fail();}
3674dbc66612 6672144: HttpURLConnection.getInputStream sends POST request after failed chunked
chegar
parents:
diff changeset
   100
}