Hi Anoob, 

>-----Original Message-----
>From: Anoob Joseph <ano...@marvell.com>
>Sent: Friday 3 September 2021 05:47
>To: Akhil Goyal <gak...@marvell.com>; Doherty, Declan
><declan.dohe...@intel.com>; Zhang, Roy Fan <roy.fan.zh...@intel.com>;
>Ananyev, Konstantin <konstantin.anan...@intel.com>
>Cc: Anoob Joseph <ano...@marvell.com>; Jerin Jacob <jer...@marvell.com>;
>Archana Muniganti <march...@marvell.com>; Tejasree Kondoj
><ktejas...@marvell.com>; Hemant Agrawal <hemant.agra...@nxp.com>;
>Nicolau, Radu <radu.nico...@intel.com>; Power, Ciara
><ciara.po...@intel.com>; Gagandeep Singh <g.si...@nxp.com>; dev@dpdk.org
>Subject: [PATCH v3 2/5] test/crypto: add combined mode tests
>
>Add framework to test IPsec features with all supported combinations of 
>ciphers.
>
>Signed-off-by: Anoob Joseph <ano...@marvell.com>
>Signed-off-by: Tejasree Kondoj <ktejas...@marvell.com>
>---
<snip>

>+static int
>+test_ipsec_proto_all(const struct ipsec_test_flags *flags) {
>+      struct ipsec_test_data td_outb[IPSEC_TEST_PACKETS_MAX];
>+      struct ipsec_test_data td_inb[IPSEC_TEST_PACKETS_MAX];
>+      unsigned int i, nb_pkts = 1, pass_cnt = 0;
>+      int ret;
>+

Is this testcase actually running multiple testcases under the hood?
I wonder could it be suited to use a sub-testsuite structure to bring the 
testcase results up to the top level, as done with cryptodev blockcipher tests.
Have you considered this approach?

Thanks,
Ciara

>+      for (i = 0; i < RTE_DIM(aead_list); i++) {
>+              test_ipsec_td_prepare(&aead_list[i],
>+                                    NULL,
>+                                    flags,
>+                                    td_outb,
>+                                    nb_pkts);
>+
>+              ret = test_ipsec_proto_process(td_outb, td_inb, nb_pkts, true,
>+                                             flags);
>+              if (ret == TEST_SKIPPED)
>+                      continue;
>+
>+              if (ret == TEST_FAILED)
>+                      return TEST_FAILED;
>+
>+              test_ipsec_td_update(td_inb, td_outb, nb_pkts, flags);
>+
>+              ret = test_ipsec_proto_process(td_inb, NULL, nb_pkts, true,
>+                                             flags);
>+              if (ret == TEST_SKIPPED)
>+                      continue;
>+
>+              if (ret == TEST_FAILED)
>+                      return TEST_FAILED;
>+
>+              if (flags->display_alg)
>+                      test_ipsec_display_alg(&aead_list[i], NULL);
>+
>+              pass_cnt++;
>+      }
>+
>+      if (pass_cnt > 0)
>+              return TEST_SUCCESS;
>+      else
>+              return TEST_SKIPPED;
>+}
>+
<snip>

Reply via email to