19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/*
29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Copyright (C) 2007 The Android Open Source Project
39066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
49066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
59066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you may not use this file except in compliance with the License.
69066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * You may obtain a copy of the License at
79066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
89066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
99066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Unless required by applicable law or agreed to in writing, software
119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * See the License for the specific language governing permissions and
149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * limitations under the License.
159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpackage android.core;
189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.net.http.RequestHandle;
209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.net.http.RequestQueue;
219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.test.AndroidTestCase;
229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.test.suitebuilder.annotation.Suppress;
239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.util.Log;
249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.webkit.CookieSyncManager;
259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport com.google.android.collect.Maps;
269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.io.ByteArrayInputStream;
289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.io.InputStream;
299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.util.HashMap;
309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.util.Map;
319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/**
339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Container class for all RequestAPI tests
349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project//http://b/issue?id=1200337
369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project@Suppress
379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpublic class RequestAPITest extends AndroidTestCase implements HttpConstants {
389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private static final String LOGTAG = "http";
399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /*
419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project      Other tests to write
429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project      GET, HEAD, POST with differing parameters to RequestQueue
439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project      More reuse and pipelining tests - testing for server closing unexpectedly
449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    */
459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    // Sync object for synchronizing end of each test that does communications
479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static Object syncObj = new Object();
489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private RequestQueue mRequestQueue;
509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private TestWebServer mTestWebServer;
519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    protected void setUp() throws Exception {
539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        super.setUp();
549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "Base setup context = " + mContext);
559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mRequestQueue = new RequestQueue(mContext);
569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        CookieSyncManager.createInstance(mContext);
579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTestWebServer = new TestWebServer();
599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTestWebServer.initServer(8080, true);
609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    protected void tearDown() throws Exception {
639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "Base tearDown");
649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTestWebServer.close();
659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "Base teardown done");
669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        super.tearDown();
689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void verifyFailure(Map<String, String> headers) {
719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        try {
729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            RequestHandle handle =
739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    mRequestQueue.queueRequest(
749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                            "http://localhost:8080/test1", "GET", headers, null,
75fe4fec7c66b0d956f008ead0fd899b588cfacb5dPatrick Scott                            null, 0);
769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            handle.waitUntilComplete();
789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            fail("expected exception not thrown");
799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        } catch (RuntimeException e) {
809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            // expected
819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void testRequestAddNullHeader() throws Exception {
859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Test Request.addHeader throws a NullPointerException if a null
879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * header is attempted to be set
889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testRequestAddNullHeader start ");
909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Map<String, String> headers = Maps.newHashMap();
919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        headers.put(null, null);
929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        verifyFailure(headers);
939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testRequestAddNullHeader - returning");
949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void testRequestAddNullValue() throws Exception {
979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Test Request.addHeader throws a RuntimeException if a null
999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * value is attempted to be set
1009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testRequestAddNullValue start ");
1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Map<String, String> headers = Maps.newHashMap();
1039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        headers.put("TestHeader", null);
1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        verifyFailure(headers);
1059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testRequestAddNullValue - returning");
1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void testRequestAddEmptyValue() throws Exception {
1099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Test Request.addEmptyValue throws a RuntimeException if an empty
1119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * header is attempted to be set
1129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testRequestAddEmptyValue start ");
1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Map<String, String> headers = Maps.newHashMap();
1159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        headers.put("TestHeader", "");
1169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        verifyFailure(headers);
1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testRequestAddEmptyValue - returning");
1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void verifySuccess(Map<String, String> headers) {
1219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTestWebServer.setKeepAlive(false);
1229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        RequestHandle handle = mRequestQueue.queueRequest(
1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                "http://localhost:8080/test1", "GET", headers, null,
124fe4fec7c66b0d956f008ead0fd899b588cfacb5dPatrick Scott                null, 0);
1259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        handle.waitUntilComplete();
1269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void testRequestAddHeader() throws Exception {
1299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Test Request.addHeader with a valid header and value can be set without
1319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * generating and exception
1329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testRequestAddHeader start ");
1349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Map<String, String> headers = Maps.newHashMap();
1359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        headers.put("TestHeader", "RequestAddHeader");
1369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        verifySuccess(headers);
1379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testRequestAddHeader - returning");
1389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void testRequestAddMultiHeader() throws Exception {
1419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Test multiple calls to Request.addHeader with valid headers and values
1439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * can be set without generating and exception
1449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testRequestAddMultiHeader start ");
1469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Map<String, String> headers = Maps.newHashMap();
1479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        headers.put("TestHeader", "RequestAddMultiHeader");
1489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        headers.put("TestHeader2", "RequestAddMultiHeader");
1499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        headers.put("TestHeader3", "RequestAddMultiHeader");
1509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        verifySuccess(headers);
1519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testRequestAddMultiHeader - returning");
1529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void testRequestAddSameHeader() throws Exception {
1559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Test multiple calls to Request.addHeader with valid identical headers
1579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * and values can be set without generating and exception
1589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testRequestAddSameHeader start ");
1609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Map<String, String> headers = Maps.newHashMap();
1619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        headers.put("TestHeader", "RequestAddSameHeader");
1629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        headers.put("TestHeader", "RequestAddSameHeader");
1639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        headers.put("TestHeader", "RequestAddSameHeader");
1649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        verifySuccess(headers);
1659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testRequestAddSameHeader - returning");
1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void testRequestAddNullHeaders() throws Exception {
1699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Test Request.addHeaders with a null header map. This should not generate
1719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * any exceptions but accept that there are no headers to add.
1729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testRequestAddNullHeaders start ");
1749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        verifySuccess(null);
1759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testRequestAddNullHeaders - returning");
1769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void testGet() throws Exception {
1799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Test sending a GET request. Test will pass if the events received
1819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * correspond with the expected response. This should respond with the
1829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * test data requested.
1839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        TestEventHandler testEventHandler = new TestEventHandler();
1859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTestWebServer.setKeepAlive(false);
1879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testGet start ");
1899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        // Load up expected response
1919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectStatus(200);
1929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectHeaders();
1939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectHeaderAdd(requestHeaders[REQ_CONNECTION], "Close");
1949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectHeaderAdd(requestHeaders[REQ_CONTENT_LENGTH], "52");
1959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectHeaderAdd(requestHeaders[REQ_CONTENT_TYPE], "text/html");
1969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectData(52);
1979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        RequestHandle handle = mRequestQueue.queueRequest(
1999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                "http://localhost:8080/test1", "GET", null, testEventHandler,
200fe4fec7c66b0d956f008ead0fd899b588cfacb5dPatrick Scott                null, 0);
2019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testGet - sent request. Waiting");
2039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        handle.waitUntilComplete();
2049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testGet - sent request. Notified");
2059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (!testEventHandler.expectPassed()) {
2079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Log.d(LOGTAG, testEventHandler.getFailureMessage());
2089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            fail("expectPassed was false " + testEventHandler.getFailureMessage());
2099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
2109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void testReuse() throws Exception {
2139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
2149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Test sending two GET requests. Test will pass if the events
2159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * received correspond with the expected response.
2169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
2179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        final String TEST_NAME = "testReuse";
2189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, TEST_NAME + " start ");
2199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        TestEventHandler testEventHandler = new TestEventHandler();
2219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        // Load up expected response
2239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectStatus(200);
2249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectHeaders();
2259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        TestEventHandler testEventHandler2 = new TestEventHandler();
2279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler2.expectStatus(200);
2289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler2.expectHeaders();
2299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTestWebServer.setAcceptLimit(2);
2319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        RequestHandle handle0 = mRequestQueue.queueRequest(
2339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                "http://localhost:8080/test1", "GET", null, testEventHandler,
234fe4fec7c66b0d956f008ead0fd899b588cfacb5dPatrick Scott                null, 0);
2359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        handle0.waitUntilComplete();
2369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        RequestHandle handle1 = mRequestQueue.queueRequest(
2379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                "http://localhost:8080/test1", "GET", null, testEventHandler2,
238fe4fec7c66b0d956f008ead0fd899b588cfacb5dPatrick Scott                null, 0);
2399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        handle1.waitUntilComplete();
2409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /* It's not correct to use same listener for multiple
2429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project           requests.  Otherwise there would be no distiction between
2439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project           events delivered for either request. */
2449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (!testEventHandler.expectPassed() && !testEventHandler2.expectPassed()) {
2469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Log.d(LOGTAG, testEventHandler.getFailureMessage());
2479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Log.d(LOGTAG, testEventHandler2.getFailureMessage());
2489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            fail();
2499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
2509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, TEST_NAME + " - sent request. Notified");
2519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void testHead() throws Exception {
2549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
2559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Test sending a HEAD request. Test will pass if the events
2569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * delivered match the expected response.
2579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
2589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        TestEventHandler testEventHandler = new TestEventHandler();
2599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        // Load up expected response
2619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectStatus(200);
2629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectHeaders();
2639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectNoData();
2649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTestWebServer.setKeepAlive(false);
2669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTestWebServer.setAcceptLimit(1);
2679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testHead start - rq = " + mRequestQueue);
2709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        RequestHandle handle = mRequestQueue.queueRequest(
2729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                "http://localhost:8080/test1", "HEAD", null, testEventHandler,
273fe4fec7c66b0d956f008ead0fd899b588cfacb5dPatrick Scott                null, 0);
2749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testHead - sent request waiting");
2769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        handle.waitUntilComplete();
2779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (!testEventHandler.expectPassed()) {
2799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Log.d(LOGTAG, testEventHandler.getFailureMessage());
2809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            fail("expectPassed was false " + testEventHandler.getFailureMessage());
2819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
2829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void testChunked() throws Exception {
2859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        TestEventHandler testEventHandler = new TestEventHandler();
2869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        // Load up expected response
2889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectStatus(200);
2899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectHeaders();
2909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTestWebServer.setKeepAlive(false);
2929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTestWebServer.setChunked(true);
2939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTestWebServer.setAcceptLimit(1);
2949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testChunked start - rq = " + mRequestQueue);
2979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        RequestHandle handle = mRequestQueue.queueRequest(
2999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                "http://localhost:8080/test1", "GET", null, testEventHandler,
300fe4fec7c66b0d956f008ead0fd899b588cfacb5dPatrick Scott                null, 0);
3019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testChunked - sent request waiting");
3039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        handle.waitUntilComplete();
3049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (!testEventHandler.expectPassed()) {
3069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Log.d(LOGTAG, testEventHandler.getFailureMessage());
3079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            fail("expectPassed was false " + testEventHandler.getFailureMessage());
3089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
3099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void verifyRedirect(int statusCode, String testName) throws Exception {
3129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        final String REDIRECT_TO = "http://localhost:8081/test1";
3139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTestWebServer.setKeepAlive(false);
3159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        TestWebServer redirectWebServer = new TestWebServer();
3169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        redirectWebServer.initServer(8081, true);
3179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        redirectWebServer.setKeepAlive(false);
3189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        try {
3209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            TestEventHandler testEventHandler = new TestEventHandler();
3219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            // Load up expected response
3229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            testEventHandler.expectStatus(statusCode);
3239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            testEventHandler.expectHeaders();
3249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            testEventHandler.expectHeaderAdd(requestHeaders[REQ_LOCATION], REDIRECT_TO);
3259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mTestWebServer.setAcceptLimit(1);
3279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mTestWebServer.setRedirect(REDIRECT_TO, statusCode);
3289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            redirectWebServer.setAcceptLimit(1);
3299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Log.d(LOGTAG, testName + " start - rq = " + mRequestQueue);
3319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            RequestHandle requestHandle = mRequestQueue.queueRequest(
333fe4fec7c66b0d956f008ead0fd899b588cfacb5dPatrick Scott                    "http://localhost:8080/test1", "GET", null, testEventHandler, null, 0);
3349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Log.d(LOGTAG, testName + " - sent request waiting");
3359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            requestHandle.waitUntilComplete();
3379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (!testEventHandler.expectPassed()) {
3399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                Log.d(LOGTAG, testEventHandler.getFailureMessage());
3409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                fail("expectPassed was false " + testEventHandler.getFailureMessage());
3419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
3429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            requestHandle.setupRedirect(REDIRECT_TO, statusCode, new HashMap<String, String>());
3449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            testEventHandler.expectStatus(HttpConstants.HTTP_OK);
3469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            testEventHandler.expectHeaders();
3479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            testEventHandler.expectHeaderAdd(requestHeaders[REQ_CONTENT_LENGTH], "52");
3489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            testEventHandler.expectHeaderAdd(requestHeaders[REQ_CONTENT_TYPE], "text/html");
3499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            // Server name should be TestWebServer+port
3509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            // we ignore the server tag, so don't test it
3519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            // testEventHandler.expectHeaderAdd(requestHeaders[REQ_SERVER], "TestWebServer8081");
3529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            testEventHandler.expectData(52);
3539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            testEventHandler.expectEndData();
3549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            requestHandle.waitUntilComplete();
3569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (!testEventHandler.expectPassed()) {
3589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                Log.d(LOGTAG, testEventHandler.getFailureMessage());
3599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                fail("expectPassed was false " + testEventHandler.getFailureMessage());
3609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project             }
3619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        } finally {
3629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Log.d(LOGTAG, testName + " - returning");
3639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            redirectWebServer.close();
3649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
3659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void testRedirect301() throws Exception {
3689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        verifyRedirect(HttpConstants.HTTP_MOVED_PERM, "testRedirect301");
3699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void testRedirect302() throws Exception {
3729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        verifyRedirect(HttpConstants.HTTP_MOVED_TEMP, "testRedirect302");
3739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void testRedirect303() throws Exception {
3769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        verifyRedirect(HttpConstants.HTTP_SEE_OTHER, "testRedirect303");
3779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void testRedirect307() throws Exception {
3809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        verifyRedirect(307, "testRedirect307");
3819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void testGetAndHead() throws Exception {
3849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
3859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Test sending a GET and a HEAD request. Test will pass if the
3869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * event received correspond with the expected response. The two
3879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * requests should respond the same test data.
3889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
3899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTestWebServer.setKeepAlive(true);
3909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTestWebServer.setAcceptLimit(2);
3919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        TestEventHandler testEventHandler = new TestEventHandler();
3939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectStatus(200);
3949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectHeaders();
3959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        TestEventHandler leh2 = new TestEventHandler();
3979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        leh2.expectStatus(200);
3989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        leh2.expectHeaders();
3999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        RequestHandle handle0 = mRequestQueue.queueRequest(
401fe4fec7c66b0d956f008ead0fd899b588cfacb5dPatrick Scott                "http://localhost:8080/test1", "GET", null, testEventHandler, null, 0);
4029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        handle0.waitUntilComplete();
4039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        RequestHandle handle1 = mRequestQueue.queueRequest(
404fe4fec7c66b0d956f008ead0fd899b588cfacb5dPatrick Scott                "http://localhost:8080/test1", "HEAD", null, testEventHandler, null, 0);
4059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testGetAndHead - sent request. Waiting");
4079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        handle1.waitUntilComplete();
4089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (!testEventHandler.expectPassed() && !leh2.expectPassed()) {
4109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Log.d(LOGTAG, testEventHandler.getFailureMessage());
4119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Log.d(LOGTAG, leh2.getFailureMessage());
4129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            fail();
4139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void testPost() throws Exception {
4179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
4189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Test sending a POST request with no body data. Test will pass if the event
4199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * received correspond with the expected response. This should respond with
4209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * the test data requested.
4219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
4229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        TestEventHandler testEventHandler = new TestEventHandler();
4239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        // Load up expected response
4259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectStatus(200);
4269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectHeaders();
4279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectData(52);
4289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTestWebServer.setKeepAlive(false);
4309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTestWebServer.setAcceptLimit(1);
4319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testPost start - rq = " + mRequestQueue);
4339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        RequestHandle handle = mRequestQueue.queueRequest(
435fe4fec7c66b0d956f008ead0fd899b588cfacb5dPatrick Scott                "http://localhost:8080/test1", "POST", null, testEventHandler, null, 0);
4369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testPost - sent request waiting");
4389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        handle.waitUntilComplete();
4399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (!testEventHandler.expectPassed()) {
4419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Log.d(LOGTAG, testEventHandler.getFailureMessage());
4429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            fail("expectPassed was false " + testEventHandler.getFailureMessage());
4439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void testPostWithData() throws Exception {
4489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
4499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Test sending a POST request with body data. Test will pass if the event
4509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * received correspond with the expected response. This should respond with
4519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * the test data requested.
4529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
4539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        TestEventHandler testEventHandler = new TestEventHandler();
4559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        // Load up expected response
4569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectStatus(200);
4579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectHeaders();
4589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        testEventHandler.expectData(52);
4599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTestWebServer.setKeepAlive(false);
4619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTestWebServer.setAcceptLimit(1);
4629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testPostWithData start - rq = " + mRequestQueue);
4649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        String mBody = TestWebData.postContent;
4669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        int bodyLength = mBody.length();
4679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (bodyLength > 0) {
4689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Log.v(LOGTAG, "testPostWithData: body " + mBody);
4699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        InputStream bodyProvider = new ByteArrayInputStream(mBody.getBytes());
4719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        RequestHandle handle = mRequestQueue.queueRequest(
473fe4fec7c66b0d956f008ead0fd899b588cfacb5dPatrick Scott                "http://localhost:8080/test1", "POST", null, testEventHandler, bodyProvider, bodyLength);
4749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Log.d(LOGTAG, "testPostWithData - sent request waiting");
4769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        handle.waitUntilComplete();
4779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (!testEventHandler.expectPassed()) {
4799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Log.d(LOGTAG, testEventHandler.getFailureMessage());
4809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            fail("expectPassed was false " + testEventHandler.getFailureMessage());
4819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project}
484