blob: fee06a4bbab28c8c2e21186884d0ca8fb3028d06 [file] [log] [blame]
Claudine Chiu45920dd2016-07-28 19:19:46 +00001/*
Brian O'Connora09fe5b2017-08-03 21:12:30 -07002 * Copyright 2016-present Open Networking Foundation
Claudine Chiu45920dd2016-07-28 19:19:46 +00003 *
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;
Ray Milkeycc001242018-09-18 14:55:59 -070022import org.onlab.graph.ScalarWeight;
Claudine Chiu45920dd2016-07-28 19:19:46 +000023import org.onlab.junit.TestUtils;
yoonseonc6a69272017-01-12 18:22:20 -080024import org.onlab.osgi.TestServiceDirectory;
Claudine Chiu45920dd2016-07-28 19:19:46 +000025import org.onosproject.common.event.impl.TestEventDispatcher;
26import org.onosproject.core.CoreService;
27import org.onosproject.incubator.net.virtual.TenantId;
28import org.onosproject.incubator.net.virtual.VirtualDevice;
29import org.onosproject.incubator.net.virtual.VirtualLink;
30import org.onosproject.incubator.net.virtual.VirtualNetwork;
31import org.onosproject.incubator.store.virtual.impl.DistributedVirtualNetworkStore;
32import org.onosproject.net.ConnectPoint;
Claudine Chiu45920dd2016-07-28 19:19:46 +000033import org.onosproject.net.DeviceId;
34import org.onosproject.net.DisjointPath;
35import org.onosproject.net.ElementId;
36import org.onosproject.net.Link;
37import org.onosproject.net.NetTestTools;
38import org.onosproject.net.Path;
39import org.onosproject.net.PortNumber;
40import org.onosproject.net.TestDeviceParams;
Ray Milkey7483e1b2018-02-07 15:43:01 -080041import org.onosproject.net.topology.LinkWeigher;
42import org.onosproject.net.topology.LinkWeigherAdapter;
Claudine Chiu45920dd2016-07-28 19:19:46 +000043import 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;
Claudine Chiu45920dd2016-07-28 19:19:46 +000058
yoonseonc6a69272017-01-12 18:22:20 -080059 private TestServiceDirectory testDirectory;
60
Claudine Chiu45920dd2016-07-28 19:19:46 +000061 @Before
62 public void setUp() throws Exception {
63 virtualNetworkManagerStore = new DistributedVirtualNetworkStore();
64
65 CoreService coreService = new TestCoreService();
yoonseonc6a69272017-01-12 18:22:20 -080066 TestUtils.setField(virtualNetworkManagerStore, "coreService", coreService);
Claudine Chiu45920dd2016-07-28 19:19:46 +000067 TestUtils.setField(virtualNetworkManagerStore, "storageService", new TestStorageService());
68 virtualNetworkManagerStore.activate();
69
70 manager = new VirtualNetworkManager();
71 manager.store = virtualNetworkManagerStore;
yoonseon322c9c32016-12-07 16:47:02 -080072 manager.coreService = coreService;
Claudine Chiu45920dd2016-07-28 19:19:46 +000073 NetTestTools.injectEventDispatcher(manager, new TestEventDispatcher());
yoonseonc6a69272017-01-12 18:22:20 -080074
75 testDirectory = new TestServiceDirectory();
76 TestUtils.setField(manager, "serviceDirectory", testDirectory);
77
Claudine Chiu45920dd2016-07-28 19:19:46 +000078 manager.activate();
79 }
80
81 @After
82 public void tearDown() {
83 virtualNetworkManagerStore.deactivate();
84 manager.deactivate();
85 NetTestTools.injectEventDispatcher(manager, null);
86 }
87
88 /**
89 * Sets up an empty virtual network (no devices, links).
90 *
91 * @return virtual network
92 */
93 private VirtualNetwork setupEmptyVnet() {
94 manager.registerTenantId(TenantId.tenantId(tenantIdValue1));
95 return manager.createVirtualNetwork(TenantId.tenantId(tenantIdValue1));
96 }
97
98 /**
99 * Creates a virtual network for further testing.
100 *
101 * @return virtual network
102 */
103 private VirtualNetwork setupVnet() {
104 manager.registerTenantId(TenantId.tenantId(tenantIdValue1));
105 VirtualNetwork virtualNetwork = manager.createVirtualNetwork(TenantId.tenantId(tenantIdValue1));
106 VirtualDevice virtualDevice1 =
107 manager.createVirtualDevice(virtualNetwork.id(), DID1);
108 VirtualDevice virtualDevice2 =
109 manager.createVirtualDevice(virtualNetwork.id(), DID2);
110 VirtualDevice virtualDevice3 =
111 manager.createVirtualDevice(virtualNetwork.id(), DID3);
112 VirtualDevice virtualDevice4 =
113 manager.createVirtualDevice(virtualNetwork.id(), DID4);
114
115 ConnectPoint cp11 = createConnectPointAndVirtualPort(virtualNetwork, virtualDevice1, 1);
116 ConnectPoint cp12 = createConnectPointAndVirtualPort(virtualNetwork, virtualDevice1, 2);
117 ConnectPoint cp23 = createConnectPointAndVirtualPort(virtualNetwork, virtualDevice2, 3);
118 ConnectPoint cp24 = createConnectPointAndVirtualPort(virtualNetwork, virtualDevice2, 4);
119 ConnectPoint cp35 = createConnectPointAndVirtualPort(virtualNetwork, virtualDevice3, 5);
120 ConnectPoint cp36 = createConnectPointAndVirtualPort(virtualNetwork, virtualDevice3, 6);
121 VirtualLink link1 = manager.createVirtualLink(virtualNetwork.id(), cp11, cp23);
122 virtualNetworkManagerStore.updateLink(link1, link1.tunnelId(), Link.State.ACTIVE);
123 VirtualLink link2 = manager.createVirtualLink(virtualNetwork.id(), cp23, cp11);
124 virtualNetworkManagerStore.updateLink(link2, link2.tunnelId(), Link.State.ACTIVE);
125 VirtualLink link3 = manager.createVirtualLink(virtualNetwork.id(), cp24, cp35);
126 virtualNetworkManagerStore.updateLink(link3, link3.tunnelId(), Link.State.ACTIVE);
127 VirtualLink link4 = manager.createVirtualLink(virtualNetwork.id(), cp35, cp24);
128 virtualNetworkManagerStore.updateLink(link4, link4.tunnelId(), Link.State.ACTIVE);
129 VirtualLink link5 = manager.createVirtualLink(virtualNetwork.id(), cp12, cp36);
130 virtualNetworkManagerStore.updateLink(link5, link5.tunnelId(), Link.State.ACTIVE);
131 VirtualLink link6 = manager.createVirtualLink(virtualNetwork.id(), cp36, cp12);
132 virtualNetworkManagerStore.updateLink(link6, link6.tunnelId(), Link.State.ACTIVE);
133
134 return virtualNetwork;
135 }
136
137 /**
138 * Creates a connect point and related virtual port.
139 *
140 * @param vnet virtual network
141 * @param vDev virtual device
142 * @param portNumber port number
143 * @return connect point
144 */
145 private ConnectPoint createConnectPointAndVirtualPort(
146 VirtualNetwork vnet, VirtualDevice vDev, long portNumber) {
147 ConnectPoint cp = new ConnectPoint(vDev.id(), PortNumber.portNumber(portNumber));
148 manager.createVirtualPort(vnet.id(), cp.deviceId(), cp.port(),
Yoonseon Han6c603892016-09-01 11:52:21 -0700149 new ConnectPoint(vDev.id(), cp.port()));
Claudine Chiu45920dd2016-07-28 19:19:46 +0000150 return cp;
151 }
152
153 /**
154 * Tests getPaths(), getDisjointPaths()
155 * on a non-empty virtual network.
156 */
157 @Test
158 public void testGetPathsOnNonEmptyVnet() {
159 VirtualNetwork vnet = setupVnet();
160 PathService pathService = manager.get(vnet.id(), PathService.class);
161
162 // src and dest are in vnet and are connected by a virtual link
163 Set<Path> paths = pathService.getPaths(DID1, DID3);
164 validatePaths(paths, 1, 1, DID1, DID3, 1.0);
165
Ray Milkey7483e1b2018-02-07 15:43:01 -0800166 LinkWeigher linkWeight = new LinkWeigherAdapter(2.0);
Claudine Chiu45920dd2016-07-28 19:19:46 +0000167 paths = pathService.getPaths(DID1, DID3, linkWeight);
168 validatePaths(paths, 1, 1, DID1, DID3, 2.0);
169
170 Set<DisjointPath> disjointPaths = pathService.getDisjointPaths(DID1, DID3);
171 validatePaths(disjointPaths, 1, 1, DID1, DID3, 1.0);
172
173 disjointPaths = pathService.getDisjointPaths(DID1, DID3, linkWeight);
174 validatePaths(disjointPaths, 1, 1, DID1, DID3, 2.0);
175
176 // src and dest are in vnet but are not connected
177 paths = pathService.getPaths(DID4, DID3);
178 assertEquals("incorrect path count", 0, paths.size());
179
180 disjointPaths = pathService.getDisjointPaths(DID4, DID3);
181 assertEquals("incorrect path count", 0, disjointPaths.size());
182
183 // src is in vnet, but dest is not in vnet.
184 DeviceId nonExistentDeviceId = DeviceId.deviceId("nonExistentDevice");
185 paths = pathService.getPaths(DID2, nonExistentDeviceId);
186 assertEquals("incorrect path count", 0, paths.size());
187
188 disjointPaths = pathService.getDisjointPaths(DID2, nonExistentDeviceId);
189 assertEquals("incorrect path count", 0, disjointPaths.size());
190 }
191
192 /**
193 * Tests getPaths(), getDisjointPaths()
194 * on an empty virtual network.
195 */
196 @Test
197 public void testGetPathsOnEmptyVnet() {
198 VirtualNetwork vnet = setupEmptyVnet();
199 PathService pathService = manager.get(vnet.id(), PathService.class);
200
201 Set<Path> paths = pathService.getPaths(DID1, DID3);
202 assertEquals("incorrect path count", 0, paths.size());
203
204 Set<DisjointPath> disjointPaths = pathService.getDisjointPaths(DID1, DID3);
205 assertEquals("incorrect path count", 0, disjointPaths.size());
206 }
207
208 /**
209 * Tests getPaths() using a null source device on an empty virtual network.
210 */
211 @Test(expected = NullPointerException.class)
212 public void testGetPathsWithNullSrc() {
213 VirtualNetwork vnet = setupEmptyVnet();
214 PathService pathService = manager.get(vnet.id(), PathService.class);
215 pathService.getPaths(null, DID3);
216 }
217
218 /**
219 * Tests getPaths() using a null destination device on a non-empty virtual network.
220 */
221 @Test(expected = NullPointerException.class)
222 public void testGetPathsWithNullDest() {
223 VirtualNetwork vnet = setupVnet();
224 PathService pathService = manager.get(vnet.id(), PathService.class);
225 pathService.getPaths(DID1, null);
226 }
227
228
229 // Makes sure the set of paths meets basic expectations.
230 private void validatePaths(Set<? extends Path> paths, int count, int length,
231 ElementId src, ElementId dst, double cost) {
232 assertEquals("incorrect path count", count, paths.size());
233 for (Path path : paths) {
234 assertEquals("incorrect length", length, path.links().size());
235 assertEquals("incorrect source", src, path.src().elementId());
236 assertEquals("incorrect destination", dst, path.dst().elementId());
Ray Milkeycc001242018-09-18 14:55:59 -0700237 assertEquals("incorrect cost", ScalarWeight.toWeight(cost), path.weight());
Claudine Chiu45920dd2016-07-28 19:19:46 +0000238 }
239 }
240}