diff options
author | Ashlee Young <ashlee@onosfw.com> | 2015-09-09 22:15:21 -0700 |
---|---|---|
committer | Ashlee Young <ashlee@onosfw.com> | 2015-09-09 22:15:21 -0700 |
commit | 13d05bc8458758ee39cb829098241e89616717ee (patch) | |
tree | 22a4d1ce65f15952f07a3df5af4b462b4697cb3a /framework/src/onos/apps/demo/cord-gui/src/test | |
parent | 6139282e1e93c2322076de4b91b1c85d0bc4a8b3 (diff) |
ONOS checkin based on commit tag e796610b1f721d02f9b0e213cf6f7790c10ecd60
Change-Id: Ife8810491034fe7becdba75dda20de4267bd15cd
Diffstat (limited to 'framework/src/onos/apps/demo/cord-gui/src/test')
4 files changed, 516 insertions, 0 deletions
diff --git a/framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/CoreModelCacheTest.java b/framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/CoreModelCacheTest.java new file mode 100644 index 00000000..70ef3596 --- /dev/null +++ b/framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/CoreModelCacheTest.java @@ -0,0 +1,299 @@ +/* + * Copyright 2015 Open Networking Laboratory + * + * 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 + * + * 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. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ + +package org.onosproject.cord.gui; + +import com.fasterxml.jackson.databind.JsonNode; +import com.fasterxml.jackson.databind.ObjectMapper; +import com.fasterxml.jackson.databind.node.ObjectNode; +import org.junit.Before; +import org.junit.Ignore; +import org.junit.Test; +import org.onosproject.cord.gui.model.BundleFactory; +import org.onosproject.cord.gui.model.SubscriberUser; + +import java.io.IOException; +import java.util.List; + +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertTrue; + +/** + * Unit tests for {@link CordModelCache}. + */ +@Ignore("How to test against a live XOS system??") +public class CoreModelCacheTest { + + private CordModelCache cache; + + @Before + public void setUp() { + cache = new CordModelCache(); + } + + @Test + public void basic() { + assertEquals("wrong bundle", BundleFactory.BASIC_BUNDLE, + cache.getCurrentBundle().descriptor()); + } + + @Test + public void basicBundleJson() { + ObjectNode node = BundleFactory.toObjectNode(cache.getCurrentBundle()); + String json = node.toString(); + System.out.println(json); + assertTrue("bad basic json", sameJson(BASIC_BUNDLE_JSON, json)); + } + + @Test + public void chooseFamilyBundle() { + cache.setCurrentBundle("family"); + assertEquals("wrong bundle", BundleFactory.FAMILY_BUNDLE, + cache.getCurrentBundle().descriptor()); + } + + @Test + public void familyBundleJson() { + cache.setCurrentBundle("family"); + ObjectNode node = BundleFactory.toObjectNode(cache.getCurrentBundle()); + String json = node.toString(); + System.out.println(json); + assertTrue("bad family json", sameJson(FAMILY_BUNDLE_JSON, json)); + } + + @Test + public void checkUsers() { + List<SubscriberUser> users = cache.getUsers(); + assertEquals("wrong # users", 4, users.size()); + } + + @Test + public void usersBasicJson() { + String json = cache.jsonUsers(); + System.out.println(json); + assertTrue("bad users basic json", sameJson(USERS_BASIC, json)); + } + + @Test + public void usersFamilyJson() { + cache.setCurrentBundle("family"); + String json = cache.jsonUsers(); + System.out.println(json); + assertTrue("bad users family json", sameJson(USERS_FAMILY, json)); + } + + @Test + public void setNewLevel() { + cache.setCurrentBundle("family"); + JsonNode node = fromString(cache.jsonUsers()); + assertEquals("wrong level", "G", getMomsLevel(node)); + + cache.applyPerUserParam("1", "url_filter", "level", "R"); + + node = fromString(cache.jsonUsers()); + assertEquals("wrong level", "R", getMomsLevel(node)); + } + + private String getMomsLevel(JsonNode node) { + JsonNode mom = node.get("users").elements().next(); + assertEquals("wrong ID", 1, mom.get("id").asInt()); + return mom.get("profile").get("url_filter").get("level").asText(); + } + + + // ============= + + private JsonNode fromString(String s) { + try { + return MAPPER.readTree(s); + } catch (IOException e) { + System.out.println("Exception: " + e); + } + return null; + } + + private boolean sameJson(String s1, String s2) { + try { + JsonNode tree1 = MAPPER.readTree(s1); + JsonNode tree2 = MAPPER.readTree(s2); + return tree1.equals(tree2); + } catch (IOException e) { + System.out.println("Exception: " + e); + } + return false; + } + + private static final ObjectMapper MAPPER = new ObjectMapper(); + + private static final String BASIC_BUNDLE_JSON = "{\n" + + " \"bundle\": {\n" + + " \"id\": \"basic\",\n" + + " \"name\": \"Basic Bundle\",\n" + + " \"desc\": \"Provides basic internet and firewall functions.\",\n" + + " \"functions\": [\n" + + " {\n" + + " \"id\": \"internet\",\n" + + " \"name\": \"Internet\",\n" + + " \"desc\": \"Basic internet connectivity.\",\n" + + " \"params\": {}\n" + + " },\n" + + " {\n" + + " \"id\": \"firewall\",\n" + + " \"name\": \"Firewall\",\n" + + " \"desc\": \"Normal firewall protection.\",\n" + + " \"params\": {}\n" + + " }\n" + + " ]\n" + + " },\n" + + " \"bundles\": [\n" + + " {\n" + + " \"id\": \"basic\",\n" + + " \"name\": \"Basic Bundle\",\n" + + " \"desc\": \"Provides basic internet and firewall functions.\"\n" + + " },\n" + + " {\n" + + " \"id\": \"family\",\n" + + " \"name\": \"Family Bundle\",\n" + + " \"desc\": \"Provides internet, firewall and parental control functions.\"\n" + + " }\n" + + " ]\n" + + "}\n"; + + private static final String FAMILY_BUNDLE_JSON = "{\n" + + " \"bundle\": {\n" + + " \"id\": \"family\",\n" + + " \"name\": \"Family Bundle\",\n" + + " \"desc\": \"Provides internet, firewall and parental control functions.\",\n" + + " \"functions\": [\n" + + " {\n" + + " \"id\": \"internet\",\n" + + " \"name\": \"Internet\",\n" + + " \"desc\": \"Basic internet connectivity.\",\n" + + " \"params\": {}\n" + + " },\n" + + " {\n" + + " \"id\": \"firewall\",\n" + + " \"name\": \"Firewall\",\n" + + " \"desc\": \"Normal firewall protection.\",\n" + + " \"params\": {}\n" + + " },\n" + + " {\n" + + " \"id\": \"url_filter\",\n" + + " \"name\": \"Parental Control\",\n" + + " \"desc\": \"Variable levels of URL filtering.\",\n" + + " \"params\": {\n" + + " \"level\": \"G\",\n" + + " \"levels\": [\n" + + " \"OFF\",\n" + + " \"G\",\n" + + " \"PG\",\n" + + " \"PG_13\",\n" + + " \"R\",\n" + + " \"NONE\"\n" + + " ]\n" + + " }\n" + + " }\n" + + " ]\n" + + " },\n" + + " \"bundles\": [\n" + + " {\n" + + " \"id\": \"basic\",\n" + + " \"name\": \"Basic Bundle\",\n" + + " \"desc\": \"Provides basic internet and firewall functions.\"\n" + + " },\n" + + " {\n" + + " \"id\": \"family\",\n" + + " \"name\": \"Family Bundle\",\n" + + " \"desc\": \"Provides internet, firewall and parental control functions.\"\n" + + " }\n" + + " ]\n" + + "}\n"; + + private static final String USERS_BASIC = "{\n" + + " \"users\": [\n" + + " {\n" + + " \"id\": 1,\n" + + " \"name\": \"Mom's MacBook\",\n" + + " \"mac\": \"010203040506\",\n" + + " \"profile\": { }\n" + + " },\n" + + " {\n" + + " \"id\": 2,\n" + + " \"name\": \"Dad's iPad\",\n" + + " \"mac\": \"010203040507\",\n" + + " \"profile\": { }\n" + + " },\n" + + " {\n" + + " \"id\": 3,\n" + + " \"name\": \"Dick's laptop\",\n" + + " \"mac\": \"010203040508\",\n" + + " \"profile\": { }\n" + + " },\n" + + " {\n" + + " \"id\": 4,\n" + + " \"name\": \"Jane's laptop\",\n" + + " \"mac\": \"010203040509\",\n" + + " \"profile\": { }\n" + + " }\n" + + " ]\n" + + "}\n"; + + private static final String USERS_FAMILY = "{\n" + + " \"users\": [\n" + + " {\n" + + " \"id\": 1,\n" + + " \"name\": \"Mom's MacBook\",\n" + + " \"mac\": \"010203040506\",\n" + + " \"profile\": {\n" + + " \"url_filter\": {\n" + + " \"level\": \"G\"\n" + + " }\n" + + " }\n" + + " },\n" + + " {\n" + + " \"id\": 2,\n" + + " \"name\": \"Dad's iPad\",\n" + + " \"mac\": \"010203040507\",\n" + + " \"profile\": {\n" + + " \"url_filter\": {\n" + + " \"level\": \"G\"\n" + + " }\n" + + " }\n" + + " },\n" + + " {\n" + + " \"id\": 3,\n" + + " \"name\": \"Dick's laptop\",\n" + + " \"mac\": \"010203040508\",\n" + + " \"profile\": {\n" + + " \"url_filter\": {\n" + + " \"level\": \"G\"\n" + + " }\n" + + " }\n" + + " },\n" + + " {\n" + + " \"id\": 4,\n" + + " \"name\": \"Jane's laptop\",\n" + + " \"mac\": \"010203040509\",\n" + + " \"profile\": {\n" + + " \"url_filter\": {\n" + + " \"level\": \"G\"\n" + + " }\n" + + " }\n" + + " }\n" + + " ]\n" + + "}\n"; +} diff --git a/framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/model/BundleFactoryTest.java b/framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/model/BundleFactoryTest.java new file mode 100644 index 00000000..a4d662e3 --- /dev/null +++ b/framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/model/BundleFactoryTest.java @@ -0,0 +1,77 @@ +/* + * Copyright 2015 Open Networking Laboratory + * + * 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 + * + * 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. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ + +package org.onosproject.cord.gui.model; + +import org.junit.Test; + +import java.util.Set; + +import static org.junit.Assert.*; +import static org.onosproject.cord.gui.model.BundleFactory.*; +import static org.onosproject.cord.gui.model.XosFunctionDescriptor.*; + +/** + * Unit tests for {@link BundleFactory}. + */ +public class BundleFactoryTest { + + @Test + public void bundleCount() { + assertEquals("wrong count", 2, availableBundles().size()); + assertTrue("missing basic", availableBundles().contains(BASIC_BUNDLE)); + assertTrue("missing family", availableBundles().contains(FAMILY_BUNDLE)); + } + + @Test + public void basicBundle() { + BundleDescriptor bundle = BundleFactory.BASIC_BUNDLE; + assertEquals("wrong id", "basic", bundle.id()); + assertEquals("wrong id", "Basic Bundle", bundle.displayName()); + Set<XosFunctionDescriptor> funcs = bundle.functions(); + assertTrue("missing internet", funcs.contains(INTERNET)); + assertTrue("missing firewall", funcs.contains(FIREWALL)); + assertFalse("unexpected url-f", funcs.contains(URL_FILTER)); + } + + @Test + public void familyBundle() { + BundleDescriptor bundle = BundleFactory.FAMILY_BUNDLE; + assertEquals("wrong id", "family", bundle.id()); + assertEquals("wrong id", "Family Bundle", bundle.displayName()); + Set<XosFunctionDescriptor> funcs = bundle.functions(); + assertTrue("missing internet", funcs.contains(INTERNET)); + assertTrue("missing firewall", funcs.contains(FIREWALL)); + assertTrue("missing url-f", funcs.contains(URL_FILTER)); + } + + @Test + public void bundleFromIdBasic() { + assertEquals("wrong bundle", BASIC_BUNDLE, bundleFromId("basic")); + } + + @Test + public void bundleFromIdFamily() { + assertEquals("wrong bundle", FAMILY_BUNDLE, bundleFromId("family")); + } + + @Test(expected = IllegalArgumentException.class) + public void bundleFromIdUnknown() { + bundleFromId("unknown"); + } +} + diff --git a/framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/model/UrlFilterFunctionTest.java b/framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/model/UrlFilterFunctionTest.java new file mode 100644 index 00000000..9995227c --- /dev/null +++ b/framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/model/UrlFilterFunctionTest.java @@ -0,0 +1,74 @@ +/* + * Copyright 2015 Open Networking Laboratory + * + * 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 + * + * 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. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ + +package org.onosproject.cord.gui.model; + +import org.junit.Before; +import org.junit.Test; + +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertTrue; + +/** + * Unit tests for {@link UrlFilterFunction}. + */ +public class UrlFilterFunctionTest { + + private SubscriberUser user = new SubscriberUser(1, "foo", "fooMAC", "levelX"); + private UrlFilterFunction fn; + + @Before + public void setUp() { + fn = new UrlFilterFunction(); + } + + @Test + public void basic() { + assertEquals("wrong enum const count", + 6, UrlFilterFunction.Level.values().length); + } + + @Test + public void memento() { + XosFunction.Memento memo = fn.createMemento(); + assertTrue("wrong class", memo instanceof UrlFilterFunction.UrlFilterMemento); + UrlFilterFunction.UrlFilterMemento umemo = + (UrlFilterFunction.UrlFilterMemento) memo; + assertEquals("wrong default level", "G", umemo.level()); + } + + @Test + public void memoNewLevel() { + XosFunction.Memento memo = fn.createMemento(); + assertTrue("wrong class", memo instanceof UrlFilterFunction.UrlFilterMemento); + UrlFilterFunction.UrlFilterMemento umemo = + (UrlFilterFunction.UrlFilterMemento) memo; + assertEquals("wrong default level", "G", umemo.level()); + umemo.setLevel(UrlFilterFunction.Level.R); + assertEquals("wrong new level", "R", umemo.level()); + } + + @Test + public void applyMemo() { + UrlFilterFunction.UrlFilterMemento memo = + (UrlFilterFunction.UrlFilterMemento) fn.createMemento(); + memo.setLevel(UrlFilterFunction.Level.PG_13); + user.setMemento(XosFunctionDescriptor.URL_FILTER, memo); + + assertEquals("wrong URL suffix", "url_filter/PG_13", fn.xosUrlApply(user)); + } +} diff --git a/framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/model/XosFunctionDescriptorTest.java b/framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/model/XosFunctionDescriptorTest.java new file mode 100644 index 00000000..022c397a --- /dev/null +++ b/framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/model/XosFunctionDescriptorTest.java @@ -0,0 +1,66 @@ +/* + * Copyright 2015 Open Networking Laboratory + * + * 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 + * + * 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. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ + +package org.onosproject.cord.gui.model; + +import org.junit.Test; + +import static org.junit.Assert.*; +import static org.onosproject.cord.gui.model.XosFunctionDescriptor.*; + +/** + * Sanity unit tests for {@link XosFunctionDescriptor}. + */ +public class XosFunctionDescriptorTest { + + @Test + public void numberOfFunctions() { + assertEquals("unexpected constant count", 4, values().length); + } + + @Test + public void internet() { + assertEquals("wrong id", "internet", INTERNET.id()); + assertEquals("wrong display", "Internet", INTERNET.displayName()); + assertTrue("wrong desc", INTERNET.description().startsWith("Basic")); + assertFalse("wrong backend", INTERNET.backend()); + } + + @Test + public void firewall() { + assertEquals("wrong id", "firewall", FIREWALL.id()); + assertEquals("wrong display", "Firewall", FIREWALL.displayName()); + assertTrue("wrong desc", FIREWALL.description().startsWith("Normal")); + assertTrue("wrong backend", FIREWALL.backend()); + } + + @Test + public void urlFilter() { + assertEquals("wrong id", "url_filter", URL_FILTER.id()); + assertEquals("wrong display", "Parental Control", URL_FILTER.displayName()); + assertTrue("wrong desc", URL_FILTER.description().startsWith("Variable")); + assertTrue("wrong backend", URL_FILTER.backend()); + } + + @Test + public void cdn() { + assertEquals("wrong id", "cdn", CDN.id()); + assertEquals("wrong display", "CDN", CDN.displayName()); + assertTrue("wrong desc", CDN.description().startsWith("Content")); + assertTrue("wrong backend", CDN.backend()); + } +} |