Initial import of Microsemi Driver
Change-Id: I431d5f2c18e0b66a84c36273c3d9f0b84f223841
Added in BUCK files for building driver
Change-Id: I70681327f5b89f67e904c45d5974ab393652d51f
Corrected some syntax errors
Change-Id: I11150cc499c212005f80619e3900e747f1c23d96
Updated pom file to clean build
Change-Id: I6613ddc9e6802aa882e716cf04df210249870835
Added in utility functions for EA1000 Init
Change-Id: I51ffe0cf0daf9ffcea0e2479ee9982fcd1755440
Added YMS code to Microsemi Driver
Change-Id: I6f2a14e454c6909bf9e9f6025321c74c98c13c72
Updated driver to work with YMS and YCH
Change-Id: If7dbe3cd5bd1b6f902d09d6b2dc3895605d70f70
Implemented IetfSystemManager as a service and call on YMS as a service
Change-Id: If1c5e8482b1f53f578a3b0b770accd50024111cf
Moved YMS calls over in to Yang Service implementation
Change-Id: I044aad06f1ef7452bc48e88987787a683666cd72
improved unit test for IetfSystemManager
Change-Id: I48fbf831e7e5ca0e1ef3de8288e56da1b5ebb7a4
Major changes to IetfSystemManager to work in live system
Change-Id: I6e3aa118ba422151f314b9a666860d90905c9929
Added in retry mechanism for DeviceDescription to wait for YCH
Change-Id: If8e0f2c2f315ffd6db15627a11382a00217dd262
Added in implementation of MseaSaFiltering and unit tests
Change-Id: I34bf888e0e732bd4664d1fb8ef5abb679b1506fe
Updated driver with unit tests for MseaSaFiltering
Change-Id: I7ea2407a546622ff55d1ab21610c45697546d632
Modified removeFlowRules of Ea1000FlowRuleProgrammable
Change-Id: Ibb4a555f61887a8e6e42af588bb42f7b70f58efb
Added in manager for MseaUniEvc service with unit tests
Change-Id: Idc5853f46051548973f52a0659f7f88982ff960c
Implemented getFlowEntries() for EVCs from EA1000
Change-Id: Ie85dadfa7760f0b30a9bdf6ccd09cca9f097fff9
Added in translation of FlowRules in to EVC on EA1000
Change-Id: Icfb65171c3300c96b3ca4e18cbd327f0ed2190be
Added in handling of FlowRule deletion including complex ceVlanMaps
Change-Id: I7fd0bb0ef04d1b40e4b7d6a6db7f7ee662329780
Updated Service entries for new onos-yang-tools
Change-Id: I44e655202f3a45073e1e16f83737caed6e01afa8
Revert "Updated Service entries for new onos-yang-tools"
This reverts commit 642b550ef1de12ed59bad2eaa3a2da414d2e5e59.
Improved timeout mechanism for YANG model loading
Change-Id: If744ecd206372e822edf2b736c83226321a12256
Minor edits of EVC creation
Change-Id: Ib0a4763deaf6dce37625ba77f5095b39cd98272d
Added in CustomEvc and supporting classes
Change-Id: Iad60eb1bcd48d2aec55b894b2d419b51852c3b2f
Created CeVlanUtils to resolve loading problem
Change-Id: I0d63931ad2c5ad2725861ebc7dccc4d5fe7b9298
Modified startup check
Change-Id: I6e6bcfa7e615044cb08fe7ee2f8a6c8b89aabb21
Modified handlin of flow rules
Change-Id: I965a79c23298866122aeb94c6d9d584aafee3bd5
Fixed problem with ceVlanMap
Change-Id: If1458c35d0b95b5b25b6636f098292f9e91c06c6
Minor Pom edits
Change-Id: I5cefb18674aa04b1f50bd7e2306260c1c3ad3814
Commented out extension references in YANG files to avoid onos-yang-tools problems
Change-Id: I32fdb34c4f476f495fe28e75d0f410aaf14e2ec1
Corrected error in removing 0 in CeVlanMapUtils
Change-Id: I8cd1fd02788b81c2613364d5639ef6e090057f80
Changes in YMS to accomodate EA1000 driver
Change-Id: I6ae2b9bd2be49eae8d4ad2f929dfe3214c514550
diff --git a/drivers/microsemi/ea1000driver/src/test/java/org/onosproject/drivers/microsemi/EA1000MeterProviderTest.java b/drivers/microsemi/ea1000driver/src/test/java/org/onosproject/drivers/microsemi/EA1000MeterProviderTest.java
new file mode 100644
index 0000000..b00b321
--- /dev/null
+++ b/drivers/microsemi/ea1000driver/src/test/java/org/onosproject/drivers/microsemi/EA1000MeterProviderTest.java
@@ -0,0 +1,120 @@
+/*
+ * Copyright 2017-present Open Networking Laboratory
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onosproject.drivers.microsemi;
+
+import java.util.HashSet;
+
+import org.junit.After;
+import org.junit.Before;
+import org.junit.Test;
+import org.onosproject.core.DefaultApplicationId;
+import org.onosproject.drivers.microsemi.yang.MockMseaUniEvcServiceManager;
+import org.onosproject.drivers.microsemi.yang.MockNetconfSessionEa1000;
+import org.onosproject.drivers.netconf.MockNetconfController;
+import org.onosproject.drivers.netconf.MockNetconfDevice;
+import org.onosproject.net.DeviceId;
+import org.onosproject.net.meter.Band;
+import org.onosproject.net.meter.DefaultBand;
+import org.onosproject.net.meter.DefaultMeter;
+import org.onosproject.net.meter.Meter;
+import org.onosproject.net.meter.Meter.Unit;
+import org.onosproject.net.meter.MeterId;
+import org.onosproject.net.meter.MeterOperation;
+import org.onosproject.net.meter.MeterOperation.Type;
+import org.onosproject.netconf.NetconfController;
+
+public class EA1000MeterProviderTest {
+
+ private EA1000MeterProvider meterProvider;
+ private NetconfController controller;
+ private DeviceId mockDeviceId;
+ private MockMseaUniEvcServiceManager mseaUniEvcServiceSvc;
+
+ @Before
+ public void setUp() throws Exception {
+ mockDeviceId = DeviceId.deviceId("netconf:1.2.3.4:830");
+ controller = new MockNetconfController();
+ MockNetconfDevice device = (MockNetconfDevice) controller.connectDevice(mockDeviceId);
+ device.setNcSessionImpl(MockNetconfSessionEa1000.class);
+ mseaUniEvcServiceSvc = new MockMseaUniEvcServiceManager();
+ mseaUniEvcServiceSvc.activate();
+ meterProvider = new TestEA1000MeterProvider(controller, mseaUniEvcServiceSvc);
+ }
+
+ @After
+ public void tearDown() throws Exception {
+ }
+
+ @Test
+ public void testPerformMeterOperationDeviceIdMeterAdd() {
+ DeviceId mockDeviceId = DeviceId.deviceId("netconf:1.2.3.4:830");
+
+ Band cbsBand = DefaultBand.builder()
+ .ofType(Band.Type.REMARK) //Committed - CIR & CBS
+ .withRate(37500L)
+ .burstSize(2000)
+ .dropPrecedence((short) 0)
+ .build();
+
+ Band ebsBand = DefaultBand.builder()
+ .ofType(Band.Type.DROP) //Excess - EIR & EBS
+ .withRate(50000L) //The rate at which we drop - for EA 1000 subtract CIR to get EIR
+ .burstSize(3000) //The burst rate to drop at
+ .build();
+
+ Meter.Builder mBuilder = DefaultMeter.builder()
+ .forDevice(mockDeviceId)
+ .withId(MeterId.meterId(1))
+ .fromApp(new DefaultApplicationId(101, "unit.test"))
+ .burst()
+ .withUnit(Unit.KB_PER_SEC)
+ .withBands(new HashSet<Band>() { { add(cbsBand); add(ebsBand); } });
+
+ MeterOperation meterOp = new MeterOperation(mBuilder.build(), Type.ADD);
+
+ meterProvider.performMeterOperation(mockDeviceId, meterOp);
+ //The NETCONF XML generated by this matches the pattern
+ // sampleXmlRegexEditConfigBwpGroup1
+ // in MockNetconfSession
+ }
+
+ @Test
+ public void testPerformMeterOperationDeviceIdMeterRemove() {
+ DeviceId mockDeviceId = DeviceId.deviceId("netconf:1.2.3.4:830");
+
+ Band cbsBand = DefaultBand.builder()
+ .ofType(Band.Type.REMARK) //Committed - CIR & CBS
+ .withRate(37500L)
+ .burstSize(2000)
+ .dropPrecedence((short) 0)
+ .build();
+
+ Meter.Builder mBuilder = DefaultMeter.builder()
+ .forDevice(mockDeviceId)
+ .withId(MeterId.meterId(1))
+ .fromApp(new DefaultApplicationId(101, "unit.test"))
+ .burst()
+ .withBands(new HashSet<Band>() { { add(cbsBand); } });
+
+ MeterOperation meterOp = new MeterOperation(mBuilder.build(), Type.REMOVE);
+
+ meterProvider.performMeterOperation(mockDeviceId, meterOp);
+ //The NETCONF XML generated by this matches the pattern
+ // sampleXmlRegexEditConfigBwpGroup1
+ // in MockNetconfSession
+ }
+
+}