blob: 6502373e656be410f9e1ac0b352a392f716337e3 [file] [log] [blame]
Yuta HIGUCHIb3b2ac42014-09-21 23:37:11 -07001package org.onlab.onos.net.device.impl;
2
3import org.junit.After;
4import org.junit.Before;
5import org.junit.Ignore;
6import org.junit.Test;
7import org.onlab.onos.event.Event;
8import org.onlab.onos.net.Device;
9import org.onlab.onos.net.DeviceId;
10import org.onlab.onos.net.MastershipRole;
11import org.onlab.onos.net.Port;
12import org.onlab.onos.net.PortNumber;
13import org.onlab.onos.net.device.DefaultDeviceDescription;
14import org.onlab.onos.net.device.DefaultPortDescription;
15import org.onlab.onos.net.device.DeviceAdminService;
16import org.onlab.onos.net.device.DeviceDescription;
17import org.onlab.onos.net.device.DeviceEvent;
18import org.onlab.onos.net.device.DeviceListener;
19import org.onlab.onos.net.device.DeviceProvider;
20import org.onlab.onos.net.device.DeviceProviderRegistry;
21import org.onlab.onos.net.device.DeviceProviderService;
22import org.onlab.onos.net.device.DeviceService;
23import org.onlab.onos.net.device.PortDescription;
24import org.onlab.onos.net.provider.AbstractProvider;
25import org.onlab.onos.net.provider.ProviderId;
26import org.onlab.onos.event.impl.TestEventDispatcher;
27import org.onlab.onos.store.device.impl.DistributedDeviceStore;
28
29import com.google.common.collect.Iterables;
30import com.hazelcast.config.Config;
31import com.hazelcast.core.Hazelcast;
32
33import java.util.ArrayList;
34import java.util.Iterator;
35import java.util.List;
36import java.util.UUID;
37
38import static org.junit.Assert.*;
39import static org.onlab.onos.net.Device.Type.SWITCH;
40import static org.onlab.onos.net.DeviceId.deviceId;
41import static org.onlab.onos.net.device.DeviceEvent.Type.*;
42
43// FIXME This test is painfully slow starting up Hazelcast on each test cases,
44// turning it off in repository for now.
45// FIXME DistributedDeviceStore should have it's own test cases.
46/**
47 * Test codifying the device service & device provider service contracts.
48 */
49@Ignore
50public class DistributedDeviceManagerTest {
51
52 private static final ProviderId PID = new ProviderId("of", "foo");
53 private static final DeviceId DID1 = deviceId("of:foo");
54 private static final DeviceId DID2 = deviceId("of:bar");
55 private static final String MFR = "whitebox";
56 private static final String HW = "1.1.x";
57 private static final String SW1 = "3.8.1";
58 private static final String SW2 = "3.9.5";
59 private static final String SN = "43311-12345";
60
61 private static final PortNumber P1 = PortNumber.portNumber(1);
62 private static final PortNumber P2 = PortNumber.portNumber(2);
63 private static final PortNumber P3 = PortNumber.portNumber(3);
64
65 private DeviceManager mgr;
66
67 protected DeviceService service;
68 protected DeviceAdminService admin;
69 protected DeviceProviderRegistry registry;
70 protected DeviceProviderService providerService;
71 protected TestProvider provider;
72 protected TestListener listener = new TestListener();
73 private DistributedDeviceStore dstore;
74
75 @Before
76 public void setUp() {
77 mgr = new DeviceManager();
78 service = mgr;
79 admin = mgr;
80 registry = mgr;
81 dstore = new DistributedDeviceStore();
82 // FIXME should be reading the hazelcast.xml
83 Config config = new Config();
84 // avoid accidentally joining other cluster
85 config.getGroupConfig().setName(UUID.randomUUID().toString());
86 // quickly form single node cluster
87 config.getNetworkConfig().getJoin().getMulticastConfig()
88 .setMulticastTimeoutSeconds(0);
89 dstore.theInstance = Hazelcast.newHazelcastInstance(config);
90 dstore.activate();
91 mgr.store = dstore;
92 mgr.eventDispatcher = new TestEventDispatcher();
93 mgr.activate();
94
95 service.addListener(listener);
96
97 provider = new TestProvider();
98 providerService = registry.register(provider);
99 assertTrue("provider should be registered",
100 registry.getProviders().contains(provider.id()));
101 }
102
103 @After
104 public void tearDown() {
105 registry.unregister(provider);
106 assertFalse("provider should not be registered",
107 registry.getProviders().contains(provider.id()));
108 service.removeListener(listener);
109 mgr.deactivate();
110
111 dstore.deactivate();
112 dstore.theInstance.shutdown();
113 }
114
115 private void connectDevice(DeviceId deviceId, String swVersion) {
116 DeviceDescription description =
117 new DefaultDeviceDescription(deviceId.uri(), SWITCH, MFR,
118 HW, swVersion, SN);
119 providerService.deviceConnected(deviceId, description);
120 assertNotNull("device should be found", service.getDevice(DID1));
121 }
122
123 @Test
124 public void deviceConnected() {
125 assertNull("device should not be found", service.getDevice(DID1));
126 connectDevice(DID1, SW1);
127 validateEvents(DEVICE_ADDED);
128
129 assertEquals("only one device expected", 1, Iterables.size(service.getDevices()));
130 Iterator<Device> it = service.getDevices().iterator();
131 assertNotNull("one device expected", it.next());
132 assertFalse("only one device expected", it.hasNext());
133
134 assertEquals("incorrect device count", 1, service.getDeviceCount());
135 assertTrue("device should be available", service.isAvailable(DID1));
136 }
137
138 @Test
139 public void deviceDisconnected() {
140 connectDevice(DID1, SW1);
141 connectDevice(DID2, SW1);
142 validateEvents(DEVICE_ADDED, DEVICE_ADDED);
143 assertTrue("device should be available", service.isAvailable(DID1));
144
145 // Disconnect
146 providerService.deviceDisconnected(DID1);
147 assertNotNull("device should not be found", service.getDevice(DID1));
148 assertFalse("device should not be available", service.isAvailable(DID1));
149 validateEvents(DEVICE_AVAILABILITY_CHANGED);
150
151 // Reconnect
152 connectDevice(DID1, SW1);
153 validateEvents(DEVICE_AVAILABILITY_CHANGED);
154
155 assertEquals("incorrect device count", 2, service.getDeviceCount());
156 }
157
158 @Test
159 public void deviceUpdated() {
160 connectDevice(DID1, SW1);
161 validateEvents(DEVICE_ADDED);
162
163 connectDevice(DID1, SW2);
164 validateEvents(DEVICE_UPDATED);
165 }
166
167 @Test
168 public void getRole() {
169 connectDevice(DID1, SW1);
170 assertEquals("incorrect role", MastershipRole.MASTER, service.getRole(DID1));
171 }
172
173 @Test
174 public void setRole() throws InterruptedException {
175 connectDevice(DID1, SW1);
176 admin.setRole(DID1, MastershipRole.STANDBY);
177 validateEvents(DEVICE_ADDED, DEVICE_MASTERSHIP_CHANGED);
178 assertEquals("incorrect role", MastershipRole.STANDBY, service.getRole(DID1));
179 assertEquals("incorrect device", DID1, provider.deviceReceived.id());
180 assertEquals("incorrect role", MastershipRole.STANDBY, provider.roleReceived);
181 }
182
183 @Test
184 public void updatePorts() {
185 connectDevice(DID1, SW1);
186 List<PortDescription> pds = new ArrayList<>();
187 pds.add(new DefaultPortDescription(P1, true));
188 pds.add(new DefaultPortDescription(P2, true));
189 pds.add(new DefaultPortDescription(P3, true));
190 providerService.updatePorts(DID1, pds);
191 validateEvents(DEVICE_ADDED, PORT_ADDED, PORT_ADDED, PORT_ADDED);
192 pds.clear();
193
194 pds.add(new DefaultPortDescription(P1, false));
195 pds.add(new DefaultPortDescription(P3, true));
196 providerService.updatePorts(DID1, pds);
197 validateEvents(PORT_UPDATED, PORT_REMOVED);
198 }
199
200 @Test
201 public void updatePortStatus() {
202 connectDevice(DID1, SW1);
203 List<PortDescription> pds = new ArrayList<>();
204 pds.add(new DefaultPortDescription(P1, true));
205 pds.add(new DefaultPortDescription(P2, true));
206 providerService.updatePorts(DID1, pds);
207 validateEvents(DEVICE_ADDED, PORT_ADDED, PORT_ADDED);
208
209 providerService.portStatusChanged(DID1, new DefaultPortDescription(P1, false));
210 validateEvents(PORT_UPDATED);
211 providerService.portStatusChanged(DID1, new DefaultPortDescription(P1, false));
212 assertTrue("no events expected", listener.events.isEmpty());
213 }
214
215 @Test
216 public void getPorts() {
217 connectDevice(DID1, SW1);
218 List<PortDescription> pds = new ArrayList<>();
219 pds.add(new DefaultPortDescription(P1, true));
220 pds.add(new DefaultPortDescription(P2, true));
221 providerService.updatePorts(DID1, pds);
222 validateEvents(DEVICE_ADDED, PORT_ADDED, PORT_ADDED);
223 assertEquals("wrong port count", 2, service.getPorts(DID1).size());
224
225 Port port = service.getPort(DID1, P1);
226 assertEquals("incorrect port", P1, service.getPort(DID1, P1).number());
227 assertEquals("incorrect state", true, service.getPort(DID1, P1).isEnabled());
228 }
229
230 @Test
231 public void removeDevice() {
232 connectDevice(DID1, SW1);
233 connectDevice(DID2, SW2);
234 assertEquals("incorrect device count", 2, service.getDeviceCount());
235 admin.removeDevice(DID1);
236 assertNull("device should not be found", service.getDevice(DID1));
237 assertNotNull("device should be found", service.getDevice(DID2));
238 assertEquals("incorrect device count", 1, service.getDeviceCount());
239
240 }
241
242 protected void validateEvents(Enum... types) {
243 int i = 0;
244 assertEquals("wrong events received", types.length, listener.events.size());
245 for (Event event : listener.events) {
246 assertEquals("incorrect event type", types[i], event.type());
247 i++;
248 }
249 listener.events.clear();
250 }
251
252
253 private class TestProvider extends AbstractProvider implements DeviceProvider {
254 private Device deviceReceived;
255 private MastershipRole roleReceived;
256
257 public TestProvider() {
258 super(PID);
259 }
260
261 @Override
262 public void triggerProbe(Device device) {
263 }
264
265 @Override
266 public void roleChanged(Device device, MastershipRole newRole) {
267 deviceReceived = device;
268 roleReceived = newRole;
269 }
270 }
271
272 private static class TestListener implements DeviceListener {
273 final List<DeviceEvent> events = new ArrayList<>();
274
275 @Override
276 public void event(DeviceEvent event) {
277 events.add(event);
278 }
279 }
280
281}