Blame glib/tests/timer.c

Packit ae235b
/* Unit tests for GTimer
Packit ae235b
 * Copyright (C) 2013 Red Hat, Inc.
Packit ae235b
 *
Packit ae235b
 * This work is provided "as is"; redistribution and modification
Packit ae235b
 * in whole or in part, in any medium, physical or electronic is
Packit ae235b
 * permitted without restriction.
Packit ae235b
 *
Packit ae235b
 * This work is distributed in the hope that it will be useful,
Packit ae235b
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit ae235b
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
Packit ae235b
 *
Packit ae235b
 * In no event shall the authors or contributors be liable for any
Packit ae235b
 * direct, indirect, incidental, special, exemplary, or consequential
Packit ae235b
 * damages (including, but not limited to, procurement of substitute
Packit ae235b
 * goods or services; loss of use, data, or profits; or business
Packit ae235b
 * interruption) however caused and on any theory of liability, whether
Packit ae235b
 * in contract, strict liability, or tort (including negligence or
Packit ae235b
 * otherwise) arising in any way out of the use of this software, even
Packit ae235b
 * if advised of the possibility of such damage.
Packit ae235b
 *
Packit ae235b
 * Author: Matthias Clasen
Packit ae235b
 */
Packit ae235b
Packit ae235b
#include "glib.h"
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_timer_basic (void)
Packit ae235b
{
Packit ae235b
  GTimer *timer;
Packit ae235b
  gdouble elapsed;
Packit ae235b
  gulong micros;
Packit ae235b
Packit ae235b
  timer = g_timer_new ();
Packit ae235b
Packit ae235b
  elapsed = g_timer_elapsed (timer, µs;;
Packit ae235b
Packit ae235b
  g_assert_cmpfloat (elapsed, <, 1.0);
Packit ae235b
  g_assert_cmpuint (micros, ==, ((guint64)(elapsed * 1e6)) % 1000000);
Packit ae235b
Packit ae235b
  g_timer_destroy (timer);
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_timer_stop (void)
Packit ae235b
{
Packit ae235b
  GTimer *timer;
Packit ae235b
  gdouble elapsed, elapsed2;
Packit ae235b
Packit ae235b
  timer = g_timer_new ();
Packit ae235b
Packit ae235b
  g_timer_stop (timer);
Packit ae235b
Packit ae235b
  elapsed = g_timer_elapsed (timer, NULL);
Packit ae235b
  g_usleep (100);
Packit ae235b
  elapsed2 = g_timer_elapsed (timer, NULL);
Packit ae235b
Packit ae235b
  g_assert_cmpfloat (elapsed, ==, elapsed2);
Packit ae235b
Packit ae235b
  g_timer_destroy (timer);
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_timer_continue (void)
Packit ae235b
{
Packit ae235b
  GTimer *timer;
Packit ae235b
  gdouble elapsed, elapsed2;
Packit ae235b
Packit ae235b
  timer = g_timer_new ();
Packit ae235b
  g_usleep (100);
Packit ae235b
  g_timer_stop (timer);
Packit ae235b
Packit ae235b
  elapsed = g_timer_elapsed (timer, NULL);
Packit ae235b
  g_timer_continue (timer);
Packit ae235b
  g_usleep (100);
Packit ae235b
  elapsed2 = g_timer_elapsed (timer, NULL);
Packit ae235b
Packit ae235b
  g_assert_cmpfloat (elapsed, <, elapsed2);
Packit ae235b
Packit ae235b
  g_timer_destroy (timer);
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_timer_reset (void)
Packit ae235b
{
Packit ae235b
  GTimer *timer;
Packit ae235b
  gdouble elapsed, elapsed2;
Packit ae235b
Packit ae235b
  timer = g_timer_new ();
Packit ae235b
  g_usleep (100);
Packit ae235b
  g_timer_stop (timer);
Packit ae235b
Packit ae235b
  elapsed = g_timer_elapsed (timer, NULL);
Packit ae235b
  g_timer_reset (timer);
Packit ae235b
  elapsed2 = g_timer_elapsed (timer, NULL);
Packit ae235b
Packit ae235b
  g_assert_cmpfloat (elapsed, >, elapsed2);
Packit ae235b
Packit ae235b
  g_timer_destroy (timer);
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_timeval_add (void)
Packit ae235b
{
Packit ae235b
  GTimeVal time = { 1, 0 };
Packit ae235b
Packit ae235b
  g_time_val_add (&time, 10);
Packit ae235b
Packit ae235b
  g_assert_cmpint (time.tv_sec, ==, 1); 
Packit ae235b
  g_assert_cmpint (time.tv_usec, ==, 10); 
Packit ae235b
Packit ae235b
  g_time_val_add (&time, -500);
Packit ae235b
  g_assert_cmpint (time.tv_sec, ==, 0); 
Packit ae235b
  g_assert_cmpint (time.tv_usec, ==, G_USEC_PER_SEC - 490); 
Packit ae235b
Packit ae235b
  g_time_val_add (&time, 1000);
Packit ae235b
  g_assert_cmpint (time.tv_sec, ==, 1); 
Packit ae235b
  g_assert_cmpint (time.tv_usec, ==, 510);
Packit ae235b
}
Packit ae235b
Packit ae235b
typedef struct {
Packit ae235b
  gboolean success;
Packit ae235b
  const gchar *in;
Packit ae235b
  GTimeVal val;
Packit ae235b
} TimeValParseTest;
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_timeval_from_iso8601 (void)
Packit ae235b
{
Packit ae235b
  TimeValParseTest tests[] = {
Packit ae235b
    { TRUE, "1990-11-01T10:21:17Z", { 657454877, 0 } },
Packit ae235b
    { TRUE, "19901101T102117Z", { 657454877, 0 } },
Packit ae235b
    { TRUE, "19901101T102117+5", { 657454577, 0 } },
Packit ae235b
    { TRUE, "19901101T102117+3:15", { 657443177, 0 } },
Packit ae235b
    { TRUE, "  1990-11-01T10:21:17Z  ", { 657454877, 0 } },
Packit ae235b
    { TRUE, "1970-01-01T00:00:17.12Z", { 17, 120000 } },
Packit ae235b
    { TRUE, "1970-01-01T00:00:17.1234Z", { 17, 123400 } },
Packit ae235b
    { TRUE, "1970-01-01T00:00:17.123456Z", { 17, 123456 } },
Packit ae235b
    { TRUE, "1980-02-22T12:36:00+02:00", { 320063760, 0 } },
Packit ae235b
    { FALSE, "   ", { 0, 0 } },
Packit ae235b
    { FALSE, "x", { 0, 0 } },
Packit ae235b
    { FALSE, "123x", { 0, 0 } },
Packit ae235b
    { FALSE, "2001-10+x", { 0, 0 } },
Packit ae235b
    { FALSE, "1980-02-22T", { 0, 0 } },
Packit ae235b
    { FALSE, "2001-10-08Tx", { 0, 0 } },
Packit ae235b
    { FALSE, "2001-10-08T10:11x", { 0, 0 } },
Packit ae235b
    { FALSE, "Wed Dec 19 17:20:20 GMT 2007", { 0, 0 } },
Packit ae235b
    { FALSE, "1980-02-22T10:36:00Zulu", { 0, 0 } }
Packit ae235b
  };
Packit ae235b
  GTimeVal out;
Packit ae235b
  gboolean success;
Packit ae235b
  gint i;
Packit ae235b
Packit ae235b
  g_unsetenv ("TZ");
Packit ae235b
Packit ae235b
  for (i = 0; i < G_N_ELEMENTS (tests); i++)
Packit ae235b
    {
Packit ae235b
      out.tv_sec = 0;
Packit ae235b
      out.tv_usec = 0;
Packit ae235b
      success = g_time_val_from_iso8601 (tests[i].in, &out;;
Packit ae235b
      g_assert (success == tests[i].success);
Packit ae235b
      if (tests[i].success)
Packit ae235b
        {
Packit ae235b
          g_assert_cmpint (out.tv_sec, ==, tests[i].val.tv_sec);
Packit ae235b
          g_assert_cmpint (out.tv_usec, ==, tests[i].val.tv_usec);
Packit ae235b
        }
Packit ae235b
    }
Packit ae235b
}
Packit ae235b
Packit ae235b
typedef struct {
Packit ae235b
  GTimeVal val;
Packit ae235b
  const gchar *expected;
Packit ae235b
} TimeValFormatTest;
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_timeval_to_iso8601 (void)
Packit ae235b
{
Packit ae235b
  TimeValFormatTest tests[] = {
Packit ae235b
    { { 657454877, 0 }, "1990-11-01T10:21:17Z" },
Packit ae235b
    { { 17, 123400 }, "1970-01-01T00:00:17.123400Z" }
Packit ae235b
  };
Packit ae235b
  gint i;
Packit ae235b
  gchar *out;
Packit ae235b
  GTimeVal val;
Packit ae235b
  gboolean ret;
Packit ae235b
Packit ae235b
  g_unsetenv ("TZ");
Packit ae235b
Packit ae235b
  for (i = 0; i < G_N_ELEMENTS (tests); i++)
Packit ae235b
    {
Packit ae235b
      out = g_time_val_to_iso8601 (&(tests[i].val));
Packit ae235b
      g_assert_cmpstr (out, ==, tests[i].expected);
Packit ae235b
Packit ae235b
      ret = g_time_val_from_iso8601 (out, &val;;
Packit ae235b
      g_assert (ret);
Packit ae235b
      g_assert_cmpint (val.tv_sec, ==, tests[i].val.tv_sec);
Packit ae235b
      g_assert_cmpint (val.tv_usec, ==, tests[i].val.tv_usec);
Packit ae235b
      g_free (out);
Packit ae235b
    }
Packit ae235b
}
Packit ae235b
Packit ae235b
int
Packit ae235b
main (int argc, char *argv[])
Packit ae235b
{
Packit ae235b
  g_test_init (&argc, &argv, NULL);
Packit ae235b
Packit ae235b
  g_test_add_func ("/timer/basic", test_timer_basic);
Packit ae235b
  g_test_add_func ("/timer/stop", test_timer_stop);
Packit ae235b
  g_test_add_func ("/timer/continue", test_timer_continue);
Packit ae235b
  g_test_add_func ("/timer/reset", test_timer_reset);
Packit ae235b
  g_test_add_func ("/timeval/add", test_timeval_add);
Packit ae235b
  g_test_add_func ("/timeval/from-iso8601", test_timeval_from_iso8601);
Packit ae235b
  g_test_add_func ("/timeval/to-iso8601", test_timeval_to_iso8601);
Packit ae235b
Packit ae235b
  return g_test_run ();
Packit ae235b
}