blob: 768bc4d9c9695a8068f75cf2701813c8e0e4d71d [file] [log] [blame]
Claudine Chiu45920dd2016-07-28 19:19:46 +00001/*
2 * Copyright 2016-present Open Networking Laboratory
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package org.onosproject.incubator.net.virtual.impl;
18
19import org.junit.After;
20import org.junit.Before;
21import org.junit.Test;
22import org.onlab.junit.TestUtils;
yoonseonc6a69272017-01-12 18:22:20 -080023import org.onlab.osgi.TestServiceDirectory;
Claudine Chiu45920dd2016-07-28 19:19:46 +000024import org.onosproject.common.event.impl.TestEventDispatcher;
25import org.onosproject.core.CoreService;
26import org.onosproject.incubator.net.virtual.TenantId;
27import org.onosproject.incubator.net.virtual.VirtualDevice;
28import org.onosproject.incubator.net.virtual.VirtualLink;
29import org.onosproject.incubator.net.virtual.VirtualNetwork;
30import org.onosproject.incubator.store.virtual.impl.DistributedVirtualNetworkStore;
31import org.onosproject.net.ConnectPoint;
Claudine Chiu45920dd2016-07-28 19:19:46 +000032import org.onosproject.net.DeviceId;
33import org.onosproject.net.DisjointPath;
34import org.onosproject.net.ElementId;
35import org.onosproject.net.Link;
36import org.onosproject.net.NetTestTools;
37import org.onosproject.net.Path;
38import org.onosproject.net.PortNumber;
39import org.onosproject.net.TestDeviceParams;
40import org.onosproject.net.intent.FakeIntentManager;
41import org.onosproject.net.intent.TestableIntentService;
42import org.onosproject.net.topology.LinkWeight;
43import org.onosproject.net.topology.PathService;
44import org.onosproject.store.service.TestStorageService;
45
46import java.util.Set;
47
48import static org.junit.Assert.assertEquals;
49
50/**
51 * Junit tests for VirtualNetworkPathService.
52 */
yoonseon214963b2016-11-21 15:41:07 -080053public class VirtualNetworkPathManagerTest extends TestDeviceParams {
Claudine Chiu45920dd2016-07-28 19:19:46 +000054 private final String tenantIdValue1 = "TENANT_ID1";
55
56 private VirtualNetworkManager manager;
57 private DistributedVirtualNetworkStore virtualNetworkManagerStore;
58 private final TestableIntentService intentService = new FakeIntentManager();
59
yoonseonc6a69272017-01-12 18:22:20 -080060 private TestServiceDirectory testDirectory;
61
Claudine Chiu45920dd2016-07-28 19:19:46 +000062 @Before
63 public void setUp() throws Exception {
64 virtualNetworkManagerStore = new DistributedVirtualNetworkStore();
65
66 CoreService coreService = new TestCoreService();
yoonseonc6a69272017-01-12 18:22:20 -080067 TestUtils.setField(virtualNetworkManagerStore, "coreService", coreService);
Claudine Chiu45920dd2016-07-28 19:19:46 +000068 TestUtils.setField(virtualNetworkManagerStore, "storageService", new TestStorageService());
69 virtualNetworkManagerStore.activate();
70
71 manager = new VirtualNetworkManager();
72 manager.store = virtualNetworkManagerStore;
73 manager.intentService = intentService;
74 NetTestTools.injectEventDispatcher(manager, new TestEventDispatcher());
yoonseonc6a69272017-01-12 18:22:20 -080075
76 testDirectory = new TestServiceDirectory();
77 TestUtils.setField(manager, "serviceDirectory", testDirectory);
78
Claudine Chiu45920dd2016-07-28 19:19:46 +000079 manager.activate();
80 }
81
82 @After
83 public void tearDown() {
84 virtualNetworkManagerStore.deactivate();
85 manager.deactivate();
86 NetTestTools.injectEventDispatcher(manager, null);
87 }
88
89 /**
90 * Sets up an empty virtual network (no devices, links).
91 *
92 * @return virtual network
93 */
94 private VirtualNetwork setupEmptyVnet() {
95 manager.registerTenantId(TenantId.tenantId(tenantIdValue1));
96 return manager.createVirtualNetwork(TenantId.tenantId(tenantIdValue1));
97 }
98
99 /**
100 * Creates a virtual network for further testing.
101 *
102 * @return virtual network
103 */
104 private VirtualNetwork setupVnet() {
105 manager.registerTenantId(TenantId.tenantId(tenantIdValue1));
106 VirtualNetwork virtualNetwork = manager.createVirtualNetwork(TenantId.tenantId(tenantIdValue1));
107 VirtualDevice virtualDevice1 =
108 manager.createVirtualDevice(virtualNetwork.id(), DID1);
109 VirtualDevice virtualDevice2 =
110 manager.createVirtualDevice(virtualNetwork.id(), DID2);
111 VirtualDevice virtualDevice3 =
112 manager.createVirtualDevice(virtualNetwork.id(), DID3);
113 VirtualDevice virtualDevice4 =
114 manager.createVirtualDevice(virtualNetwork.id(), DID4);
115
116 ConnectPoint cp11 = createConnectPointAndVirtualPort(virtualNetwork, virtualDevice1, 1);
117 ConnectPoint cp12 = createConnectPointAndVirtualPort(virtualNetwork, virtualDevice1, 2);
118 ConnectPoint cp23 = createConnectPointAndVirtualPort(virtualNetwork, virtualDevice2, 3);
119 ConnectPoint cp24 = createConnectPointAndVirtualPort(virtualNetwork, virtualDevice2, 4);
120 ConnectPoint cp35 = createConnectPointAndVirtualPort(virtualNetwork, virtualDevice3, 5);
121 ConnectPoint cp36 = createConnectPointAndVirtualPort(virtualNetwork, virtualDevice3, 6);
122 VirtualLink link1 = manager.createVirtualLink(virtualNetwork.id(), cp11, cp23);
123 virtualNetworkManagerStore.updateLink(link1, link1.tunnelId(), Link.State.ACTIVE);
124 VirtualLink link2 = manager.createVirtualLink(virtualNetwork.id(), cp23, cp11);
125 virtualNetworkManagerStore.updateLink(link2, link2.tunnelId(), Link.State.ACTIVE);
126 VirtualLink link3 = manager.createVirtualLink(virtualNetwork.id(), cp24, cp35);
127 virtualNetworkManagerStore.updateLink(link3, link3.tunnelId(), Link.State.ACTIVE);
128 VirtualLink link4 = manager.createVirtualLink(virtualNetwork.id(), cp35, cp24);
129 virtualNetworkManagerStore.updateLink(link4, link4.tunnelId(), Link.State.ACTIVE);
130 VirtualLink link5 = manager.createVirtualLink(virtualNetwork.id(), cp12, cp36);
131 virtualNetworkManagerStore.updateLink(link5, link5.tunnelId(), Link.State.ACTIVE);
132 VirtualLink link6 = manager.createVirtualLink(virtualNetwork.id(), cp36, cp12);
133 virtualNetworkManagerStore.updateLink(link6, link6.tunnelId(), Link.State.ACTIVE);
134
135 return virtualNetwork;
136 }
137
138 /**
139 * Creates a connect point and related virtual port.
140 *
141 * @param vnet virtual network
142 * @param vDev virtual device
143 * @param portNumber port number
144 * @return connect point
145 */
146 private ConnectPoint createConnectPointAndVirtualPort(
147 VirtualNetwork vnet, VirtualDevice vDev, long portNumber) {
148 ConnectPoint cp = new ConnectPoint(vDev.id(), PortNumber.portNumber(portNumber));
149 manager.createVirtualPort(vnet.id(), cp.deviceId(), cp.port(),
Yoonseon Han6c603892016-09-01 11:52:21 -0700150 new ConnectPoint(vDev.id(), cp.port()));
Claudine Chiu45920dd2016-07-28 19:19:46 +0000151 return cp;
152 }
153
154 /**
155 * Tests getPaths(), getDisjointPaths()
156 * on a non-empty virtual network.
157 */
158 @Test
159 public void testGetPathsOnNonEmptyVnet() {
160 VirtualNetwork vnet = setupVnet();
161 PathService pathService = manager.get(vnet.id(), PathService.class);
162
163 // src and dest are in vnet and are connected by a virtual link
164 Set<Path> paths = pathService.getPaths(DID1, DID3);
165 validatePaths(paths, 1, 1, DID1, DID3, 1.0);
166
167 LinkWeight linkWeight = edge -> 2.0;
168 paths = pathService.getPaths(DID1, DID3, linkWeight);
169 validatePaths(paths, 1, 1, DID1, DID3, 2.0);
170
171 Set<DisjointPath> disjointPaths = pathService.getDisjointPaths(DID1, DID3);
172 validatePaths(disjointPaths, 1, 1, DID1, DID3, 1.0);
173
174 disjointPaths = pathService.getDisjointPaths(DID1, DID3, linkWeight);
175 validatePaths(disjointPaths, 1, 1, DID1, DID3, 2.0);
176
177 // src and dest are in vnet but are not connected
178 paths = pathService.getPaths(DID4, DID3);
179 assertEquals("incorrect path count", 0, paths.size());
180
181 disjointPaths = pathService.getDisjointPaths(DID4, DID3);
182 assertEquals("incorrect path count", 0, disjointPaths.size());
183
184 // src is in vnet, but dest is not in vnet.
185 DeviceId nonExistentDeviceId = DeviceId.deviceId("nonExistentDevice");
186 paths = pathService.getPaths(DID2, nonExistentDeviceId);
187 assertEquals("incorrect path count", 0, paths.size());
188
189 disjointPaths = pathService.getDisjointPaths(DID2, nonExistentDeviceId);
190 assertEquals("incorrect path count", 0, disjointPaths.size());
191 }
192
193 /**
194 * Tests getPaths(), getDisjointPaths()
195 * on an empty virtual network.
196 */
197 @Test
198 public void testGetPathsOnEmptyVnet() {
199 VirtualNetwork vnet = setupEmptyVnet();
200 PathService pathService = manager.get(vnet.id(), PathService.class);
201
202 Set<Path> paths = pathService.getPaths(DID1, DID3);
203 assertEquals("incorrect path count", 0, paths.size());
204
205 Set<DisjointPath> disjointPaths = pathService.getDisjointPaths(DID1, DID3);
206 assertEquals("incorrect path count", 0, disjointPaths.size());
207 }
208
209 /**
210 * Tests getPaths() using a null source device on an empty virtual network.
211 */
212 @Test(expected = NullPointerException.class)
213 public void testGetPathsWithNullSrc() {
214 VirtualNetwork vnet = setupEmptyVnet();
215 PathService pathService = manager.get(vnet.id(), PathService.class);
216 pathService.getPaths(null, DID3);
217 }
218
219 /**
220 * Tests getPaths() using a null destination device on a non-empty virtual network.
221 */
222 @Test(expected = NullPointerException.class)
223 public void testGetPathsWithNullDest() {
224 VirtualNetwork vnet = setupVnet();
225 PathService pathService = manager.get(vnet.id(), PathService.class);
226 pathService.getPaths(DID1, null);
227 }
228
229
230 // Makes sure the set of paths meets basic expectations.
231 private void validatePaths(Set<? extends Path> paths, int count, int length,
232 ElementId src, ElementId dst, double cost) {
233 assertEquals("incorrect path count", count, paths.size());
234 for (Path path : paths) {
235 assertEquals("incorrect length", length, path.links().size());
236 assertEquals("incorrect source", src, path.src().elementId());
237 assertEquals("incorrect destination", dst, path.dst().elementId());
238 assertEquals("incorrect cost", cost, path.cost(), 0);
239 }
240 }
241}