get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

GET /api/patches/120307/?format=api
HTTP 200 OK
Allow: GET, PUT, PATCH, HEAD, OPTIONS
Content-Type: application/json
Vary: Accept

{
    "id": 120307,
    "url": "https://patches.dpdk.org/api/patches/120307/?format=api",
    "web_url": "https://patches.dpdk.org/project/dts/patch/20221130035329.98118-4-ke1.xu@intel.com/",
    "project": {
        "id": 3,
        "url": "https://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": "<20221130035329.98118-4-ke1.xu@intel.com>",
    "list_archive_url": "https://inbox.dpdk.org/dts/20221130035329.98118-4-ke1.xu@intel.com",
    "date": "2022-11-30T03:53:29",
    "name": "[V1,3/3] tests/dcf_lifecycle: update test plan to support represented port action from deprecated vf action",
    "commit_ref": null,
    "pull_url": null,
    "state": "accepted",
    "archived": false,
    "hash": "bf579e739396ab17a76dc2965840ef95ee3fbcfc",
    "submitter": {
        "id": 2810,
        "url": "https://patches.dpdk.org/api/people/2810/?format=api",
        "name": "Ke Xu",
        "email": "ke1.xu@intel.com"
    },
    "delegate": null,
    "mbox": "https://patches.dpdk.org/project/dts/patch/20221130035329.98118-4-ke1.xu@intel.com/mbox/",
    "series": [
        {
            "id": 25935,
            "url": "https://patches.dpdk.org/api/series/25935/?format=api",
            "web_url": "https://patches.dpdk.org/project/dts/list/?series=25935",
            "date": "2022-11-30T03:53:26",
            "name": "update test plans and tests to support represented port action and port representor action from deprecated vf action in dcf_lifecycle",
            "version": 1,
            "mbox": "https://patches.dpdk.org/series/25935/mbox/"
        }
    ],
    "comments": "https://patches.dpdk.org/api/patches/120307/comments/",
    "check": "success",
    "checks": "https://patches.dpdk.org/api/patches/120307/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 AAC16A00C2;\n\tWed, 30 Nov 2022 04:54:52 +0100 (CET)",
            "from mails.dpdk.org (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id A6A3642D0D;\n\tWed, 30 Nov 2022 04:54:52 +0100 (CET)",
            "from mga11.intel.com (mga11.intel.com [192.55.52.93])\n by mails.dpdk.org (Postfix) with ESMTP id CD8F04014F\n for <dts@dpdk.org>; Wed, 30 Nov 2022 04:54:49 +0100 (CET)",
            "from orsmga006.jf.intel.com ([10.7.209.51])\n by fmsmga102.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384;\n 29 Nov 2022 19:54:49 -0800",
            "from dpdk-xuke-lab.sh.intel.com ([10.67.114.198])\n by orsmga006.jf.intel.com with ESMTP; 29 Nov 2022 19:54:47 -0800"
        ],
        "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/simple;\n d=intel.com; i=@intel.com; q=dns/txt; s=Intel;\n t=1669780490; x=1701316490;\n h=from:to:cc:subject:date:message-id:in-reply-to:\n references:mime-version:content-transfer-encoding;\n bh=awllhLDM94fraZY5F2ccOYwXirN1ZMEIq8et7bTT+4M=;\n b=mx932GP9v0urCwTFbxXNFpnSsUZuTOwwiND+1BHlDjAif0nDN/HL/4g4\n kmvZSfOKUENrCWKSgr32gVgoqIqZnmfvz6B/si2bauIPESPWkDoLxVYNl\n kzXhfWn7PwIdPEQA6N4WSFrbXDYoh+5KsxUHo0XdK6QhunYOypURu50Lg\n obucxG0+eN8ldMbb6iHkOpa8Zic3me8uhf48BBHO+Ab1oYiZo8jqBsLcW\n I343qul7NdNmnV4cAvFC21Z1CgnMZ9fpwd3fxlTbVCAq/D6Jl/wjPd4dV\n LR7+WIsVgG/sVetqo76b0iFnG83r27QRcLiz9zu4pjphV1amK8wnhABLF A==;",
        "X-IronPort-AV": [
            "E=McAfee;i=\"6500,9779,10546\"; a=\"312910916\"",
            "E=Sophos;i=\"5.96,205,1665471600\"; d=\"scan'208\";a=\"312910916\"",
            "E=McAfee;i=\"6500,9779,10546\"; a=\"621728193\"",
            "E=Sophos;i=\"5.96,205,1665471600\"; d=\"scan'208\";a=\"621728193\""
        ],
        "X-ExtLoop1": "1",
        "From": "Ke Xu <ke1.xu@intel.com>",
        "To": "dts@dpdk.org",
        "Cc": "lijuan.tu@intel.com, Ke Xu <ke1.xu@intel.com>,\n Jin Ling <jin.ling@intel.com>",
        "Subject": "[DTS][PATCH V1 3/3] tests/dcf_lifecycle: update test plan to support\n represented port action from deprecated vf action",
        "Date": "Wed, 30 Nov 2022 11:53:29 +0800",
        "Message-Id": "<20221130035329.98118-4-ke1.xu@intel.com>",
        "X-Mailer": "git-send-email 2.25.1",
        "In-Reply-To": "<20221130035329.98118-1-ke1.xu@intel.com>",
        "References": "<20221130035329.98118-1-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>,\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"
    },
    "content": "A new API is introduced to replace the VF actions in DPDK 22.11. To support This\n new API, several modifications are made.\n\nNew field is added in setup for applying representor to the case.\n\nTestpmd args are modified to support appyling representors for the new API. Rules\n are modified for the old API being deprecated, changing to the new API. Ports id\n are modified corresponding to the port representors and modified API.\n\nSigned-off-by: Jin Ling <jin.ling@intel.com>\nSigned-off-by: Ke Xu <ke1.xu@intel.com>\n---\n tests/TestSuite_dcf_lifecycle.py | 24 +++++++++++++-----------\n 1 file changed, 13 insertions(+), 11 deletions(-)",
    "diff": "diff --git a/tests/TestSuite_dcf_lifecycle.py b/tests/TestSuite_dcf_lifecycle.py\nindex 1c97412c..cd7e1824 100644\n--- a/tests/TestSuite_dcf_lifecycle.py\n+++ b/tests/TestSuite_dcf_lifecycle.py\n@@ -239,11 +239,13 @@ class TestDcfLifeCycle(TestCase):\n         )\n         allowlist = {\n             \"pf1_vf0_dcf\": f\"-a {pf1_vf0},cap=dcf\",\n+            \"pf1_vf0_dcf_repre_vf1\": f\"-a {pf1_vf0},cap=dcf,representor=vf[1]\",\n             \"pf1_vf1_dcf\": f\"-a {pf1_vf1},cap=dcf\",\n             \"pf1_vf0_pf2_vf0_dcf\": f\"-a {pf1_vf0},cap=dcf -a {pf2_vf0},cap=dcf\",\n             \"pf1_vf1_vf2\": f\"-a {pf1_vf1} -a {pf1_vf2}\",\n             \"pf1_vf1\": f\"-a {pf1_vf1}\",\n             \"pf2_vf0_dcf\": f\"-a {pf2_vf0},cap=dcf\",\n+            \"pf2_vf0_dcf_repre_vf1\": f\"-a {pf2_vf0},cap=dcf,representor=vf[1]\",\n             \"pf1_vf0\": f\"-a {pf1_vf0}\",\n             \"pf1_vf0_dcf_vf1\": f\"-a {pf1_vf0},cap=dcf -a {pf1_vf1}\",\n         }\n@@ -278,11 +280,11 @@ class TestDcfLifeCycle(TestCase):\n             \"{port} \"\n             \"priority 0 \"\n             \"ingress pattern eth / ipv4 src is {ip_src} dst is {ip_dst} / end \"\n-            \"actions vf id {vf_id} / end\"\n+            \"actions represented_port ethdev_port_id {vf_id} / end\"\n         ).format(\n             **{\n                 \"port\": dut_port_id,\n-                \"vf_id\": 1,\n+                \"vf_id\": dut_port_id + 1,\n                 \"ip_src\": self.get_ip_layer()[\"ipv4\"][\"src\"],\n                 \"ip_dst\": self.get_ip_layer()[\"ipv4\"][\"dst\"],\n             }\n@@ -664,7 +666,7 @@ class TestDcfLifeCycle(TestCase):\n         except_content = None\n         try:\n             self.vf_set_trust()\n-            pmd_opts = [[\"pf1_vf0_dcf\", \"dcf\"], [\"pf1_vf1\", \"vf\"]]\n+            pmd_opts = [[\"pf1_vf0_dcf_repre_vf1\", \"dcf\"], [\"pf1_vf1\", \"vf\"]]\n             self.run_test_pre(pmd_opts)\n             self.vf_dcf_testpmd_set_flow_rule()\n             self.check_vf_pmd2_traffic(\"close_vf_dcf_testpmd\")\n@@ -684,7 +686,7 @@ class TestDcfLifeCycle(TestCase):\n         except_content = None\n         try:\n             self.vf_set_trust()\n-            pmd_opts = [[\"pf1_vf0_dcf\", \"dcf\"], [\"pf1_vf1\", \"vf\"]]\n+            pmd_opts = [[\"pf1_vf0_dcf_repre_vf1\", \"dcf\"], [\"pf1_vf1\", \"vf\"]]\n             self.run_test_pre(pmd_opts)\n             self.vf_dcf_testpmd_set_flow_rule()\n             self.check_vf_pmd2_traffic(\"vf_set_trust_off\")\n@@ -704,7 +706,7 @@ class TestDcfLifeCycle(TestCase):\n         except_content = None\n         try:\n             self.vf_set_trust()\n-            pmd_opts = [[\"pf1_vf0_dcf\", \"dcf\"], [\"pf1_vf1\", \"vf\"]]\n+            pmd_opts = [[\"pf1_vf0_dcf_repre_vf1\", \"dcf\"], [\"pf1_vf1\", \"vf\"]]\n             self.run_test_pre(pmd_opts)\n             self.vf_dcf_testpmd_set_flow_rule()\n             self.check_vf_pmd2_traffic(\n@@ -760,7 +762,7 @@ class TestDcfLifeCycle(TestCase):\n         except_content = None\n         try:\n             self.vf_set_trust()\n-            pmd_opts = [[\"pf1_vf0_dcf\", \"dcf\"], [\"pf1_vf1\", \"vf\"]]\n+            pmd_opts = [[\"pf1_vf0_dcf_repre_vf1\", \"dcf\"], [\"pf1_vf1\", \"vf\"]]\n             self.run_test_pre(pmd_opts)\n             self.vf_dcf_testpmd_set_flow_rule()\n             self.check_vf_pmd2_traffic(\"vf_set_mac_addr\", flag=True)\n@@ -1642,7 +1644,7 @@ class TestDcfLifeCycle(TestCase):\n         except_content = None\n         try:\n             self.vf_set_trust()\n-            pmd_opts = [[\"pf1_vf0_dcf\", \"dcf\"], [\"pf1_vf1\", \"vf\"]]\n+            pmd_opts = [[\"pf1_vf0_dcf_repre_vf1\", \"dcf\"], [\"pf1_vf1\", \"vf\"]]\n             self.run_test_pre(pmd_opts)\n             self.vf_dcf_testpmd_set_flow_rule()\n             self.check_vf_traffic(\n@@ -1668,7 +1670,7 @@ class TestDcfLifeCycle(TestCase):\n         except_content = None\n         try:\n             self.vf_set_trust()\n-            pmd_opts = [[\"pf1_vf0_dcf\", \"dcf\"], [\"pf1_vf1\", \"vf\"]]\n+            pmd_opts = [[\"pf1_vf0_dcf_repre_vf1\", \"dcf\"], [\"pf1_vf1\", \"vf\"]]\n             self.run_test_pre(pmd_opts)\n             self.vf_dcf_testpmd_set_flow_rule()\n             self.check_vf_traffic(\"vf_dcf_reset_device\")\n@@ -1690,7 +1692,7 @@ class TestDcfLifeCycle(TestCase):\n         except_content = None\n         try:\n             self.vf_set_trust()\n-            pmd_opts = [[\"pf1_vf0_dcf\", \"dcf\"], [\"pf1_vf1\", \"vf\"]]\n+            pmd_opts = [[\"pf1_vf0_dcf_repre_vf1\", \"dcf\"], [\"pf1_vf1\", \"vf\"]]\n             self.run_test_pre(pmd_opts)\n             self.vf_dcf_testpmd_set_flow_rule()\n             self.check_vf_traffic(\"vf_dcf_reset_port_detach\")\n@@ -1712,7 +1714,7 @@ class TestDcfLifeCycle(TestCase):\n         except_content = None\n         try:\n             self.vf_set_trust()\n-            pmd_opts = [[\"pf1_vf0_dcf\", \"dcf\"], [\"pf1_vf1\", \"vf\"]]\n+            pmd_opts = [[\"pf1_vf0_dcf_repre_vf1\", \"dcf\"], [\"pf1_vf1\", \"vf\"]]\n             self.run_test_pre(pmd_opts)\n             self.vf_dcf_testpmd_set_flow_rule()\n             self.check_vf_traffic(\"vf_dcf_reset_mtu\")\n@@ -1734,7 +1736,7 @@ class TestDcfLifeCycle(TestCase):\n         except_content = None\n         try:\n             self.vf_set_trust()\n-            pmd_opts = [[\"pf1_vf0_dcf\", \"dcf\"], [\"pf1_vf1\", \"vf\"]]\n+            pmd_opts = [[\"pf1_vf0_dcf_repre_vf1\", \"dcf\"], [\"pf1_vf1\", \"vf\"]]\n             self.run_test_pre(pmd_opts)\n             self.vf_dcf_testpmd_set_flow_rule()\n             self.check_vf_traffic(\"vf_dcf_set_mac_addr\")\n",
    "prefixes": [
        "V1",
        "3/3"
    ]
}