diff options
author | CNlucius <lukai1@huawei.com> | 2016-09-13 11:40:12 +0800 |
---|---|---|
committer | CNlucius <lukai1@huawei.com> | 2016-09-13 11:41:53 +0800 |
commit | b731e2f1dd0972409b136aebc7b463dd72c9cfad (patch) | |
tree | 5107d7d80c19ad8076c2c97c2b5ef8d1cf3ab903 /framework/src/onos/apps/demo/cord-gui/src/test/org | |
parent | ee93993458266114c29271a481ef9ce7ce621b2a (diff) |
ONOSFW-171
O/S-SFC-ONOS scenario documentation
Change-Id: I51ae1cf736ea24ab6680f8edca1b2bf5dd598365
Signed-off-by: CNlucius <lukai1@huawei.com>
Diffstat (limited to 'framework/src/onos/apps/demo/cord-gui/src/test/org')
4 files changed, 0 insertions, 516 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 deleted file mode 100644 index 70ef3596..00000000 --- a/framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/CoreModelCacheTest.java +++ /dev/null @@ -1,299 +0,0 @@ -/* - * 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 deleted file mode 100644 index a4d662e3..00000000 --- a/framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/model/BundleFactoryTest.java +++ /dev/null @@ -1,77 +0,0 @@ -/* - * 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 deleted file mode 100644 index 9995227c..00000000 --- a/framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/model/UrlFilterFunctionTest.java +++ /dev/null @@ -1,74 +0,0 @@ -/* - * 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 deleted file mode 100644 index 022c397a..00000000 --- a/framework/src/onos/apps/demo/cord-gui/src/test/org/onosproject/cord/gui/model/XosFunctionDescriptorTest.java +++ /dev/null @@ -1,66 +0,0 @@ -/* - * 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()); - } -} |