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