summaryrefslogtreecommitdiffstats
path: root/glance-model/src/test/java/com/woorea/openstack/glance/model/ImagesTest.java
diff options
context:
space:
mode:
Diffstat (limited to 'glance-model/src/test/java/com/woorea/openstack/glance/model/ImagesTest.java')
-rw-r--r--glance-model/src/test/java/com/woorea/openstack/glance/model/ImagesTest.java101
1 files changed, 95 insertions, 6 deletions
diff --git a/glance-model/src/test/java/com/woorea/openstack/glance/model/ImagesTest.java b/glance-model/src/test/java/com/woorea/openstack/glance/model/ImagesTest.java
index 1dc02be..913fa01 100644
--- a/glance-model/src/test/java/com/woorea/openstack/glance/model/ImagesTest.java
+++ b/glance-model/src/test/java/com/woorea/openstack/glance/model/ImagesTest.java
@@ -2,8 +2,8 @@
* ============LICENSE_START=======================================================
* ONAP - SO
* ================================================================================
- * Copyright (C) 2018 Huawei Intellectual Property. All rights reserved.
- * ================================================================================
+ * Copyright (C) 2018 AT&T Intellectual Property. All rights reserved.
+ * ================================================================================
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
@@ -17,16 +17,105 @@
* limitations under the License.
* ============LICENSE_END=========================================================
*/
+
package com.woorea.openstack.glance.model;
+import com.woorea.openstack.glance.model.Image;
+import com.woorea.openstack.glance.model.Images;
+import java.util.List;
+import org.codehaus.jackson.map.DeserializationConfig;
+import org.codehaus.jackson.map.ObjectMapper;
+import org.codehaus.jackson.map.SerializationConfig;
+import org.codehaus.jackson.map.annotate.JsonSerialize.Inclusion;
+import org.junit.Assert;
import org.junit.Test;
+import org.skyscreamer.jsonassert.JSONAssert;
+import org.skyscreamer.jsonassert.JSONCompareMode;
public class ImagesTest {
- Images images = new Images();
+ private static final String EOL = System.lineSeparator();
+
+ private static final String JSON_FULL = "{" + EOL
+ + " \"images\" : [ {" + EOL
+ + " \"id\" : \"id\"," + EOL
+ + " \"uri\" : \"uri\"," + EOL
+ + " \"name\" : \"name\"," + EOL
+ + " \"size\" : 43," + EOL
+ + " \"checksum\" : \"checksum\"," + EOL
+ + " \"status\" : \"status\"," + EOL
+ + " \"owner\" : \"owner\"," + EOL
+ + " \"properties\" : {" + EOL
+ + " \"properties-k1\" : \"properties-v1\"," + EOL
+ + " \"properties-k2\" : \"properties-v2\"" + EOL
+ + " }," + EOL
+ + " \"public\" : false," + EOL
+ + " \"deleted\" : false," + EOL
+ + " \"protected\" : true," + EOL
+ + " \"disk_format\" : \"diskformat\"," + EOL
+ + " \"container_format\" : \"containerformat\"," + EOL
+ + " \"virtual_size\" : 18," + EOL
+ + " \"created_at\" : 1486296000000," + EOL
+ + " \"updated_at\" : 1487592000000," + EOL
+ + " \"deleted_at\" : 1486209600000," + EOL
+ + " \"is_public\" : false," + EOL
+ + " \"min_ram\" : 62," + EOL
+ + " \"min_disk\" : 69" + EOL
+ + " }, {" + EOL
+ + " \"id\" : \"id\"," + EOL
+ + " \"uri\" : \"uri\"," + EOL
+ + " \"name\" : \"name\"," + EOL
+ + " \"size\" : 43," + EOL
+ + " \"checksum\" : \"checksum\"," + EOL
+ + " \"status\" : \"status\"," + EOL
+ + " \"owner\" : \"owner\"," + EOL
+ + " \"properties\" : {" + EOL
+ + " \"properties-k1\" : \"properties-v1\"," + EOL
+ + " \"properties-k2\" : \"properties-v2\"" + EOL
+ + " }," + EOL
+ + " \"public\" : false," + EOL
+ + " \"deleted\" : false," + EOL
+ + " \"protected\" : true," + EOL
+ + " \"disk_format\" : \"diskformat\"," + EOL
+ + " \"container_format\" : \"containerformat\"," + EOL
+ + " \"virtual_size\" : 18," + EOL
+ + " \"created_at\" : 1486296000000," + EOL
+ + " \"updated_at\" : 1487592000000," + EOL
+ + " \"deleted_at\" : 1486209600000," + EOL
+ + " \"is_public\" : false," + EOL
+ + " \"min_ram\" : 62," + EOL
+ + " \"min_disk\" : 69" + EOL
+ + " } ]" + EOL
+ + "}";
+
+ private ObjectMapper objectMapper = new ObjectMapper()
+ .setSerializationInclusion(Inclusion.NON_NULL)
+ .enable(SerializationConfig.Feature.INDENT_OUTPUT)
+ .enable(DeserializationConfig.Feature.ACCEPT_SINGLE_VALUE_AS_ARRAY);
+
@Test
- public void getListTest() throws Exception {
- images.getList();
+ public void testSerialization() throws Exception {
+ System.out.println("CLASS: " + Images.class.getName());
+ System.out.println("TEST JSON: " + JSON_FULL);
+ Images images = objectMapper.readValue(JSON_FULL, Images.class);
+ String json = objectMapper.writeValueAsString(images);
+ System.out.println("RE-SERIALIZED OBJECT: " + json);
+ JSONAssert.assertEquals(JSON_FULL, json, JSONCompareMode.LENIENT);
}
-} \ No newline at end of file
+ @Test
+ public void testMethods() throws Exception {
+ Images images = objectMapper.readValue(JSON_FULL, Images.class);
+ images.toString();
+
+ List<Image> list = images.getList();
+ Assert.assertNotNull(list);
+ Assert.assertEquals(2, list.size());
+
+ int cnt = 0;
+ for (@SuppressWarnings("unused") Image x : images) {
+ ++cnt;
+ }
+ Assert.assertEquals(2, cnt);
+ }
+}