//JAVA TO C# CONVERTER TODO TASK: Most Java annotations will not have direct .NET equivalent attributes: //ORIGINAL LINE: @Test public void shouldPerform500ConcurrentRequests() throws InterruptedException, java.util.concurrent.ExecutionException //JAVA TO C# CONVERTER WARNING: Method 'throws' clauses are not available in .NET: public virtual void shouldPerform500ConcurrentRequests() { PoolingHttpClientConnectionManager cm = new PoolingHttpClientConnectionManager(); //JAVA TO C# CONVERTER WARNING: The original Java variable was marked 'final': //ORIGINAL LINE: final org.apache.http.impl.client.CloseableHttpClient httpClient = org.apache.http.impl.client.HttpClients.custom().setConnectionManager(cm).build(); CloseableHttpClient httpClient = HttpClients.custom().setConnectionManager(cm).build(); Callable <string> performRequest = new CallableAnonymousInnerClass(this, httpClient); int requestsCount = 500; ExecutorService service = Executors.newFixedThreadPool(requestsCount); IList <Callable <string> > requests = new List <Callable <string> >(); for (int i = 0; i < requestsCount; i++) { requests.Add(performRequest); } IList <Future <string> > futures = service.invokeAll(requests); service.shutdown(); service.awaitTermination(1, TimeUnit.HOURS); foreach (Future <string> future in futures) { assertEquals(future.get(), "[]"); } }
public virtual CloseableHttpClient Build() { // Create main request executor HttpRequestExecutor requestExec = this.requestExec; if (requestExec == null) { requestExec = new HttpRequestExecutor(); } HttpClientConnectionManager connManager = this.connManager; if (connManager == null) { LayeredConnectionSocketFactory sslSocketFactory = this.sslSocketFactory; if (sslSocketFactory == null) { string[] supportedProtocols = systemProperties ? Split(Runtime.GetProperty("https.protocols" )) : null; string[] supportedCipherSuites = systemProperties ? Split(Runtime.GetProperty("https.cipherSuites" )) : null; X509HostnameVerifier hostnameVerifier = this.hostnameVerifier; if (hostnameVerifier == null) { hostnameVerifier = SSLConnectionSocketFactory.BrowserCompatibleHostnameVerifier; } if (sslcontext != null) { sslSocketFactory = new SSLConnectionSocketFactory(sslcontext, supportedProtocols, supportedCipherSuites, hostnameVerifier); } else { if (systemProperties) { sslSocketFactory = new SSLConnectionSocketFactory((SSLSocketFactory)SSLSocketFactory .GetDefault(), supportedProtocols, supportedCipherSuites, hostnameVerifier); } else { sslSocketFactory = new SSLConnectionSocketFactory(SSLContexts.CreateDefault(), hostnameVerifier ); } } } PoolingHttpClientConnectionManager poolingmgr = new PoolingHttpClientConnectionManager (RegistryBuilder.Create <ConnectionSocketFactory>().Register("http", PlainConnectionSocketFactory .GetSocketFactory()).Register("https", sslSocketFactory).Build()); if (defaultSocketConfig != null) { poolingmgr.SetDefaultSocketConfig(defaultSocketConfig); } if (defaultConnectionConfig != null) { poolingmgr.SetDefaultConnectionConfig(defaultConnectionConfig); } if (systemProperties) { string s = Runtime.GetProperty("http.keepAlive", "true"); if (Sharpen.Runtime.EqualsIgnoreCase("true", s)) { s = Runtime.GetProperty("http.maxConnections", "5"); int max = System.Convert.ToInt32(s); poolingmgr.SetDefaultMaxPerRoute(max); poolingmgr.SetMaxTotal(2 * max); } } if (maxConnTotal > 0) { poolingmgr.SetMaxTotal(maxConnTotal); } if (maxConnPerRoute > 0) { poolingmgr.SetDefaultMaxPerRoute(maxConnPerRoute); } connManager = poolingmgr; } ConnectionReuseStrategy reuseStrategy = this.reuseStrategy; if (reuseStrategy == null) { if (systemProperties) { string s = Runtime.GetProperty("http.keepAlive", "true"); if (Sharpen.Runtime.EqualsIgnoreCase("true", s)) { reuseStrategy = DefaultConnectionReuseStrategy.Instance; } else { reuseStrategy = NoConnectionReuseStrategy.Instance; } } else { reuseStrategy = DefaultConnectionReuseStrategy.Instance; } } ConnectionKeepAliveStrategy keepAliveStrategy = this.keepAliveStrategy; if (keepAliveStrategy == null) { keepAliveStrategy = DefaultConnectionKeepAliveStrategy.Instance; } AuthenticationStrategy targetAuthStrategy = this.targetAuthStrategy; if (targetAuthStrategy == null) { targetAuthStrategy = TargetAuthenticationStrategy.Instance; } AuthenticationStrategy proxyAuthStrategy = this.proxyAuthStrategy; if (proxyAuthStrategy == null) { proxyAuthStrategy = ProxyAuthenticationStrategy.Instance; } UserTokenHandler userTokenHandler = this.userTokenHandler; if (userTokenHandler == null) { if (!connectionStateDisabled) { userTokenHandler = DefaultUserTokenHandler.Instance; } else { userTokenHandler = NoopUserTokenHandler.Instance; } } ClientExecChain execChain = new MainClientExec(requestExec, connManager, reuseStrategy , keepAliveStrategy, targetAuthStrategy, proxyAuthStrategy, userTokenHandler); execChain = DecorateMainExec(execChain); HttpProcessor httpprocessor = this.httpprocessor; if (httpprocessor == null) { string userAgent = this.userAgent; if (userAgent == null) { if (systemProperties) { userAgent = Runtime.GetProperty("http.agent"); } if (userAgent == null) { userAgent = DefaultUserAgent; } } HttpProcessorBuilder b = HttpProcessorBuilder.Create(); if (requestFirst != null) { foreach (IHttpRequestInterceptor i in requestFirst) { b.AddFirst(i); } } if (responseFirst != null) { foreach (HttpResponseInterceptor i in responseFirst) { b.AddFirst(i); } } b.AddAll(new RequestDefaultHeaders(defaultHeaders), new RequestContent(), new RequestTargetHost (), new RequestClientConnControl(), new RequestUserAgent(userAgent), new RequestExpectContinue ()); if (!cookieManagementDisabled) { b.Add(new RequestAddCookies()); } if (!contentCompressionDisabled) { b.Add(new RequestAcceptEncoding()); } if (!authCachingDisabled) { b.Add(new RequestAuthCache()); } if (!cookieManagementDisabled) { b.Add(new ResponseProcessCookies()); } if (!contentCompressionDisabled) { b.Add(new ResponseContentEncoding()); } if (requestLast != null) { foreach (IHttpRequestInterceptor i in requestLast) { b.AddLast(i); } } if (responseLast != null) { foreach (HttpResponseInterceptor i in responseLast) { b.AddLast(i); } } httpprocessor = b.Build(); } execChain = new ProtocolExec(execChain, httpprocessor); execChain = DecorateProtocolExec(execChain); // Add request retry executor, if not disabled if (!automaticRetriesDisabled) { HttpRequestRetryHandler retryHandler = this.retryHandler; if (retryHandler == null) { retryHandler = DefaultHttpRequestRetryHandler.Instance; } execChain = new RetryExec(execChain, retryHandler); } HttpRoutePlanner routePlanner = this.routePlanner; if (routePlanner == null) { SchemePortResolver schemePortResolver = this.schemePortResolver; if (schemePortResolver == null) { schemePortResolver = DefaultSchemePortResolver.Instance; } if (proxy != null) { routePlanner = new DefaultProxyRoutePlanner(proxy, schemePortResolver); } else { if (systemProperties) { routePlanner = new SystemDefaultRoutePlanner(schemePortResolver, ProxySelector.GetDefault ()); } else { routePlanner = new DefaultRoutePlanner(schemePortResolver); } } } // Add redirect executor, if not disabled if (!redirectHandlingDisabled) { RedirectStrategy redirectStrategy = this.redirectStrategy; if (redirectStrategy == null) { redirectStrategy = DefaultRedirectStrategy.Instance; } execChain = new RedirectExec(execChain, routePlanner, redirectStrategy); } // Optionally, add service unavailable retry executor ServiceUnavailableRetryStrategy serviceUnavailStrategy = this.serviceUnavailStrategy; if (serviceUnavailStrategy != null) { execChain = new ServiceUnavailableRetryExec(execChain, serviceUnavailStrategy); } // Optionally, add connection back-off executor BackoffManager backoffManager = this.backoffManager; ConnectionBackoffStrategy connectionBackoffStrategy = this.connectionBackoffStrategy; if (backoffManager != null && connectionBackoffStrategy != null) { execChain = new BackoffStrategyExec(execChain, connectionBackoffStrategy, backoffManager ); } Lookup <AuthSchemeProvider> authSchemeRegistry = this.authSchemeRegistry; if (authSchemeRegistry == null) { authSchemeRegistry = RegistryBuilder.Create <AuthSchemeProvider>().Register(AuthSchemes .Basic, new BasicSchemeFactory()).Register(AuthSchemes.Digest, new DigestSchemeFactory ()).Register(AuthSchemes.Ntlm, new NTLMSchemeFactory()).Register(AuthSchemes.Spnego , new SPNegoSchemeFactory()).Register(AuthSchemes.Kerberos, new KerberosSchemeFactory ()).Build(); } Lookup <CookieSpecProvider> cookieSpecRegistry = this.cookieSpecRegistry; if (cookieSpecRegistry == null) { cookieSpecRegistry = RegistryBuilder.Create <CookieSpecProvider>().Register(CookieSpecs .BestMatch, new BestMatchSpecFactory()).Register(CookieSpecs.Standard, new RFC2965SpecFactory ()).Register(CookieSpecs.BrowserCompatibility, new BrowserCompatSpecFactory()).Register (CookieSpecs.Netscape, new NetscapeDraftSpecFactory()).Register(CookieSpecs.IgnoreCookies , new IgnoreSpecFactory()).Register("rfc2109", new RFC2109SpecFactory()).Register ("rfc2965", new RFC2965SpecFactory()).Build(); } CookieStore defaultCookieStore = this.cookieStore; if (defaultCookieStore == null) { defaultCookieStore = new BasicCookieStore(); } CredentialsProvider defaultCredentialsProvider = this.credentialsProvider; if (defaultCredentialsProvider == null) { if (systemProperties) { defaultCredentialsProvider = new SystemDefaultCredentialsProvider(); } else { defaultCredentialsProvider = new BasicCredentialsProvider(); } } return(new InternalHttpClient(execChain, connManager, routePlanner, cookieSpecRegistry , authSchemeRegistry, defaultCookieStore, defaultCredentialsProvider, defaultRequestConfig != null ? defaultRequestConfig : RequestConfig.Default, closeables != null ? new AList <IDisposable>(closeables) : null)); }