public void ListeningConfigTest() { var server = new TestTcpServer(); var engine = new DefaultEngine(server, new ListeningConfig(10000)); (engine as IReadOnlyHttpProxyEngine).Start(); server.IsStartupCalled.IsTrue(); server.Port.Is(10000); engine.connections.Count.Is(0); server.AcceptTcp(new TestTcpClient()); engine.connections.Count.Is(1); server.AcceptTcp(new TestTcpClient()); engine.connections.Count.Is(2); var testClient = new TestTcpClient(); server.AcceptTcp(testClient); engine.connections.Count.Is(3); var tcsDispose = new TaskCompletionSource <ProxyConnection>(); engine.connections.Last().Disposing += connection => tcsDispose.TrySetResult(connection); testClient.Close(); tcsDispose.Task.Wait(5000); engine.connections.Count.Is(2); (engine as IReadOnlyHttpProxyEngine).Stop(); server.IsShutdownCalled.IsTrue(); engine.connections.Count.Is(0); }
public void VeryQuicklyCloseTest() { var server = new TestTcpServer(); var engine = new DefaultEngine(server) { DelayForTest = 100 }; var client = new TestTcpClient(); Task.Run(() => server.AcceptTcp(client)); client.Close(); int count = 0; while (!client.IsClosed) { Thread.Sleep(100); count++; if (50 < count) { Assert.False(true, "timeout."); } } engine.connections.Count.Is(0); (engine as IReadOnlyHttpProxyEngine).Stop(); }
public void SessionContentLengthTest() { var clientTcp = new TestTcpClient(); var connection = new ProxyConnection(clientTcp) { CreateTcpClientForServer = (host, port) => new TestTcpClient(host, port) }; connection.StartReceiving(); var tcsRequest = new TaskCompletionSource <IReadOnlyHttpRequest>(); connection.HttpRequestSent += result => tcsRequest.TrySetResult(result); var tcsSession = new TaskCompletionSource <IReadOnlySession>(); connection.HttpResponseSent += result => tcsSession.TrySetResult(result); var tcsClose = new TaskCompletionSource <ProxyConnection>(); connection.Disposing += result => tcsClose.TrySetResult(result); var request = @"GET http://203.104.209.71/kcs2/resources/voice/titlecall_1/005.mp3 HTTP/1.1 Host: 203.104.209.71 Connection: keep-alive User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.79 Safari/537.36 Accept: */* Referer: http://203.104.209.71/kcs2/index.php?api_root=/kcsapi&voice_root=/kcs/sound&osapi_root=osapi.example.com&version=4.1.1.4 Accept-Encoding: gzip, deflate Accept-Language: en-US,en;q=0.9 "; clientTcp.WriteToInput(request); //var tcsRequestSuccess = tcsRequest.Task.Wait(1000); //if (!tcsRequestSuccess) // Assert.False(true, "request timeout"); var requestResult = tcsRequest.GetResult(); connection.serverConnection.client.AsTest().WriteFileToInput("TestData/ResponseContentLength"); //var tcsSessionSuccess = tcsSession.Task.Wait(1000); //if (!tcsSessionSuccess) // Assert.False(true, "session timeout"); var sessionResult = tcsSession.GetResult(); var requestHeaders = sessionResult.Request.Headers as HttpHeaders; sessionResult.Request.RequestLine.HttpVersion.Is(new Version(1, 1)); sessionResult.Request.RequestLine.Method.Is(HttpMethod.Get); sessionResult.Request.RequestLine.RequestTarget.Is("http://203.104.209.71/kcs2/resources/voice/titlecall_1/005.mp3"); requestHeaders.Host.Is("203.104.209.71"); requestHeaders.GetFirstValue("Connection").Is("keep-alive"); requestHeaders.GetFirstValue("User-Agent").Is("Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.79 Safari/537.36"); requestHeaders.GetFirstValue("Accept").Is("*/*"); requestHeaders.GetFirstValue("Referer").Is("http://203.104.209.71/kcs2/index.php?api_root=/kcsapi&voice_root=/kcs/sound&osapi_root=osapi.example.com&version=4.1.1.4"); requestHeaders.GetFirstValue("Accept-Encoding").Is("gzip, deflate"); requestHeaders.GetFirstValue("Accept-Language").Is("en-US,en;q=0.9"); requestHeaders.HasHeader("Via").IsFalse(); sessionResult.Request.Body.IsNull(); var response = sessionResult.Response as HttpResponse; response.StatusLine.HttpVersion.Is(new Version(1, 1)); response.StatusLine.StatusCode.Is(HttpStatusCode.OK); response.StatusLine.ReasonPhrase.Is("OK"); response.Headers.ContentLength.Exists.Is(true); response.Headers.ContentLength.Is(47); response.Headers.TransferEncoding.Exists.Is(false); response.Headers.IsChunked.Is(false); response.Headers.GetFirstValue("Access-Control-Allow-Credentials").Is("true"); response.Headers.GetFirstValue("Access-Control-Allow-Methods").Is("POST,GET,HEAD,OPTIONS"); response.Headers.GetFirstValue("Access-Control-Allow-Origin").Is("http://d.hatena.ne.jp"); response.Headers.GetFirstValue("Cache-Control").Is("no-store, no-cache"); response.Headers.ContentType.Is("application/json"); response.Headers.GetFirstValue("Date").Is("Thu, 20 Sep 2018 01:59:09 GMT"); response.Headers.GetFirstValue("Expires").Is("Mon, 15 Jun 1998 00:00:00 GMT"); response.Headers.GetFirstValue("Pragma").Is("no-cache"); response.Headers.GetFirstValue("Server").Is("Adtech Adserver"); response.GetBodyAsString().Is(@"{""id"":""31259257328373081"",""seatbid"":[],""nbr"":1}"); //connection.serverConnection.client.AsTest().Close(); // サーバーから閉じる clientTcp.Close(); // クライアントから閉じる tcsClose.GetResult().Is(connection); connection.Dispose(); }