4f2eb316717337693dec5fde5d31a8a08f23613d
[policy/common.git] /
1 /*
2  * ============LICENSE_START=======================================================
3  * ONAP
4  * ================================================================================
5  * Copyright (C) 2019-2020 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  *
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  * ============LICENSE_END=========================================================
19  */
20
21 package org.onap.policy.common.endpoints.http.server.test;
22
23 import static org.assertj.core.api.Assertions.assertThatThrownBy;
24 import static org.junit.Assert.assertEquals;
25 import static org.junit.Assert.assertFalse;
26 import static org.junit.Assert.assertTrue;
27
28 import java.io.ByteArrayInputStream;
29 import java.io.ByteArrayOutputStream;
30 import java.io.IOException;
31 import java.io.InputStream;
32 import java.io.OutputStream;
33 import java.util.HashMap;
34 import java.util.Map;
35 import javax.ws.rs.core.MediaType;
36 import org.junit.Before;
37 import org.junit.Test;
38 import org.onap.policy.common.endpoints.http.server.YamlMessageBodyHandler;
39 import org.yaml.snakeyaml.error.YAMLException;
40
41 public class YamlMessageBodyHandlerTest {
42     private static final String EXPECTED_EXCEPTION = "expected exception";
43
44     private static final String GEN_TYPE = "some-type";
45     private static final String[] subtypes = {"yaml"};
46
47     @SuppressWarnings("rawtypes")
48     private static final Class GEN_CLASS = MyObject.class;
49
50     @SuppressWarnings("unchecked")
51     private static final Class<Object> CLASS_OBJ = GEN_CLASS;
52
53     private YamlMessageBodyHandler hdlr;
54
55     @Before
56     public void setUp() {
57         hdlr = new YamlMessageBodyHandler();
58     }
59
60     @Test
61     public void testIsWriteable() {
62         for (String subtype : subtypes) {
63             assertTrue("writeable " + subtype, hdlr.isWriteable(null, null, null, new MediaType(GEN_TYPE, subtype)));
64
65         }
66
67         // the remaining should be FALSE
68
69         // null media type
70         assertFalse(hdlr.isWriteable(null, null, null, null));
71
72         // null subtype
73         assertFalse(hdlr.isWriteable(null, null, null, new MediaType(GEN_TYPE, null)));
74
75         // text subtype
76         assertFalse(hdlr.isWriteable(null, null, null, MediaType.TEXT_HTML_TYPE));
77     }
78
79     @Test
80     public void testGetSize() {
81         assertEquals(-1, hdlr.getSize(null, null, null, null, null));
82     }
83
84     @Test
85     public void testWriteTo_testReadFrom() throws Exception {
86         ByteArrayOutputStream outstr = new ByteArrayOutputStream();
87         MyObject obj1 = new MyObject(10);
88         hdlr.writeTo(obj1, obj1.getClass(), CLASS_OBJ, null, null, null, outstr);
89
90         Object obj2 = hdlr.readFrom(CLASS_OBJ, CLASS_OBJ, null, null, null,
91                         new ByteArrayInputStream(outstr.toByteArray()));
92         assertEquals(obj1.toString(), obj2.toString());
93     }
94
95     @Test
96     public void testWriteTo_DifferentTypes() throws Exception {
97         ByteArrayOutputStream outstr = new ByteArrayOutputStream();
98
99         // use a derived type, but specify the base type when writing
100         MyObject obj1 = new DerivedObject(10);
101         hdlr.writeTo(obj1, obj1.getClass(), CLASS_OBJ, null, null, null, outstr);
102
103         Object obj2 = hdlr.readFrom(CLASS_OBJ, CLASS_OBJ, null, null, null,
104                         new ByteArrayInputStream(outstr.toByteArray()));
105         assertEquals(obj1.toString(), obj2.toString());
106     }
107
108     @Test
109     public void testWriteTo_Ex() throws Exception {
110         OutputStream outstr = new OutputStream() {
111             @Override
112             public void write(int value) throws IOException {
113                 throw new IOException(EXPECTED_EXCEPTION);
114             }
115         };
116
117         MyObject obj1 = new MyObject(10);
118         assertThatThrownBy(() -> hdlr.writeTo(obj1, MyObject.class, CLASS_OBJ, null, null, null, outstr))
119                         .isInstanceOf(YAMLException.class);
120
121         outstr.close();
122     }
123
124     @Test
125     public void testIsReadable() {
126         for (String subtype : subtypes) {
127             assertTrue("readable " + subtype, hdlr.isReadable(null, null, null, new MediaType(GEN_TYPE, subtype)));
128
129         }
130
131         // the remaining should be FALSE
132
133         // null media type
134         assertFalse(hdlr.isReadable(null, null, null, null));
135
136         // null subtype
137         assertFalse(hdlr.isReadable(null, null, null, new MediaType(GEN_TYPE, null)));
138
139         // text subtype
140         assertFalse(hdlr.isReadable(null, null, null, MediaType.TEXT_HTML_TYPE));
141     }
142
143     @Test
144     public void testReadFrom_DifferentTypes() throws Exception {
145         ByteArrayOutputStream outstr = new ByteArrayOutputStream();
146         MyObject obj1 = new MyObject(10);
147         hdlr.writeTo(obj1, obj1.getClass(), CLASS_OBJ, null, null, null, outstr);
148
149         // use a derived type, but specify the base type when reading
150         @SuppressWarnings("rawtypes")
151         Class clazz = DerivedObject.class;
152
153         @SuppressWarnings("unchecked")
154         Class<Object> objclazz = clazz;
155
156         Object obj2 = hdlr.readFrom(objclazz, CLASS_OBJ, null, null, null,
157                         new ByteArrayInputStream(outstr.toByteArray()));
158         assertEquals(obj1.toString(), obj2.toString());
159     }
160
161     @Test
162     public void testReadFrom_Ex() throws Exception {
163         InputStream inpstr = new InputStream() {
164             @Override
165             public int read() throws IOException {
166                 throw new IOException(EXPECTED_EXCEPTION);
167             }
168         };
169
170         assertThatThrownBy(() -> hdlr.readFrom(CLASS_OBJ, CLASS_OBJ, null, null, null, inpstr))
171                         .isInstanceOf(YAMLException.class);
172
173         inpstr.close();
174     }
175
176     @Test
177     public void testReadFrom_Invalid() throws Exception {
178         InputStream inpstr = new ByteArrayInputStream("plain text".getBytes());
179
180         assertThatThrownBy(() -> hdlr.readFrom(CLASS_OBJ, CLASS_OBJ, null, null, null, inpstr))
181                         .isInstanceOf(YAMLException.class);
182
183         inpstr.close();
184     }
185
186     @Test
187     public void testMapDouble() throws Exception {
188         MyMap map = new MyMap();
189         map.props = new HashMap<>();
190         map.props.put("plainString", "def");
191         map.props.put("negInt", -10);
192         map.props.put("doubleVal", 12.5);
193         map.props.put("posLong", 100000000000L);
194
195         ByteArrayOutputStream outstr = new ByteArrayOutputStream();
196         hdlr.writeTo(map, map.getClass(), map.getClass(), null, null, null, outstr);
197
198         Object obj2 = hdlr.readFrom(Object.class, map.getClass(), null, null, null,
199                         new ByteArrayInputStream(outstr.toByteArray()));
200         assertEquals(map.toString(), obj2.toString());
201
202         map = (MyMap) obj2;
203
204         assertEquals(-10, map.props.get("negInt"));
205         assertEquals(100000000000L, map.props.get("posLong"));
206         assertEquals(12.5, map.props.get("doubleVal"));
207     }
208
209     public static class DerivedObject extends MyObject {
210         public DerivedObject(int id) {
211             super(id);
212         }
213     }
214
215     public static class MyObject {
216         private int id;
217
218         public MyObject() {
219             super();
220         }
221
222         public MyObject(int id) {
223             this.id = id;
224         }
225
226         @Override
227         public String toString() {
228             return "MyObject [id=" + id + "]";
229         }
230     }
231
232     private static class MyMap {
233         private Map<String, Object> props;
234
235         @Override
236         public String toString() {
237             return props.toString();
238         }
239     }
240 }