b12f00174031d0fb74de24aa81e62f179a021e93
[dmaap/messagerouter/msgrtr.git] / src / test / java / org / onap / dmaap / mr / test / dme2 / DME2ConsumerTest.java
1 /*******************************************************************************
2  *  ============LICENSE_START=======================================================
3  *  org.onap.dmaap
4  *  ================================================================================
5  *  Copyright © 2017 AT&T Intellectual Property. All rights reserved.
6  *  ================================================================================
7  *  Licensed under the Apache License, Version 2.0 (the "License");
8  *  you may not use this file except in compliance with the License.
9  *  You may obtain a copy of the License at
10  *        http://www.apache.org/licenses/LICENSE-2.0
11  *  
12  *  Unless required by applicable law or agreed to in writing, software
13  *  distributed under the License is distributed on an "AS IS" BASIS,
14  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15  *  See the License for the specific language governing permissions and
16  *  limitations under the License.
17  *  ============LICENSE_END=========================================================
18  *
19  *  ECOMP is a trademark and service mark of AT&T Intellectual Property.
20  *  
21  *******************************************************************************/
22 package org.onap.dmaap.mr.test.dme2;
23
24 import java.net.URI;
25 import java.net.URISyntaxException;
26 import java.util.HashMap;
27 import java.util.Properties;
28
29 import org.apache.log4j.Logger;
30
31 import junit.framework.TestCase;
32
33 import com.att.aft.dme2.api.DME2Client;
34 import com.att.aft.dme2.api.DME2Exception;
35
36 public class DME2ConsumerTest extends TestCase {
37         private static final Logger LOGGER = Logger.getLogger(DME2ConsumerTest.class);
38
39         public void testConsumer() {
40                 LOGGER.info("Test case subcribing initiated");
41                 
42                 Properties props = LoadPropertyFile.getPropertyFileDataProducer();
43                 String latitude = props.getProperty("Latitude");
44                 String longitude = props.getProperty("Longitude");
45                 String version = props.getProperty("Version");
46                 String serviceName = props.getProperty("ServiceName");
47                 String env = props.getProperty("Environment");
48                 String partner = props.getProperty("Partner");
49                 String protocol = props.getProperty("Protocol");
50                 String methodType = props.getProperty("MethodTypeGet");
51                 String user = props.getProperty("user");
52                 String password = props.getProperty("password");
53                 String contenttype = props.getProperty("contenttype");
54                 String url = protocol + "://DME2SEARCH/" + "service=" + serviceName + "/" + "version=" + version + "/"
55                                 + "envContext=" + env + "/" + "partner=" + partner;
56                 LoadPropertyFile.loadAFTProperties(latitude, longitude);
57                 HashMap<String, String> hm = new HashMap<String, String>();
58                 hm.put("AFT_DME2_EP_READ_TIMEOUT_MS", "50000");
59                 hm.put("AFT_DME2_ROUNDTRIP_TIMEOUT_MS", "240000");
60                 hm.put("AFT_DME2_EP_CONN_TIMEOUT", "5000");
61                 try {
62
63                         // topic exist logic is commented
64                         // if (!topicTestObj.topicExist(url, props, hm)) {
65                         // throw new Exception("Topic does not exist");
66                         // } else {
67                         DME2Client sender = new DME2Client(new URI(url), 5000L);
68                         sender.setAllowAllHttpReturnCodes(true);
69                         sender.setMethod(methodType);
70                         String subContextPathConsumer = props.getProperty("SubContextPathConsumer") + props.getProperty("newTopic")
71                                         + "/" + props.getProperty("group") + "/" + props.getProperty("id");
72                         sender.setSubContext(subContextPathConsumer);
73                         sender.setPayload("");
74
75                         sender.addHeader("Content-Type", contenttype);
76                         sender.setCredentials(user, password);
77                         sender.setHeaders(hm);
78
79                         LOGGER.info("Consuming Message");
80                         String reply = sender.sendAndWait(5000L);
81
82                         assertNotNull(reply);
83                         LOGGER.info("Message received = " + reply);
84                         // }
85                 } catch (DME2Exception e) {
86                         e.printStackTrace();
87                 } catch (URISyntaxException e) {
88                         e.printStackTrace();
89                 } catch (Exception e) {
90                         e.printStackTrace();
91                 }
92         }
93
94 }