On Thu, Jul 18, 2024 at 12:07:12PM -0700, Stephen Hemminger wrote:
> This test should be using the TEST_ASSERT macros, and can be
> run as part of the fast test suite now.
> 
> Signed-off-by: Stephen Hemminger <step...@networkplumber.org>
> ---
>  app/test/test_alarm.c | 53 ++++++++++++++++---------------------------
>  1 file changed, 20 insertions(+), 33 deletions(-)
> 
> diff --git a/app/test/test_alarm.c b/app/test/test_alarm.c
> index 70e97a3109..4ba8aa1af2 100644
> --- a/app/test/test_alarm.c
> +++ b/app/test/test_alarm.c
> @@ -10,7 +10,8 @@
>  
>  #include "test.h"
>  
> -#ifndef RTE_EXEC_ENV_WINDOWS
> +#define US_PER_SEC 1000000
> +
>  static volatile int flag;
>  
>  static void
> @@ -19,46 +20,32 @@ test_alarm_callback(void *cb_arg)
>       flag = 1;
>       printf("Callback setting flag - OK. [cb_arg = %p]\n", cb_arg);
>  }
> -#endif
>  
>  static int
>  test_alarm(void)
>  {
> -#ifdef RTE_EXEC_ENV_FREEBSD
> -     printf("The alarm API is not supported on FreeBSD\n");
> -     return 0;
> -#endif
> +     int ret;
> +
> +     ret = rte_eal_alarm_set(0, test_alarm_callback, NULL);
> +     TEST_ASSERT_FAIL(ret, "should not be succeed with 0 us value");
> +
> +     ret = rte_eal_alarm_set(UINT64_MAX - 1, test_alarm_callback, NULL);
> +     TEST_ASSERT_FAIL(ret, "should not be succeed with (UINT64_MAX-1) us 
> value");
> +
> +     ret = rte_eal_alarm_set(10, NULL, NULL);
> +     TEST_ASSERT_FAIL(ret, "should not succeed with null callback 
> parameter");
>  

+1 to use of TEST_ASSERT_FAIL, the test is a lot cleaner now.
However, I think we still need the #ifdefs in it if some of it doesn't work
on Windows/BSD.

/Bruce

Reply via email to