From abe4681722ff1fa897454e5bc1703ef446201a78 Mon Sep 17 00:00:00 2001 From: Ravi Pendurty Date: Tue, 6 Apr 2021 11:41:09 +0200 Subject: [PATCH] http proxy settings need a different connector ApacheConnectorProvider supports the http proxy properties defined by DMAAP MR and not the default HttpUrlConnectorProvider Issue-ID: DMAAP-1548 Signed-off-by: Ravi Pendurty Change-Id: Ie1cff823ff247133c69434110b04b8191b46a1f6 Signed-off-by: Ravi Pendurty --- pom.xml | 5 +++++ .../java/org/onap/dmaap/mr/client/impl/DmaapClientUtil.java | 11 +++++++---- .../org/onap/dmaap/mr/client/impl/DMaapClientUtilTest.java | 12 ++++++++++++ 3 files changed, 24 insertions(+), 4 deletions(-) diff --git a/pom.xml b/pom.xml index 3d1785b..134971a 100644 --- a/pom.xml +++ b/pom.xml @@ -174,6 +174,11 @@ jersey-common ${jersey.version} + + org.glassfish.jersey.connectors + jersey-apache-connector + 2.29.1 + org.glassfish.jersey.core jersey-client diff --git a/src/main/java/org/onap/dmaap/mr/client/impl/DmaapClientUtil.java b/src/main/java/org/onap/dmaap/mr/client/impl/DmaapClientUtil.java index 4c50596..948ca31 100644 --- a/src/main/java/org/onap/dmaap/mr/client/impl/DmaapClientUtil.java +++ b/src/main/java/org/onap/dmaap/mr/client/impl/DmaapClientUtil.java @@ -8,7 +8,7 @@ * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * http://www.apache.org/licenses/LICENSE-2.0 - * + * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. @@ -17,18 +17,17 @@ * ============LICENSE_END========================================================= * * ECOMP is a trademark and service mark of AT&T Intellectual Property. - * + * *******************************************************************************/ package org.onap.dmaap.mr.client.impl; import java.util.Properties; - import javax.ws.rs.client.Client; import javax.ws.rs.client.ClientBuilder; import javax.ws.rs.client.Entity; import javax.ws.rs.client.WebTarget; import javax.ws.rs.core.Response; - +import org.glassfish.jersey.apache.connector.ApacheConnectorProvider; import org.glassfish.jersey.client.ClientConfig; import org.glassfish.jersey.client.ClientProperties; import org.glassfish.jersey.client.authentication.HttpAuthenticationFeature; @@ -55,6 +54,10 @@ public class DmaapClientUtil { config.property(httpClientProperties[i], properties.getProperty(httpClientProperties[i])); } } + if ((properties.getProperty(ClientProperties.PROXY_URI) != null) && + !(properties.getProperty(ClientProperties.PROXY_URI).isEmpty())) { + config.connectorProvider(new ApacheConnectorProvider()); + } // else the default connectorProvider (HttpConnectorProvider) will be used } diff --git a/src/test/java/org/onap/dmaap/mr/client/impl/DMaapClientUtilTest.java b/src/test/java/org/onap/dmaap/mr/client/impl/DMaapClientUtilTest.java index 4378942..5d63759 100644 --- a/src/test/java/org/onap/dmaap/mr/client/impl/DMaapClientUtilTest.java +++ b/src/test/java/org/onap/dmaap/mr/client/impl/DMaapClientUtilTest.java @@ -26,11 +26,14 @@ import static org.mockito.Matchers.any; import static org.mockito.Mockito.times; import static org.mockito.Mockito.verify; +import java.util.Properties; + import javax.ws.rs.client.Invocation.Builder; import javax.ws.rs.client.WebTarget; import javax.ws.rs.core.Response; import org.glassfish.jersey.client.ClientConfig; +import org.glassfish.jersey.client.ClientProperties; import org.junit.Before; import org.junit.Test; import org.mockito.Mock; @@ -78,6 +81,15 @@ public class DMaapClientUtilTest { verify(target).request(); verify(builder, times(2)).header((String) any(), any()); } + + @Test + public void testSetHttpClientProperties() { + Properties properties = new Properties(); + properties.setProperty(ClientProperties.PROXY_URI, "http://localhost:1234"); + ClientConfig cConfig = DmaapClientUtil.getClientConfig(properties); + + assertEquals(cConfig.getConnectorProvider().getClass().getSimpleName(), "ApacheConnectorProvider"); + } private ClientConfig getClientConfig(){ if(config==null){ -- 2.16.6