Tested-by: Han,YingyaX BRs, Yingya -----Original Message----- From: dts On Behalf Of Chen,Bo Sent: Wednesday, April 22, 2020 5:49 PM To: dts@dpdk.org Cc: Chen, BoX C ; Chen@dpdk.org Subject: [dts] [PATCH V1] tests/ABI: add abi stable test case add ABI stable test case: negative Signed-off-by: Chen,Bo --- tests/TestSuite_ABI_stable.py | 129 ++++++++++++++++++++++++++++++++++ 1 file changed, 129 insertions(+) create mode 100644 tests/TestSuite_ABI_stable.py diff --git a/tests/TestSuite_ABI_stable.py b/tests/TestSuite_ABI_stable.py new file mode 100644 index 0000000..d292b33 --- /dev/null +++ b/tests/TestSuite_ABI_stable.py @@ -0,0 +1,129 @@ +# BSD LICENSE +# +# Copyright(c) 2010-2014 Intel Corporation. All rights reserved. +# All rights reserved. +# +# Redistribution and use in source and binary forms, with or without # +modification, are permitted provided that the following conditions # +are met: +# +# * Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# * Redistributions in binary form must reproduce the above copyright +# notice, this list of conditions and the following disclaimer in +# the documentation and/or other materials provided with the +# distribution. +# * Neither the name of Intel Corporation nor the names of its +# contributors may be used to endorse or promote products derived +# from this software without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS # +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT # +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR # +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT # +OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, # +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT # +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, # +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY # +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT # +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE # +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +""" +DPDK Test suite. + +Test support of RX/TX Checksum Offload Features by Poll Mode Drivers. + +""" +import utils +import time + +from test_case import TestCase +from pmd_output import PmdOutput +from settings import load_global_setting, HOST_SHARED_LIB_SETTING, +HOST_SHARED_LIB_PATH + + +class TestABIStable(TestCase): + + def set_up_all(self): + """ + Run at the start of each test suite. + """ + self.pmdout = PmdOutput(self.dut) + self.dut_ports = self.dut.get_ports(self.nic) + self.port_mask = utils.create_mask([self.dut_ports[0]]) + use_shared_lib = load_global_setting(HOST_SHARED_LIB_SETTING) + self.verify(use_shared_lib != 'ture', "The case only support + ABI mode") + + def set_up(self): + """ + Run before each test case. + """ + pass + + def test_negative(self): + net_device = self.dut.ports_info[0]['port'] + nic_drive = net_device.get_nic_driver() + shared_lib_path = load_global_setting(HOST_SHARED_LIB_PATH) + + self.verify(nic_drive != "ixgbe", "The case only support ixgbe drive") + # self.dut.send_expect("git apply 0001-rte_tx_burst_t_add-one-argument-at-the-begin.patch", "#") + # self.dut.build_install_dpdk(self.target) + # cmd = 'meson -Dexamples=all --buildtype=debugoptimized --default-library=shared ./devtools/.. ./build-gcc-shared' + # self.dut.send_expect(cmd, "#") + # cmd = 'meson configure -Ddisable_drivers=net/af_packet,net/ark,net/atlantic,net/avp,net/axgbe,net/bond,net/bnx2x,net/cxgbe,net/e1000,net/ena,net/enetc,net/enic,net/fm10k,net/hinic,net/hns3,net/iavf,net/ice,net/kni,net/liquidio,net/memif,net/netvsc,net/nfp,net/null,net/octeontx,net/octeontx2,net/pcap,net/pfe,net/qede,net/sfc,net/tap,net/thunderx,net/vdev_netvsc,net/vhost,net/virtio,net/vmxnet3,common/iavf,bus/ifpga,bus/vmbus,mempool/bucket,mempool/stack,raw/ioat,raw/octeontx2_dma,raw/octeontx2_ep,raw/skeleton,crypto/caam_jr,crypto/ccp,crypto/nitrox,crypto/null_crypto,crypto/octeontx_crypto,crypto/octeontx2_crypto,crypto/openssl,crypto/crypto_scheduler,crypto/virtio_crypto,vdpa/ifc,event/octeontx2,event/opdl,event/skeleton,event/sw,event/dsw,event/octeontx,baseband/null,baseband/turbo_sw,baseband/fpga_lte_fec,net/failsafe ./build-gcc-shared' + # self.dut.send_expect(cmd, "#") + # cmd = 'ninja -C ./build-gcc-shared' + # self.dut.send_expect(cmd, "#") + # cmd = 'cp -Rap ./build-gcc-shared/drivers/* ./build-gcc-shared/lib/' + # self.dut.send_expect(cmd, "#") + cmd = 'rm -rf {}'.format(shared_lib_path) + self.dut.send_expect(cmd, "#") + cmd = 'cp -a /root/shared_lib_negative {}'.format(shared_lib_path) + self.dut.send_expect(cmd, "#") + # cmd = 'mv ./build-gcc-shared/lib/ {}'.format(shared_lib_path) + # self.dut.send_expect(cmd, "#") + # cmd = 'rm -rf {}/*.a'.format(shared_lib_path) + # self.dut.send_expect(cmd, "#") + # cmd = 'rm -rf {}/*.exp_chk'.format(shared_lib_path) + # self.dut.send_expect(cmd, "#") + # cmd = 'rm -rf {}/*.def'.format(shared_lib_path) + # self.dut.send_expect(cmd, "#") + # cmd = 'rm -rf {}/*.c'.format(shared_lib_path) + # self.dut.send_expect(cmd, "#") + + self.pmdout.start_testpmd("Default", "--portmask={} ".format(self.port_mask)) + time.sleep(1) + self.dut.send_expect("set fwd txonly", "testpmd>") + self.dut.send_expect("start", "testpmd>") + time.sleep(1) + try: + self.dut.send_expect("quit", "testpmd>") + except Exception as e: + if 'TIMEOUT' in str(e): + self.logger.info(str(e)) + else: + self.verify(False, "No timeout") + self.dut.kill_all() + # time.sleep(1) + # self.dut.send_expect("git apply -R abi_negative.patch") + # self.dut.build_install_dpdk(self.target) + return + + self.verify(False, "negative test failed") + self.dut.kill_all() + # time.sleep(1) + # self.dut.send_expect("git apply -R abi_negative.patch", "#") + # self.dut.build_install_dpdk(self.target) + + def tear_down(self): + """ + Run after each test case. + """ + pass + + def tear_down_all(self): + """ + Run after each test suite. + """ + self.dut.kill_all() -- 2.17.1