blob: 4421bde9432161f744ecad92b94890fb09bcdfb6 [file] [log] [blame]
Shubham Sharma47f2caf2020-02-18 12:13:40 +00001/*
2 * Copyright 2017-present Open Networking Foundation
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
developere400c582020-03-24 19:42:08 +010017package org.opencord.igmpproxy.impl;
Shubham Sharma47f2caf2020-02-18 12:13:40 +000018
19import static org.junit.Assert.assertEquals;
20import static org.onlab.junit.TestTools.assertAfter;
21
22import java.util.List;
23
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +000024import com.google.common.collect.Maps;
Shubham Sharma47f2caf2020-02-18 12:13:40 +000025import org.junit.After;
26import org.junit.Before;
27import org.junit.Test;
28import org.onlab.junit.TestUtils;
29import org.onlab.packet.Ethernet;
Sonal Kasliwalf11c0672020-03-18 11:11:50 +000030import org.onlab.packet.Ip4Address;
Esin Karaman586f1d62020-06-04 10:15:34 +000031import org.onlab.packet.VlanId;
Shubham Sharma47f2caf2020-02-18 12:13:40 +000032import org.onosproject.core.CoreServiceAdapter;
33import org.onosproject.net.flow.FlowRuleServiceAdapter;
34import org.onosproject.net.flowobjective.FlowObjectiveServiceAdapter;
35
developere400c582020-03-24 19:42:08 +010036import org.opencord.igmpproxy.IgmpStatisticsEvent;
37
Shubham Sharma47f2caf2020-02-18 12:13:40 +000038import com.google.common.collect.Lists;
developere400c582020-03-24 19:42:08 +010039import org.opencord.igmpproxy.IgmpStatisticsEventListener;
Shubham Sharma47f2caf2020-02-18 12:13:40 +000040
41/**
42 * Set of tests of the ONOS application component for IGMP Statistics.
43 */
44public class IgmpStatisticsTest extends IgmpManagerBase {
45
46 private static final int WAIT_TIMEOUT = 500;
47
48 private IgmpManager igmpManager;
49
50 private IgmpStatisticsManager igmpStatisticsManager;
51
52 private MockIgmpStatisticsEventListener mockListener = new MockIgmpStatisticsEventListener();
53
54 // Set up the IGMP application.
55 @Before
56 public void setUp() {
57 igmpManager = new IgmpManager();
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +000058 igmpManager.igmpLeadershipService = new TestIgmpLeaderShipService();
Shubham Sharma47f2caf2020-02-18 12:13:40 +000059 igmpManager.coreService = new CoreServiceAdapter();
60 igmpManager.mastershipService = new MockMastershipService();
61 igmpManager.flowObjectiveService = new FlowObjectiveServiceAdapter();
62 igmpManager.deviceService = new MockDeviceService();
63 igmpManager.packetService = new MockPacketService();
64 igmpManager.flowRuleService = new FlowRuleServiceAdapter();
65 igmpManager.multicastService = new TestMulticastRouteService();
66 igmpManager.sadisService = new MockSadisService();
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +000067 igmpManager.groupMemberStore = new TestGroupMemberStoreService();
68 StateMachineManager stateMachineService = new StateMachineManager();
69 stateMachineService.stateMachineStore = new TestStateMachineStoreService(Maps.newConcurrentMap());
70 stateMachineService.activate(new MockComponentContext());
71 igmpManager.stateMachineService = stateMachineService;
Shubham Sharma47f2caf2020-02-18 12:13:40 +000072 igmpStatisticsManager = new IgmpStatisticsManager();
73 igmpStatisticsManager.cfgService = new MockCfgService();
74 igmpStatisticsManager.addListener(mockListener);
75 TestUtils.setField(igmpStatisticsManager, "eventDispatcher", new TestEventDispatcher());
76 igmpStatisticsManager.activate(new MockComponentContext());
77 igmpManager.igmpStatisticsManager = this.igmpStatisticsManager;
78 // By default - we send query messages
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +000079 StateMachineManager.sendQuery = true;
Shubham Sharma47f2caf2020-02-18 12:13:40 +000080 }
81
82 // Tear Down the IGMP application.
83 @After
84 public void tearDown() {
85 igmpStatisticsManager.removeListener(mockListener);
86 igmpStatisticsManager.deactivate();
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +000087 igmpManager.stateMachineService.clearAllMaps();
Shubham Sharma47f2caf2020-02-18 12:13:40 +000088 }
89
90 //Test Igmp Statistics.
91 @Test
92 public void testIgmpStatistics() throws InterruptedException {
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +000093 StateMachineManager.sendQuery = false;
Shubham Sharma47f2caf2020-02-18 12:13:40 +000094 igmpManager.networkConfig = new TestNetworkConfigRegistry(false);
95 igmpManager.activate();
Sonal Kasliwalf11c0672020-03-18 11:11:50 +000096
Shubham Sharma47f2caf2020-02-18 12:13:40 +000097 //IGMPv3 Join
Sonal Kasliwalf11c0672020-03-18 11:11:50 +000098 flagForPacket = false;
Shubham Sharma47f2caf2020-02-18 12:13:40 +000099 Ethernet igmpv3MembershipReportPkt = IgmpSender.getInstance().buildIgmpV3Join(GROUP_IP, SOURCE_IP_OF_A);
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000100 sendPacket(igmpv3MembershipReportPkt);
Shubham Sharma47f2caf2020-02-18 12:13:40 +0000101 synchronized (savedPackets) {
102 savedPackets.wait(WAIT_TIMEOUT);
103 }
104 //Leave
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000105 flagForPacket = false;
Shubham Sharma47f2caf2020-02-18 12:13:40 +0000106 Ethernet igmpv3LeavePkt = IgmpSender.getInstance().buildIgmpV3Leave(GROUP_IP, SOURCE_IP_OF_A);
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000107 sendPacket(igmpv3LeavePkt);
Shubham Sharma47f2caf2020-02-18 12:13:40 +0000108 synchronized (savedPackets) {
109 savedPackets.wait(WAIT_TIMEOUT);
110 }
111
112 assertAfter(WAIT_TIMEOUT, WAIT_TIMEOUT * 2, () ->
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +0000113 assertEquals((long) 2, igmpStatisticsManager.getIgmpStats().getTotalMsgReceived().longValue()));
Shubham Sharma47f2caf2020-02-18 12:13:40 +0000114 assertEquals((long) 1, igmpStatisticsManager.getIgmpStats().getIgmpJoinReq().longValue());
115 assertEquals((long) 2, igmpStatisticsManager.getIgmpStats().getIgmpv3MembershipReport().longValue());
116 assertEquals((long) 1, igmpStatisticsManager.getIgmpStats().getIgmpSuccessJoinRejoinReq().longValue());
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000117 assertEquals((long) 1, igmpStatisticsManager.getIgmpStats().getUnconfiguredGroupCounter().longValue());
118 assertEquals((long) 2, igmpStatisticsManager.getIgmpStats().getValidIgmpPacketCounter().longValue());
119 assertEquals((long) 1, igmpStatisticsManager.getIgmpStats().getIgmpChannelJoinCounter().longValue());
Shubham Sharma47f2caf2020-02-18 12:13:40 +0000120 assertEquals((long) 1, igmpStatisticsManager.getIgmpStats().getIgmpLeaveReq().longValue());
121 assertEquals((long) 2, igmpStatisticsManager.getIgmpStats().getIgmpMsgReceived().longValue());
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000122 assertEquals((long) 2, igmpStatisticsManager.getIgmpStats().getIgmpValidChecksumCounter().longValue());
Shubham Sharma47f2caf2020-02-18 12:13:40 +0000123
124 }
125
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000126 //Test packet with Unknown Multicast IpAddress
127 @Test
128 public void testIgmpUnknownMulticastIpAddress() throws InterruptedException {
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +0000129 StateMachineManager.sendQuery = false;
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000130
131 igmpManager.networkConfig = new TestNetworkConfigRegistry(false);
132 igmpManager.activate();
133
134 Ethernet firstPacket =
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +0000135 IgmpSender.getInstance().buildIgmpV3Join(UNKNOWN_GRP_IP, SOURCE_IP_OF_A);
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000136 // Sending first packet
137 sendPacket(firstPacket);
138 assertAfter(WAIT_TIMEOUT, WAIT_TIMEOUT * 2, () ->
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +0000139 assertEquals((long) 1,
140 igmpStatisticsManager.getIgmpStats().getFailJoinReqUnknownMulticastIpCounter().longValue()));
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000141 }
142
143 //Test Igmp Query Statistics.
144 @Test
145 public void testIgmpQueryStatistics() throws InterruptedException {
146 igmpManager.networkConfig = new TestNetworkConfigRegistry(false);
147 igmpManager.activate();
148
149 flagForQueryPacket = true;
150 //IGMPV3 Group Specific Membership Query packet
Esin Karaman586f1d62020-06-04 10:15:34 +0000151 Ethernet igmpv3MembershipQueryPkt = IgmpSender.getInstance().
152 buildIgmpV3Query(GROUP_IP, SOURCE_IP_OF_A, VlanId.MAX_VLAN);
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000153 sendPacket(igmpv3MembershipQueryPkt);
154
155 //IGMPV3 General Membership Query packet
156 Ethernet igmpv3MembershipQueryPkt1 =
Esin Karaman586f1d62020-06-04 10:15:34 +0000157 IgmpSender.getInstance().buildIgmpV3Query(Ip4Address.valueOf(0), SOURCE_IP_OF_A, VlanId.MAX_VLAN);
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000158 sendPacket(igmpv3MembershipQueryPkt1);
159 assertAfter(WAIT_TIMEOUT, WAIT_TIMEOUT * 2, () ->
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +0000160 assertEquals(igmpStatisticsManager.getIgmpStats()
161 .getIgmpGrpAndSrcSpecificMembershipQuery().longValue(), 1));
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000162 assertEquals(igmpStatisticsManager.getIgmpStats()
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +0000163 .getIgmpGeneralMembershipQuery().longValue(), 1);
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000164 assertEquals(igmpStatisticsManager.getIgmpStats()
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +0000165 .getCurrentGrpNumCounter().longValue(), 1);
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000166 }
167
Shubham Sharma47f2caf2020-02-18 12:13:40 +0000168 //Test Events
169 @Test
170 public void testIgmpStatisticsEvent() {
171 final int waitEventGeneration = igmpStatisticsManager.statisticsGenerationPeriodInSeconds * 1000;
172 //assert that event listened as the app activates
173 assertAfter(WAIT_TIMEOUT, WAIT_TIMEOUT * 2, () ->
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +0000174 assertEquals(mockListener.events.size(), 1));
Shubham Sharma47f2caf2020-02-18 12:13:40 +0000175
176 assertAfter(waitEventGeneration / 2, waitEventGeneration, () ->
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +0000177 assertEquals(mockListener.events.size(), 2));
Shubham Sharma47f2caf2020-02-18 12:13:40 +0000178
179 for (IgmpStatisticsEvent event : mockListener.events) {
180 assertEquals(event.type(), IgmpStatisticsEvent.Type.STATS_UPDATE);
181 }
182 }
183
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000184 //Test packet with Unknown Wrong Membership mode
185 @Test
186 public void testWrongIgmpPacket() throws InterruptedException {
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +0000187 StateMachineManager.sendQuery = false;
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000188
189 igmpManager.networkConfig = new TestNetworkConfigRegistry(false);
190 igmpManager.activate();
191
192 Ethernet firstPacket = buildWrongIgmpPacket(GROUP_IP, SOURCE_IP_OF_A);
193 // Sending first packet
194 sendPacket(firstPacket);
195 assertAfter(WAIT_TIMEOUT, WAIT_TIMEOUT * 2, () ->
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +0000196 assertEquals((long) 1,
197 igmpStatisticsManager.getIgmpStats().getReportsRxWithWrongModeCounter().longValue()));
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000198 }
199
200 //Test packet with Unknown IGMP type.
201 @Test
202 public void testUnknownIgmpPacket() throws InterruptedException {
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +0000203 StateMachineManager.sendQuery = false;
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000204
205 igmpManager.networkConfig = new TestNetworkConfigRegistry(false);
206 igmpManager.activate();
207
208 Ethernet firstPacket = buildUnknownIgmpPacket(GROUP_IP, SOURCE_IP_OF_A);
209 // Sending first packet
210 sendPacket(firstPacket);
211 assertAfter(WAIT_TIMEOUT, WAIT_TIMEOUT * 2, () ->
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +0000212 assertEquals((long) 1,
213 igmpStatisticsManager.getIgmpStats().getUnknownIgmpTypePacketsRxCounter().longValue()));
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000214 }
215
216 //Test packet with Insufficient Permission.
217 @Test
218 public void testSufficientPermission() throws InterruptedException {
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +0000219 StateMachineManager.sendQuery = false;
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000220
221 flagForPermission = true;
222 igmpManager.networkConfig = new TestNetworkConfigRegistry(false);
223 igmpManager.activate();
224
225 Ethernet firstPacket = IgmpSender.getInstance().buildIgmpV3Join(GROUP_IP, SOURCE_IP_OF_A);
226 // Sending first packet
227 sendPacket(firstPacket);
228 assertAfter(WAIT_TIMEOUT, WAIT_TIMEOUT * 2, () ->
Ilayda Ozdemir4c5947c2020-05-05 13:14:32 +0000229 assertEquals((long) 1,
230 igmpStatisticsManager.getIgmpStats()
231 .getFailJoinReqInsuffPermissionAccessCounter().longValue()));
Sonal Kasliwalf11c0672020-03-18 11:11:50 +0000232 }
233
Shubham Sharma47f2caf2020-02-18 12:13:40 +0000234 public class MockIgmpStatisticsEventListener implements IgmpStatisticsEventListener {
235 protected List<IgmpStatisticsEvent> events = Lists.newArrayList();
236
237 @Override
238 public void event(IgmpStatisticsEvent event) {
239 events.add(event);
240 }
241
242 }
243}