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