Stats need not be reflected instantly after the operation. Relax the
test case to have retries to allow slower updates.

Signed-off-by: Anoob Joseph <ano...@marvell.com>
---
 app/test/test_cryptodev.h                |  1 +
 app/test/test_cryptodev_security_ipsec.c | 11 ++++++++++-
 2 files changed, 11 insertions(+), 1 deletion(-)

diff --git a/app/test/test_cryptodev.h b/app/test/test_cryptodev.h
index b479ab8a2a..bb54a33d62 100644
--- a/app/test/test_cryptodev.h
+++ b/app/test/test_cryptodev.h
@@ -9,6 +9,7 @@
 #define MAX_NUM_OPS_INFLIGHT            (4096)
 #define MIN_NUM_OPS_INFLIGHT            (128)
 #define DEFAULT_NUM_OPS_INFLIGHT        (128)
+#define TEST_STATS_RETRIES              (100)
 
 #define DEFAULT_NUM_XFORMS              (2)
 #define NUM_MBUFS                       (8191)
diff --git a/app/test/test_cryptodev_security_ipsec.c 
b/app/test/test_cryptodev_security_ipsec.c
index 1aba1ad993..e6a81ca186 100644
--- a/app/test/test_cryptodev_security_ipsec.c
+++ b/app/test/test_cryptodev_security_ipsec.c
@@ -1103,9 +1103,12 @@ test_ipsec_stats_verify(void *ctx,
                        enum rte_security_ipsec_sa_direction dir)
 {
        struct rte_security_stats stats = {0};
-       int ret = TEST_SUCCESS;
+       int retries = 0, ret = TEST_SUCCESS;
 
        if (flags->stats_success) {
+stats_get:
+               ret = TEST_SUCCESS;
+
                if (rte_security_session_stats_get(ctx, sess, &stats) < 0)
                        return TEST_FAILED;
 
@@ -1118,6 +1121,12 @@ test_ipsec_stats_verify(void *ctx,
                            stats.ipsec.ierrors != 0)
                                ret = TEST_FAILED;
                }
+
+               if (ret == TEST_FAILED && retries < TEST_STATS_RETRIES) {
+                       retries++;
+                       rte_delay_ms(1);
+                       goto stats_get;
+               }
        }
 
        return ret;
-- 
2.45.2

Reply via email to