[V2,0/6] Rewrite test suite for checksum_offload, tso and vf_offload
Message ID | 20230718012629.2471811-1-ke1.xu@intel.com (mailing list archive) |
---|---|
Headers |
Return-Path: <dts-bounces@dpdk.org> X-Original-To: patchwork@inbox.dpdk.org Delivered-To: patchwork@inbox.dpdk.org Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id 6A29842E9F; Tue, 18 Jul 2023 03:26:32 +0200 (CEST) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 3CF25406B3; Tue, 18 Jul 2023 03:26:32 +0200 (CEST) Received: from mga14.intel.com (mga14.intel.com [192.55.52.115]) by mails.dpdk.org (Postfix) with ESMTP id C0DC040223 for <dts@dpdk.org>; Tue, 18 Jul 2023 03:26:30 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1689643590; x=1721179590; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=opzSLH9IdGmQqycBab6R05aEbNmgkrLXTSaQ/4mm8CM=; b=HxxC0w0Ux1ISTsul4Koqyxpl+Z4+auykb+pVL0uYZv+JKTJdw0A3rqfN 7L331PQLQjNqDlV83+lFSUvU+qCe+8OmwGgj4BxcacQf10eg1nByWt8UX N9lKi59M2CKXEICThJMm2EMbqM+mH8s/tHtJYCx4hAgVjVzb6QWTXwR4H /nwHY3hGzJXZwQRJjSHrG3j4n8J1Rh4EaE2W9MVjBnoxVggUyneYgbsv6 gJ6aUalmlXXwdJWOS+ZdoLQkNnQ53EHF70D4mD+2UMHrhvnjh6GXL+qF/ V0lNtmQaKUriF1oJMu+9VHD7vNVIC7YoV4I6YwbK6jvOuCmWGNvZZ+tp4 Q==; X-IronPort-AV: E=McAfee;i="6600,9927,10774"; a="366119508" X-IronPort-AV: E=Sophos;i="6.01,211,1684825200"; d="scan'208";a="366119508" Received: from fmsmga002.fm.intel.com ([10.253.24.26]) by fmsmga103.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 17 Jul 2023 18:26:29 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=McAfee;i="6600,9927,10774"; a="837089786" X-IronPort-AV: E=Sophos;i="6.01,211,1684825200"; d="scan'208";a="837089786" Received: from dpdk-xuke-host.sh.intel.com ([10.67.114.220]) by fmsmga002.fm.intel.com with ESMTP; 17 Jul 2023 18:26:28 -0700 From: Ke Xu <ke1.xu@intel.com> To: dts@dpdk.org Cc: ke1.xu@intel.com, tarcadia@qq.com Subject: [DTS][Patch V2 0/6] Rewrite test suite for checksum_offload, tso and vf_offload Date: Tue, 18 Jul 2023 01:26:23 +0000 Message-Id: <20230718012629.2471811-1-ke1.xu@intel.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20230712203334.2032445-3-ke1.xu@intel.com> References: <20230712203334.2032445-3-ke1.xu@intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-BeenThere: dts@dpdk.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: test suite reviews and discussions <dts.dpdk.org> List-Unsubscribe: <https://mails.dpdk.org/options/dts>, <mailto:dts-request@dpdk.org?subject=unsubscribe> List-Archive: <http://mails.dpdk.org/archives/dts/> List-Post: <mailto:dts@dpdk.org> List-Help: <mailto:dts-request@dpdk.org?subject=help> List-Subscribe: <https://mails.dpdk.org/listinfo/dts>, <mailto:dts-request@dpdk.org?subject=subscribe> Errors-To: dts-bounces@dpdk.org |
Message
Ke Xu
July 18, 2023, 1:26 a.m. UTC
Checksum offload cases were in bad situation. Cases are not well organized in structure. Cases were added one by one along with the development of features. The very beginning cases are designed to verifying RX Checksum Offload enabling / disabling. The followed cases are to verify the TX Offload, and found a gap when TX introduces differences to IP and L4. Then IP and L4 RX cases are added again. There were also a gap found on the flag verifying and a seperate ol_flag case was added. To better organizing the checksum offload cases. I introduced the scenario based common cases and specific cases named with sufix to cover specific scenarios of special requirements. And we placed all available test scopes introduced in any existing cases to each of our common test execution to ensure no leakage to our test scopes. For scenarios, we introduce the very commonly used configurations for checksum as our test scenarios. These scenarios cover combined usage of HW checksum Offload, SW checksum and differently configured tunneling scenario, w/wo VLAN. These cases formed a organized web for future cases that if a new configuration is introduced, cases of new configuration combinations are to be added but existing configurations for different scopes are not to be added. For test scopes, we introduce verifying ol_flag, fwd stats, other verbose lines, and forwarded packet capturing and analyzing. All these scopes are recorder for verifying in each common checksum offload execution. This ensures no scope would be missed in this rewrite and in future case updating. The newly organized cases also helps better covering our existing test requirements. A common packet sending and recording helps cut down the repeating time cost of different executions for scope based redundant cases. This rewrite also helps formating a data-process-seperated suite structure. The test parameters and required packets are listed in front and cases are referring to the configured parameters. This helps better reading the suite code. In the test plan, new cases are added and old ones are merged with the new cases. Packets, ol_flags, stats and related test scopes are listed in table to show where the expected result is from. Similar modifications are also made to TSO cases. Common TSO executions are introduced and scenarios are designed based on configurations with test scopes covering all cases. Common packets are introduced. In vf_offload, checksum_offload and tso cases are synced with those in checksum_offload and tso suites. During the release DPDK 22.11 and 23.03, several main features are synced from PF to VF. This means the cases and scopes in checksum_offload and tso are available in vf_offload now. This patch also helped introducing these common test execution and scopes to vf_offload suite. Generally speaking, this case rewrite helps formating the cases structure and helps better maintaining the cases in future. Ke Xu (6): test_plans/checksum_offload: Refactor checksum_offload case. tests/checksum_offload: Refactor checksum_offload case. test_plans/tso: Refactor TSO case. tests/tso: Refactor TSO cases. test_plans/vf_offload: Refactor checksum_offload case. tests/vf_offload: Refactor vf_offload cases. test_plans/checksum_offload_test_plan.rst | 1478 ++++------ test_plans/tso_test_plan.rst | 489 +++- test_plans/vf_offload_test_plan.rst | 1356 +++++---- tests/TestSuite_checksum_offload.py | 1788 ++++++------ tests/TestSuite_tso.py | 1100 +++++--- tests/TestSuite_vf_offload.py | 3053 +++++++++++++-------- 6 files changed, 5369 insertions(+), 3895 deletions(-)