TCA: Support for VES/A&AI enrichment
[dcaegen2/analytics/tca.git] / dcae-analytics-cdap-plugins / src / test / java / org / openecomp / dcae / apod / analytics / cdap / plugins / batch / sink / dmaap / DMaaPMROutputFormatTest.java
1 /*\r
2  * ===============================LICENSE_START======================================\r
3  *  dcae-analytics\r
4  * ================================================================================\r
5  *    Copyright © 2017 AT&T Intellectual Property. All rights reserved.\r
6  * ================================================================================\r
7  *  Licensed under the Apache License, Version 2.0 (the "License");\r
8  *  you may not use this file except in compliance with the License.\r
9  *   You may obtain a copy of the License at\r
10  *\r
11  *          http://www.apache.org/licenses/LICENSE-2.0\r
12  *\r
13  *  Unless required by applicable law or agreed to in writing, software\r
14  *  distributed under the License is distributed on an "AS IS" BASIS,\r
15  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
16  *  See the License for the specific language governing permissions and\r
17  *  limitations under the License.\r
18  *  ============================LICENSE_END===========================================\r
19  */\r
20 \r
21 package org.openecomp.dcae.apod.analytics.cdap.plugins.batch.sink.dmaap;\r
22 \r
23 import org.apache.hadoop.io.NullWritable;\r
24 import org.apache.hadoop.mapreduce.JobContext;\r
25 import org.apache.hadoop.mapreduce.OutputCommitter;\r
26 import org.apache.hadoop.mapreduce.RecordWriter;\r
27 import org.apache.hadoop.mapreduce.TaskAttemptContext;\r
28 import org.junit.Before;\r
29 import org.junit.Test;\r
30 import org.mockito.Mockito;\r
31 import org.openecomp.dcae.apod.analytics.cdap.plugins.BaseAnalyticsCDAPPluginsUnitTest;\r
32 \r
33 import static org.junit.Assert.assertFalse;\r
34 import static org.junit.Assert.assertNotNull;\r
35 import static org.junit.Assert.assertTrue;\r
36 import static org.mockito.Mockito.when;\r
37 \r
38 /**\r
39  * @author Rajiv Singla . Creation Date: 1/30/2017.\r
40  */\r
41 public class DMaaPMROutputFormatTest extends BaseAnalyticsCDAPPluginsUnitTest {\r
42 \r
43     private DMaaPMROutputFormat dMaaPMROutputFormat;\r
44 \r
45     @Before\r
46     public void before() {\r
47         dMaaPMROutputFormat = new DMaaPMROutputFormat();\r
48     }\r
49 \r
50     @Test\r
51     public void testGetRecordWriter() throws Exception {\r
52         final TaskAttemptContext taskAttemptContext = Mockito.mock(TaskAttemptContext.class);\r
53         when(taskAttemptContext.getConfiguration()).thenReturn(getTestConfiguration());\r
54         final RecordWriter<String, NullWritable> recordWriter = dMaaPMROutputFormat.getRecordWriter(taskAttemptContext);\r
55         assertNotNull(recordWriter);\r
56         final JobContext jobContext = Mockito.mock(JobContext.class);\r
57         dMaaPMROutputFormat.checkOutputSpecs(jobContext);\r
58     }\r
59 \r
60     @Test\r
61     public void testGetOutputCommitter() throws Exception {\r
62         final TaskAttemptContext taskAttemptContext = Mockito.mock(TaskAttemptContext.class);\r
63         final OutputCommitter outputCommitter = dMaaPMROutputFormat.getOutputCommitter(taskAttemptContext);\r
64         assertTrue(outputCommitter.getClass().equals(DMaaPMROutputFormat.NoOpOutputCommitter.class));\r
65         final JobContext jobContext = Mockito.mock(JobContext.class);\r
66         outputCommitter.setupJob(jobContext);\r
67         outputCommitter.setupTask(taskAttemptContext);\r
68         assertFalse(outputCommitter.needsTaskCommit(taskAttemptContext));\r
69         outputCommitter.commitJob(jobContext);\r
70         outputCommitter.commitTask(taskAttemptContext);\r
71         outputCommitter.abortTask(taskAttemptContext);\r
72 \r
73     }\r
74 \r
75 }\r