blob: c23ec00956da408ab8ad9723edc0e7b1ebab6069 [file] [log] [blame]
#!/usr/bin/env python3
# Copyright (c) 2021 Graphiant, Inc.
import unittest
from asfframework import VppTestCase, VppTestRunner
from vpp_policer import VppPolicer, PolicerAction
# Default for the tests is 10s of "Green" packets at 8Mbps, ie. 10M bytes.
# The policer helper CLI "sends" 500 byte packets, so default is 20000.
TEST_RATE = 8000 # kbps
TEST_BURST = 10000 # ms
CIR_OK = 8500 # CIR in kbps, above test rate
CIR_LOW = 7000 # CIR in kbps, below test rate
EIR_OK = 9000 # EIR in kbps, above test rate
EIR_LOW = 7500 # EIR in kbps, below test rate
NUM_PKTS = 20000
CBURST = 100000 # Committed burst in bytes
EBURST = 200000 # Excess burst in bytes
class TestPolicer(VppTestCase):
"""Policer Test Case"""
def run_policer_test(
self, type, cir, cb, eir, eb, rate=8000, burst=10000, colour=0
):
"""
Configure a Policer and push traffic through it.
"""
types = {
"1R2C": 0,
"1R3C": 1,
"2R3C": 3,
}
pol_type = types.get(type)
policer = VppPolicer(
self,
"pol1",
cir,
eir,
cb,
eb,
rate_type=0,
type=pol_type,
color_aware=colour,
)
policer.add_vpp_config()
error = self.vapi.cli(
f"test policing index {policer.policer_index} rate {rate} "
f"burst {burst} colour {colour}"
)
stats = policer.get_stats()
policer.remove_vpp_config()
return stats
def test_policer_1r2c(self):
"""Single rate, 2 colour policer"""
stats = self.run_policer_test("1R2C", CIR_OK, CBURST, 0, 0)
self.assertEqual(stats["conform_packets"], NUM_PKTS)
stats = self.run_policer_test("1R2C", CIR_LOW, CBURST, 0, 0)
self.assertLess(stats["conform_packets"], NUM_PKTS)
self.assertEqual(stats["exceed_packets"], 0)
self.assertGreater(stats["violate_packets"], 0)
stats = self.run_policer_test("1R2C", CIR_LOW, CBURST, 0, 0, colour=2)
self.assertEqual(stats["violate_packets"], NUM_PKTS)
def test_policer_1r3c(self):
"""Single rate, 3 colour policer"""
stats = self.run_policer_test("1R3C", CIR_OK, CBURST, 0, 0)
self.assertEqual(stats["conform_packets"], NUM_PKTS)
stats = self.run_policer_test("1R3C", CIR_LOW, CBURST, 0, EBURST)
self.assertLess(stats["conform_packets"], NUM_PKTS)
self.assertGreater(stats["exceed_packets"], 0)
self.assertGreater(stats["violate_packets"], 0)
stats = self.run_policer_test("1R3C", CIR_LOW, CBURST, 0, EBURST, colour=1)
self.assertEqual(stats["conform_packets"], 0)
self.assertGreater(stats["exceed_packets"], 0)
self.assertGreater(stats["violate_packets"], 0)
stats = self.run_policer_test("1R3C", CIR_LOW, CBURST, 0, EBURST, colour=2)
self.assertEqual(stats["violate_packets"], NUM_PKTS)
def test_policer_2r3c(self):
"""Dual rate, 3 colour policer"""
stats = self.run_policer_test("2R3C", CIR_OK, CBURST, EIR_OK, EBURST)
self.assertEqual(stats["conform_packets"], NUM_PKTS)
stats = self.run_policer_test("2R3C", CIR_LOW, CBURST, EIR_OK, EBURST)
self.assertLess(stats["conform_packets"], NUM_PKTS)
self.assertGreater(stats["exceed_packets"], 0)
self.assertEqual(stats["violate_packets"], 0)
stats = self.run_policer_test("2R3C", CIR_LOW, CBURST, EIR_LOW, EBURST)
self.assertLess(stats["conform_packets"], NUM_PKTS)
self.assertGreater(stats["exceed_packets"], 0)
self.assertGreater(stats["violate_packets"], 0)
stats = self.run_policer_test("2R3C", CIR_LOW, CBURST, EIR_OK, EBURST, colour=1)
self.assertEqual(stats["exceed_packets"], NUM_PKTS)
stats = self.run_policer_test(
"2R3C", CIR_LOW, CBURST, EIR_LOW, EBURST, colour=1
)
self.assertEqual(stats["conform_packets"], 0)
self.assertGreater(stats["exceed_packets"], 0)
self.assertGreater(stats["violate_packets"], 0)
stats = self.run_policer_test("2R3C", CIR_LOW, CBURST, EIR_OK, EBURST, colour=2)
self.assertEqual(stats["violate_packets"], NUM_PKTS)
if __name__ == "__main__":
unittest.main(testRunner=VppTestRunner)