Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/patches/103279/?format=api
http://patches.dpdk.org/api/patches/103279/?format=api", "web_url": "http://patches.dpdk.org/project/dts/patch/20211101120056.12228-4-zhiminx.huang@intel.com/", "project": { "id": 3, "url": "http://patches.dpdk.org/api/projects/3/?format=api", "name": "DTS", "link_name": "dts", "list_id": "dts.dpdk.org", "list_email": "dts@dpdk.org", "web_url": "", "scm_url": "git://dpdk.org/tools/dts", "webscm_url": "http://git.dpdk.org/tools/dts/", "list_archive_url": "https://inbox.dpdk.org/dts", "list_archive_url_format": "https://inbox.dpdk.org/dts/{}", "commit_url_format": "" }, "msgid": "<20211101120056.12228-4-zhiminx.huang@intel.com>", "list_archive_url": "https://inbox.dpdk.org/dts/20211101120056.12228-4-zhiminx.huang@intel.com", "date": "2021-11-01T12:00:55", "name": "[V1,4/5] tests/cvl_ip_fragment_rte_flow:modify testcase to adapt dpdk changed", "commit_ref": null, "pull_url": null, "state": "accepted", "archived": false, "hash": "a6f00605a8ea59dbcce3cd80e0962813a3bc1157", "submitter": { "id": 1685, "url": "http://patches.dpdk.org/api/people/1685/?format=api", "name": "Huang, ZhiminX", "email": "zhiminx.huang@intel.com" }, "delegate": null, "mbox": "http://patches.dpdk.org/project/dts/patch/20211101120056.12228-4-zhiminx.huang@intel.com/mbox/", "series": [ { "id": 20153, "url": "http://patches.dpdk.org/api/series/20153/?format=api", "web_url": "http://patches.dpdk.org/project/dts/list/?series=20153", "date": "2021-11-01T12:00:52", "name": "[V1,1/5] test_plans/cvl_iavf_ip_fragment_rte_flow:modify testplan to adapt dpdk changed", "version": 1, "mbox": "http://patches.dpdk.org/series/20153/mbox/" } ], "comments": "http://patches.dpdk.org/api/patches/103279/comments/", "check": "pending", "checks": "http://patches.dpdk.org/api/patches/103279/checks/", "tags": {}, "related": [], "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])\n\tby inbox.dpdk.org (Postfix) with ESMTP id 000E3A0C52;\n\tMon, 1 Nov 2021 04:31:56 +0100 (CET)", "from [217.70.189.124] (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id E90E841101;\n\tMon, 1 Nov 2021 04:31:56 +0100 (CET)", "from mga14.intel.com (mga14.intel.com [192.55.52.115])\n by mails.dpdk.org (Postfix) with ESMTP id E36C040DF6\n for <dts@dpdk.org>; Mon, 1 Nov 2021 04:31:54 +0100 (CET)", "from fmsmga001.fm.intel.com ([10.253.24.23])\n by fmsmga103.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384;\n 31 Oct 2021 20:31:54 -0700", "from unknown (HELO localhost.localdomain) ([10.240.183.103])\n by fmsmga001-auth.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384;\n 31 Oct 2021 20:31:53 -0700" ], "X-IronPort-AV": [ "E=McAfee;i=\"6200,9189,10154\"; a=\"231202982\"", "E=Sophos;i=\"5.87,198,1631602800\"; d=\"scan'208\";a=\"231202982\"", "E=Sophos;i=\"5.87,198,1631602800\"; d=\"scan'208\";a=\"637668846\"" ], "From": "Zhimin Huang <zhiminx.huang@intel.com>", "To": "dts@dpdk.org", "Cc": "Zhimin Huang <zhiminx.huang@intel.com>", "Date": "Mon, 1 Nov 2021 20:00:55 +0800", "Message-Id": "<20211101120056.12228-4-zhiminx.huang@intel.com>", "X-Mailer": "git-send-email 2.17.1", "In-Reply-To": "<20211101120056.12228-1-zhiminx.huang@intel.com>", "References": "<20211101120056.12228-1-zhiminx.huang@intel.com>", "Subject": "[dts] [PATCH V1 4/5] tests/cvl_ip_fragment_rte_flow:modify testcase\n to adapt dpdk changed", "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>,\n <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>,\n <mailto:dts-request@dpdk.org?subject=subscribe>", "Errors-To": "dts-bounces@dpdk.org", "Sender": "\"dts\" <dts-bounces@dpdk.org>" }, "content": "1.according to b3d95f1817288ca228f09b9164d6d3ff6249b175.\nthe default rss not support ipfrag rss, need take a rss rule to enable ipfrag rss for fdir test.\n\n2.according to e4a0a7599d974f05665fec3e4c251659f0b11453.\nswitch have high priority,should take the rule with mark into fdir.\n\nSigned-off-by: Zhimin Huang <zhiminx.huang@intel.com>\n---\n tests/TestSuite_cvl_ip_fragment_rte_flow.py | 42 +++++++++++----------\n 1 file changed, 23 insertions(+), 19 deletions(-)", "diff": "diff --git a/tests/TestSuite_cvl_ip_fragment_rte_flow.py b/tests/TestSuite_cvl_ip_fragment_rte_flow.py\nindex 181634c3..df67eac4 100644\n--- a/tests/TestSuite_cvl_ip_fragment_rte_flow.py\n+++ b/tests/TestSuite_cvl_ip_fragment_rte_flow.py\n@@ -31,6 +31,7 @@\n \n \n import time\n+import re\n \n from scapy.all import *\n \n@@ -71,7 +72,7 @@ tv_mac_ipv4_frag_fdir_passthru = {\n \n tv_mac_ipv4_frag_fdir_drop = {\n \"name\": \"tv_mac_ipv4_frag_fdir_drop\",\n- \"rule\": \"flow create 0 ingress pattern eth / ipv4 fragment_offset spec 0x2000 fragment_offset mask 0x2000 / end actions drop / end\",\n+ \"rule\": \"flow create 0 ingress pattern eth / ipv4 fragment_offset spec 0x2000 fragment_offset mask 0x2000 / end actions drop / mark / end\",\n \"scapy_str\": {\"matched\": [\"Ether()/IP(id=47750)/Raw('X'*666)\"],\n \"unmatched\": [\"Ether()/IPv6()/IPv6ExtHdrFragment(id=47750)/Raw('X'*666)\"]\n },\n@@ -105,7 +106,7 @@ tvs_mac_ipv4_fragment_fdir = [\n tv_mac_ipv4_frag_fdir_mark,\n ]\n \n-tvs_mac_ipv4_fragment_fdir_l2dst = [eval(str(element).replace('mac_ipv4_frag', 'mac_ipv4_frag_l2dst')\n+tvs_mac_ipv4_fragment_fdir_l2dst = [eval(str(element).replace('mac_ipv4_frag_fdir', 'mac_ipv4_frag_fdir_l2dst')\n .replace('eth / ipv4 fragment_offset', 'eth dst is 00:00:00:00:00:01 / ipv4 fragment_offset')\n .replace(\"Ether()\", \"Ether(dst='00:00:00:00:00:01')\")\n )\n@@ -113,12 +114,12 @@ tvs_mac_ipv4_fragment_fdir_l2dst = [eval(str(element).replace('mac_ipv4_frag', '\n \n tvs_mac_ipv4_frag_fdir_with_l2 = tvs_mac_ipv4_fragment_fdir_l2dst\n \n-tvs_mac_ipv4_fragment_fdir_l3src = [eval(str(element).replace('mac_ipv4_frag', 'mac_ipv4_frag_l3src')\n+tvs_mac_ipv4_fragment_fdir_l3src = [eval(str(element).replace('mac_ipv4_frag_fdir', 'mac_ipv4_frag_fdir_l3src')\n .replace('ipv4 fragment_offset', 'ipv4 src is 192.168.1.1 fragment_offset')\n .replace(\"IP(id=47750)\", \"IP(id=47750, src='192.168.1.1')\"))\n for element in tvs_mac_ipv4_fragment_fdir]\n \n-tvs_mac_ipv4_fragment_fdir_l3dst = [eval(str(element).replace('mac_ipv4_frag', 'mac_ipv4_frag_l3dst')\n+tvs_mac_ipv4_fragment_fdir_l3dst = [eval(str(element).replace('mac_ipv4_frag_fdir', 'mac_ipv4_frag_fdir_l3dst')\n .replace('ipv4 fragment_offset', 'ipv4 dst is 192.168.1.2 fragment_offset')\n .replace(\"IP(id=47750)\", \"IP(id=47750, dst='192.168.1.2')\"))\n for element in tvs_mac_ipv4_fragment_fdir]\n@@ -154,7 +155,7 @@ tv_mac_ipv6_frag_fdir_passthru = {\n \n tv_mac_ipv6_frag_fdir_drop = {\n \"name\": \"tv_mac_ipv6_frag_fdir_drop\",\n- \"rule\": \"flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext frag_data spec 0x0001 frag_data mask 0x0001 / end actions drop / end\",\n+ \"rule\": \"flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext frag_data spec 0x0001 frag_data mask 0x0001 / end actions drop / mark / end\",\n \"scapy_str\": {\"matched\": [\"Ether()/IPv6()/IPv6ExtHdrFragment(id=47750)/Raw('X'*666)\"],\n \"unmatched\": [\"Ether()/IP(id=47750)/Raw('X'*666)\"]\n },\n@@ -188,7 +189,7 @@ tvs_mac_ipv6_fragment_fdir = [\n tv_mac_ipv6_frag_fdir_mark,\n ]\n \n-tvs_mac_ipv6_fragment_fdir_l2dst = [eval(str(element).replace('mac_ipv6_frag', 'mac_ipv6_frag_l2dst')\n+tvs_mac_ipv6_fragment_fdir_l2dst = [eval(str(element).replace('mac_ipv6_frag_fdir', 'mac_ipv6_frag_fdir_l2dst')\n .replace('eth / ipv6 / ipv6_frag_ext frag_data', 'eth dst is 00:00:00:00:00:01 / ipv6 / ipv6_frag_ext frag_data')\n .replace(\"Ether()\", \"Ether(dst='00:00:00:00:00:01')\")\n )\n@@ -196,12 +197,12 @@ tvs_mac_ipv6_fragment_fdir_l2dst = [eval(str(element).replace('mac_ipv6_frag', '\n \n tvs_mac_ipv6_frag_fdir_with_l2 = tvs_mac_ipv6_fragment_fdir_l2dst\n \n-tvs_mac_ipv6_fragment_fdir_l3src = [eval(str(element).replace('mac_ipv6_frag', 'mac_ipv6_frag_l3src')\n+tvs_mac_ipv6_fragment_fdir_l3src = [eval(str(element).replace('mac_ipv6_frag_fdir', 'mac_ipv6_frag_fdir_l3src')\n .replace('/ ipv6 /', '/ ipv6 src is 2001::1 /')\n .replace(\"IPv6()\", \"IPv6(src='2001::1')\"))\n for element in tvs_mac_ipv6_fragment_fdir]\n \n-tvs_mac_ipv6_fragment_fdir_l3dst = [eval(str(element).replace('mac_ipv6_frag', 'mac_ipv6_frag_l3dst')\n+tvs_mac_ipv6_fragment_fdir_l3dst = [eval(str(element).replace('mac_ipv6_frag_fdir', 'mac_ipv6_frag_fdir_l3dst')\n .replace('/ ipv6 /', '/ ipv6 dst is 2001::2 /')\n .replace(\"IPv6()\", \"IPv6(dst='2001::2')\"))\n for element in tvs_mac_ipv6_fragment_fdir]\n@@ -366,9 +367,10 @@ class TestCvlIpFragmentRteFlow(TestCase):\n result = True\n result_list = []\n rule_list_fdir = [\n- 'flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / ipv4 src is 192.168.0.20 / end actions queue index 1 / end',\n- 'flow create 0 ingress pattern eth / ipv4 fragment_offset spec 0x2000 fragment_offset mask 0x2000 / end actions queue index 2 / end']\n- pkt_fdir = \"Ether(dst='00:11:22:33:44:55')/IP(src='192.168.0.20', id=47750)/Raw('X'*666)\"\n+ 'flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / ipv4 src is 192.168.0.20 / end actions queue index 1 / mark / end',\n+ 'flow create 0 ingress pattern eth / ipv4 fragment_offset spec 0x2000 fragment_offset mask 0x2000 / end actions queue index 2 / mark / end']\n+ pkt_fdir = [\"Ether(dst='00:11:22:33:44:55')/IP(src='192.168.0.20', id=47750)/Raw('X'*666)\"]\n+ p = re.compile(r\"port\\s+%s/queue\\s+(\\d+):\\s+received\\s+(\\d+)\\s+packets\" % 0)\n \n self.logger.info('Subcase 1: exclusive validation fdir rule')\n self.launch_testpmd(param_fdir=True)\n@@ -377,11 +379,12 @@ class TestCvlIpFragmentRteFlow(TestCase):\n except Exception as e:\n self.logger.warning('Subcase 1 failed: %s' % e)\n result = False\n- hashes, queues = self.rssprocess.send_pkt_get_hash_queues(pkts=pkt_fdir)\n- for queue in queues:\n- if '0x2' != queue:\n+ out = self.fdirprocess.send_pkt_get_output(pkt_fdir)\n+ res = p.findall(out)\n+ for queue in res:\n+ if queue[0][0].strip() != '2':\n result = False\n- self.logger.error('Error: queue index {} != 2'.format(queue))\n+ self.logger.error(\"Error: queue index {} != '2'\".format(queue[0][0]))\n continue\n result_list.append(result)\n self.dut.send_expect(\"quit\", \"# \")\n@@ -395,11 +398,12 @@ class TestCvlIpFragmentRteFlow(TestCase):\n except Exception as e:\n self.logger.warning('Subcase 2 failed: %s' % e)\n result = False\n- hashes, queues = self.rssprocess.send_pkt_get_hash_queues(pkts=pkt_fdir)\n- for queue in queues:\n- if '0x2' != queue:\n+ out = self.fdirprocess.send_pkt_get_output(pkt_fdir)\n+ res = p.findall(out)\n+ for queue in res:\n+ if queue[0][0].strip() != '2':\n result = False\n- self.logger.error('Error: queue index {} != 2'.format(queue))\n+ self.logger.error(\"Error: queue index {} != '2'\".format(queue[0][0]))\n continue\n result_list.append(result)\n self.dut.send_expect(\"quit\", \"# \")\n", "prefixes": [ "V1", "4/5" ] }{ "id": 103279, "url": "