From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mga02.intel.com (mga02.intel.com [134.134.136.20]) by dpdk.org (Postfix) with ESMTP id 0984DE6D for ; Fri, 22 Apr 2016 08:06:58 +0200 (CEST) Received: from fmsmga002.fm.intel.com ([10.253.24.26]) by orsmga101.jf.intel.com with ESMTP; 21 Apr 2016 23:06:59 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.24,516,1455004800"; d="scan'208";a="964068878" Received: from unknown (HELO dpdk-fedora20.icx.intel.com) ([10.238.55.12]) by fmsmga002.fm.intel.com with ESMTP; 21 Apr 2016 23:06:58 -0700 From: "xu,huilong" To: dts@dpdk.org Cc: "xu,huilong" Date: Fri, 22 Apr 2016 14:02:36 +0800 Message-Id: <1461304956-20509-2-git-send-email-huilongx.xu@intel.com> X-Mailer: git-send-email 1.9.3 In-Reply-To: <1461304956-20509-1-git-send-email-huilongx.xu@intel.com> References: <1461304956-20509-1-git-send-email-huilongx.xu@intel.com> Subject: [dts] [PATCH V2][dts 2/2] add allmutlicast and broadcast test case X-BeenThere: dts@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: test suite reviews and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 22 Apr 2016 06:06:59 -0000 Signed-off-by: xu,huilong --- tests/TestSuite_dynamic_config.py | 69 ++++++++++++++++++++++++++++++++------- 1 file changed, 58 insertions(+), 11 deletions(-) diff --git a/tests/TestSuite_dynamic_config.py b/tests/TestSuite_dynamic_config.py index ba740b1..380fa6d 100644 --- a/tests/TestSuite_dynamic_config.py +++ b/tests/TestSuite_dynamic_config.py @@ -1,6 +1,6 @@ # BSD LICENSE # -# Copyright(c) 2010-2015 Intel Corporation. All rights reserved. +# Copyright(c) 2010-2016 Intel Corporation. All rights reserved. # All rights reserved. # # Redistribution and use in source and binary forms, with or without @@ -67,18 +67,12 @@ class TestDynamicConfig(TestCase): print self.dut_ports # Verify that enough ports are available - if self.nic in ["fortville_eagle", "fortville_spirit", "fortville_spirit_single"]: - self.verify(len(self.dut_ports) >= 2, "Insufficient ports") - else: - self.verify(len(self.dut_ports) >= 1, "Insufficient ports") + self.verify(len(self.dut_ports) >= 2, "Insufficient ports") # Prepare cores and ports cores = self.dut.get_core_list('1S/2C/2T') coreMask = dts.create_mask(cores) - if self.nic in ["fortville_eagle", "fortville_spirit", "fortville_spirit_single"]: - portMask = dts.create_mask(self.dut_ports[:2]) - else: - portMask = dts.create_mask([self.dut_ports[0]]) + portMask = dts.create_mask(self.dut_ports[:2]) # launch app cmd = "./%s/build/app/test-pmd/testpmd -c %s -n 3 -- -i --rxpt=0 \ @@ -99,8 +93,7 @@ class TestDynamicConfig(TestCase): self.verify(cmp(ret.lower(), self.dest) == 0, "MAC address wrong") self.verify("Promiscuous mode: enabled" in out, "wrong default promiscuous value") - if self.nic in ["fortville_eagle", "fortville_spirit", "fortville_spirit_single"]: - self.dut.send_expect("start", "testpmd> ", 120) + self.dut.send_expect("start", "testpmd> ", 120) def dynamic_config_send_packet(self, portid, destMac="00:11:22:33:44:55"): """ @@ -129,6 +122,7 @@ class TestDynamicConfig(TestCase): portid = self.dut_ports[0] # get the current rx statistic + out = self.dut.send_expect("clear port stats all" , "testpmd> ") out = self.dut.send_expect("show port stats %d" % portid, "testpmd> ") cur_rxpkt = dts.regexp(out, "RX-packets: ([0-9]+)") @@ -211,7 +205,60 @@ class TestDynamicConfig(TestCase): # check the pakcet increasment self.verify(int(cur_rxpkt) == int( pre_rxpkt) + 1, "2nd packet increasment error") + def test_dynamic_config_broadcast(self): + """ + Dynamic config disable promiscuous, send a broadcast packet + dpdk will received packet and fwd by io model. send a general packet + and dst mac not port mac, dpdk will not received packet. + """ + + self.dut.send_expect("set promisc all off", "testpmd> ") + self.dut.send_expect("set fwd io", "testpmd> ") + self.dut.send_expect("clear port stats all", "testpmd> ") + + self.dynamic_config_send_packet(self.dut_ports[0],"ff:ff:ff:ff:ff:ff") + out = self.dut.send_expect( + "show port stats %d" % self.dut_ports[1], "testpmd> ") + + cur_rxpkt = dts.regexp(out, "TX-packets: ([0-9]+)") + self.verify(int(cur_rxpkt) == 1, "1st packet increasment error") + + self.dut.send_expect("clear port stats all", "testpmd> ") + + self.dynamic_config_send_packet(self.dut_ports[0]) + out = self.dut.send_expect( + "show port stats %d" % self.dut_ports[1], "testpmd> ") + + cur_rxpkt = dts.regexp(out, "TX-packets: ([0-9]+)") + self.verify(int(cur_rxpkt) == 0, "2st packet increasment error") + + def test_dynamic_config_allmulticast(self): + """ + Dynamic config disable promiscuous,when dpdk enable multicast, send a + mulicast packet, dpdk received this packet and fwd by io model. when dpdk + disable multicast, dpdk not received this packet + """ + + self.dut.send_expect("set promisc all off", "testpmd> ") + self.dut.send_expect("set fwd io", "testpmd> ") + self.dut.send_expect("clear port stats all", "testpmd> ") + self.dut.send_expect("set allmulti all on", "testpmd> ") + self.dynamic_config_send_packet(self.dut_ports[0],"01:00:00:33:00:01") + out = self.dut.send_expect( + "show port stats %d" % self.dut_ports[1], "testpmd> ") + + cur_rxpkt = dts.regexp(out, "TX-packets: ([0-9]+)") + self.verify(int(cur_rxpkt) == 1, "1st packet increasment error") + + self.dut.send_expect("clear port stats all", "testpmd> ") + self.dut.send_expect("set allmulti all off", "testpmd> ") + self.dynamic_config_send_packet(self.dut_ports[0],"01:00:00:33:00:01") + out = self.dut.send_expect( + "show port stats %d" % self.dut_ports[1], "testpmd> ") + cur_rxpkt = dts.regexp(out, "TX-packets: ([0-9]+)") + self.verify(int(cur_rxpkt) == 0, "2st packet increasment error") + def test_dynamic_config_enable_promiscuous(self): """ Dynamic config enable promiscuous test -- 1.9.3