bug-gnulib
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

gettimeofday tests: Enhance test


From: Bruno Haible
Subject: gettimeofday tests: Enhance test
Date: Wed, 08 Mar 2023 10:18:00 +0100

This patch strengthens the gettimeofday() unit test, in a way similar to the
timespec_get() unit test.


2023-03-08  Bruno Haible  <bruno@clisp.org>

        gettimeofday tests: Enhance test.
        * tests/test-gettimeofday.c: Include <stdlib.h> and macros.h.
        (test_clobber): New function, extracted from main.
        (test_consistency): New function, based on tests/test-timespec_get.c.
        (main): Invoke both functions.
        * modules/gettimeofday-tests (Files): Add macros.h.

diff --git a/modules/gettimeofday-tests b/modules/gettimeofday-tests
index 996df8e716..83c7c4b363 100644
--- a/modules/gettimeofday-tests
+++ b/modules/gettimeofday-tests
@@ -1,6 +1,7 @@
 Files:
-tests/signature.h
 tests/test-gettimeofday.c
+tests/signature.h
+tests/macros.h
 
 Depends-on:
 
diff --git a/tests/test-gettimeofday.c b/tests/test-gettimeofday.c
index ac133e3695..6daf069339 100644
--- a/tests/test-gettimeofday.c
+++ b/tests/test-gettimeofday.c
@@ -1,6 +1,5 @@
 /*
  * Copyright (C) 2005, 2007, 2009-2023 Free Software Foundation, Inc.
- * Written by Jim Meyering.
  *
  * This program is free software: you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as published by
@@ -15,6 +14,8 @@
  * You should have received a copy of the GNU General Public License
  * along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 
+/* Written by Jim Meyering and Bruno Haible.  */
+
 #include <config.h>
 
 #include <sys/time.h>
@@ -26,10 +27,13 @@ SIGNATURE_CHECK (gettimeofday, int,
 #include <time.h>
 
 #include <stdio.h>
+#include <stdlib.h>
 #include <string.h>
 
-int
-main (void)
+#include "macros.h"
+
+static void
+test_clobber ()
 {
   time_t t = 0;
   struct tm *lt;
@@ -41,7 +45,43 @@ main (void)
   if (memcmp (lt, &saved_lt, sizeof (struct tm)) != 0)
     {
       fprintf (stderr, "gettimeofday still clobbers the localtime buffer!\n");
-      return 1;
+      exit (1);
     }
+}
+
+static void
+test_consistency ()
+{
+  struct timeval tv1;
+  time_t tt2;
+  struct timeval tv3;
+  time_t tt4;
+
+  ASSERT (gettimeofday (&tv1, NULL) == 0);
+  tt2 = time (NULL);
+  ASSERT (gettimeofday (&tv3, NULL) == 0);
+  tt4 = time (NULL);
+
+  /* Verify monotonicity of gettimeofday().  */
+  ASSERT (tv1.tv_sec < tv3.tv_sec
+          || (tv1.tv_sec == tv3.tv_sec && tv1.tv_usec <= tv3.tv_usec));
+
+  /* Verify monotonicity of time().  */
+  ASSERT (tt2 <= tt4);
+
+  /* Verify that the tv_sec field of the result is the same as time(NULL).  */
+  /* Note: This assertion sometimes fails on glibc systems, see
+     https://sourceware.org/bugzilla/show_bug.cgi?id=30200  */
+  ASSERT (tv1.tv_sec <= tt2);
+  ASSERT (tt2 <= tv3.tv_sec);
+  ASSERT (tv3.tv_sec <= tt4);
+}
+
+int
+main (void)
+{
+  test_clobber ();
+  test_consistency ();
+
   return 0;
 }






reply via email to

[Prev in Thread] Current Thread [Next in Thread]