blob: 9a1faf7d38f7c1eeec62c4e7872d9ee0a8df01b0 [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;
23import org.onosproject.common.event.impl.TestEventDispatcher;
24import org.onosproject.core.CoreService;
25import org.onosproject.incubator.net.virtual.TenantId;
26import org.onosproject.incubator.net.virtual.VirtualDevice;
27import org.onosproject.incubator.net.virtual.VirtualLink;
28import org.onosproject.incubator.net.virtual.VirtualNetwork;
29import org.onosproject.incubator.store.virtual.impl.DistributedVirtualNetworkStore;
30import org.onosproject.net.ConnectPoint;
Claudine Chiu45920dd2016-07-28 19:19:46 +000031import org.onosproject.net.DeviceId;
32import org.onosproject.net.DisjointPath;
33import org.onosproject.net.ElementId;
34import org.onosproject.net.Link;
35import org.onosproject.net.NetTestTools;
36import org.onosproject.net.Path;
37import org.onosproject.net.PortNumber;
38import org.onosproject.net.TestDeviceParams;
39import org.onosproject.net.intent.FakeIntentManager;
40import org.onosproject.net.intent.TestableIntentService;
41import org.onosproject.net.topology.LinkWeight;
42import org.onosproject.net.topology.PathService;
43import org.onosproject.store.service.TestStorageService;
44
45import java.util.Set;
46
47import static org.junit.Assert.assertEquals;
48
49/**
50 * Junit tests for VirtualNetworkPathService.
51 */
52public class VirtualNetworkPathServiceTest extends TestDeviceParams {
53 private final String tenantIdValue1 = "TENANT_ID1";
54
55 private VirtualNetworkManager manager;
56 private DistributedVirtualNetworkStore virtualNetworkManagerStore;
57 private final TestableIntentService intentService = new FakeIntentManager();
58
59 @Before
60 public void setUp() throws Exception {
61 virtualNetworkManagerStore = new DistributedVirtualNetworkStore();
62
63 CoreService coreService = new TestCoreService();
64 virtualNetworkManagerStore.setCoreService(coreService);
65 TestUtils.setField(virtualNetworkManagerStore, "storageService", new TestStorageService());
66 virtualNetworkManagerStore.activate();
67
68 manager = new VirtualNetworkManager();
69 manager.store = virtualNetworkManagerStore;
70 manager.intentService = intentService;
71 NetTestTools.injectEventDispatcher(manager, new TestEventDispatcher());
72 manager.activate();
73 }
74
75 @After
76 public void tearDown() {
77 virtualNetworkManagerStore.deactivate();
78 manager.deactivate();
79 NetTestTools.injectEventDispatcher(manager, null);
80 }
81
82 /**
83 * Sets up an empty virtual network (no devices, links).
84 *
85 * @return virtual network
86 */
87 private VirtualNetwork setupEmptyVnet() {
88 manager.registerTenantId(TenantId.tenantId(tenantIdValue1));
89 return manager.createVirtualNetwork(TenantId.tenantId(tenantIdValue1));
90 }
91
92 /**
93 * Creates a virtual network for further testing.
94 *
95 * @return virtual network
96 */
97 private VirtualNetwork setupVnet() {
98 manager.registerTenantId(TenantId.tenantId(tenantIdValue1));
99 VirtualNetwork virtualNetwork = manager.createVirtualNetwork(TenantId.tenantId(tenantIdValue1));
100 VirtualDevice virtualDevice1 =
101 manager.createVirtualDevice(virtualNetwork.id(), DID1);
102 VirtualDevice virtualDevice2 =
103 manager.createVirtualDevice(virtualNetwork.id(), DID2);
104 VirtualDevice virtualDevice3 =
105 manager.createVirtualDevice(virtualNetwork.id(), DID3);
106 VirtualDevice virtualDevice4 =
107 manager.createVirtualDevice(virtualNetwork.id(), DID4);
108
109 ConnectPoint cp11 = createConnectPointAndVirtualPort(virtualNetwork, virtualDevice1, 1);
110 ConnectPoint cp12 = createConnectPointAndVirtualPort(virtualNetwork, virtualDevice1, 2);
111 ConnectPoint cp23 = createConnectPointAndVirtualPort(virtualNetwork, virtualDevice2, 3);
112 ConnectPoint cp24 = createConnectPointAndVirtualPort(virtualNetwork, virtualDevice2, 4);
113 ConnectPoint cp35 = createConnectPointAndVirtualPort(virtualNetwork, virtualDevice3, 5);
114 ConnectPoint cp36 = createConnectPointAndVirtualPort(virtualNetwork, virtualDevice3, 6);
115 VirtualLink link1 = manager.createVirtualLink(virtualNetwork.id(), cp11, cp23);
116 virtualNetworkManagerStore.updateLink(link1, link1.tunnelId(), Link.State.ACTIVE);
117 VirtualLink link2 = manager.createVirtualLink(virtualNetwork.id(), cp23, cp11);
118 virtualNetworkManagerStore.updateLink(link2, link2.tunnelId(), Link.State.ACTIVE);
119 VirtualLink link3 = manager.createVirtualLink(virtualNetwork.id(), cp24, cp35);
120 virtualNetworkManagerStore.updateLink(link3, link3.tunnelId(), Link.State.ACTIVE);
121 VirtualLink link4 = manager.createVirtualLink(virtualNetwork.id(), cp35, cp24);
122 virtualNetworkManagerStore.updateLink(link4, link4.tunnelId(), Link.State.ACTIVE);
123 VirtualLink link5 = manager.createVirtualLink(virtualNetwork.id(), cp12, cp36);
124 virtualNetworkManagerStore.updateLink(link5, link5.tunnelId(), Link.State.ACTIVE);
125 VirtualLink link6 = manager.createVirtualLink(virtualNetwork.id(), cp36, cp12);
126 virtualNetworkManagerStore.updateLink(link6, link6.tunnelId(), Link.State.ACTIVE);
127
128 return virtualNetwork;
129 }
130
131 /**
132 * Creates a connect point and related virtual port.
133 *
134 * @param vnet virtual network
135 * @param vDev virtual device
136 * @param portNumber port number
137 * @return connect point
138 */
139 private ConnectPoint createConnectPointAndVirtualPort(
140 VirtualNetwork vnet, VirtualDevice vDev, long portNumber) {
141 ConnectPoint cp = new ConnectPoint(vDev.id(), PortNumber.portNumber(portNumber));
142 manager.createVirtualPort(vnet.id(), cp.deviceId(), cp.port(),
Yoonseon Han6c603892016-09-01 11:52:21 -0700143 new ConnectPoint(vDev.id(), cp.port()));
Claudine Chiu45920dd2016-07-28 19:19:46 +0000144 return cp;
145 }
146
147 /**
148 * Tests getPaths(), getDisjointPaths()
149 * on a non-empty virtual network.
150 */
151 @Test
152 public void testGetPathsOnNonEmptyVnet() {
153 VirtualNetwork vnet = setupVnet();
154 PathService pathService = manager.get(vnet.id(), PathService.class);
155
156 // src and dest are in vnet and are connected by a virtual link
157 Set<Path> paths = pathService.getPaths(DID1, DID3);
158 validatePaths(paths, 1, 1, DID1, DID3, 1.0);
159
160 LinkWeight linkWeight = edge -> 2.0;
161 paths = pathService.getPaths(DID1, DID3, linkWeight);
162 validatePaths(paths, 1, 1, DID1, DID3, 2.0);
163
164 Set<DisjointPath> disjointPaths = pathService.getDisjointPaths(DID1, DID3);
165 validatePaths(disjointPaths, 1, 1, DID1, DID3, 1.0);
166
167 disjointPaths = pathService.getDisjointPaths(DID1, DID3, linkWeight);
168 validatePaths(disjointPaths, 1, 1, DID1, DID3, 2.0);
169
170 // src and dest are in vnet but are not connected
171 paths = pathService.getPaths(DID4, DID3);
172 assertEquals("incorrect path count", 0, paths.size());
173
174 disjointPaths = pathService.getDisjointPaths(DID4, DID3);
175 assertEquals("incorrect path count", 0, disjointPaths.size());
176
177 // src is in vnet, but dest is not in vnet.
178 DeviceId nonExistentDeviceId = DeviceId.deviceId("nonExistentDevice");
179 paths = pathService.getPaths(DID2, nonExistentDeviceId);
180 assertEquals("incorrect path count", 0, paths.size());
181
182 disjointPaths = pathService.getDisjointPaths(DID2, nonExistentDeviceId);
183 assertEquals("incorrect path count", 0, disjointPaths.size());
184 }
185
186 /**
187 * Tests getPaths(), getDisjointPaths()
188 * on an empty virtual network.
189 */
190 @Test
191 public void testGetPathsOnEmptyVnet() {
192 VirtualNetwork vnet = setupEmptyVnet();
193 PathService pathService = manager.get(vnet.id(), PathService.class);
194
195 Set<Path> paths = pathService.getPaths(DID1, DID3);
196 assertEquals("incorrect path count", 0, paths.size());
197
198 Set<DisjointPath> disjointPaths = pathService.getDisjointPaths(DID1, DID3);
199 assertEquals("incorrect path count", 0, disjointPaths.size());
200 }
201
202 /**
203 * Tests getPaths() using a null source device on an empty virtual network.
204 */
205 @Test(expected = NullPointerException.class)
206 public void testGetPathsWithNullSrc() {
207 VirtualNetwork vnet = setupEmptyVnet();
208 PathService pathService = manager.get(vnet.id(), PathService.class);
209 pathService.getPaths(null, DID3);
210 }
211
212 /**
213 * Tests getPaths() using a null destination device on a non-empty virtual network.
214 */
215 @Test(expected = NullPointerException.class)
216 public void testGetPathsWithNullDest() {
217 VirtualNetwork vnet = setupVnet();
218 PathService pathService = manager.get(vnet.id(), PathService.class);
219 pathService.getPaths(DID1, null);
220 }
221
222
223 // Makes sure the set of paths meets basic expectations.
224 private void validatePaths(Set<? extends Path> paths, int count, int length,
225 ElementId src, ElementId dst, double cost) {
226 assertEquals("incorrect path count", count, paths.size());
227 for (Path path : paths) {
228 assertEquals("incorrect length", length, path.links().size());
229 assertEquals("incorrect source", src, path.src().elementId());
230 assertEquals("incorrect destination", dst, path.dst().elementId());
231 assertEquals("incorrect cost", cost, path.cost(), 0);
232 }
233 }
234}