summaryrefslogtreecommitdiffstats
path: root/framework/src/onos/apps/demo/cord-gui/src/test
diff options
context:
space:
mode:
Diffstat (limited to 'framework/src/onos/apps/demo/cord-gui/src/test')
-rw-r--r--framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/CoreModelCacheTest.java299
-rw-r--r--framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/model/BundleFactoryTest.java77
-rw-r--r--framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/model/UrlFilterFunctionTest.java74
-rw-r--r--framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/model/XosFunctionDescriptorTest.java66
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());
+ }
+}