mirror of
https://github.com/weechat/weechat.git
synced 2026-06-12 14:14:48 +02:00
789 lines
31 KiB
C++
789 lines
31 KiB
C++
/*
|
|
* SPDX-FileCopyrightText: 2014-2026 Sébastien Helleu <flashcode@flashtux.org>
|
|
*
|
|
* SPDX-License-Identifier: GPL-3.0-or-later
|
|
*
|
|
* This file is part of WeeChat, the extensible chat client.
|
|
*
|
|
* WeeChat is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* WeeChat is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with WeeChat. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
/* Test util functions */
|
|
|
|
#include "CppUTest/TestHarness.h"
|
|
|
|
#include "tests.h"
|
|
|
|
extern "C"
|
|
{
|
|
#include <limits.h>
|
|
#include <stdlib.h>
|
|
#include <unistd.h>
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#include <time.h>
|
|
#include <sys/time.h>
|
|
#include "src/core/core-string.h"
|
|
#include "src/core/core-util.h"
|
|
}
|
|
|
|
#define WEE_PARSE_NUMBER(__result, __parsed, __string, __base) \
|
|
LONGS_EQUAL( \
|
|
__result, \
|
|
util_parse_int (__string, __base, NULL)); \
|
|
LONGS_EQUAL( \
|
|
__result, \
|
|
util_parse_int (__string, __base, &number_int)); \
|
|
if (__result) \
|
|
LONGS_EQUAL(__parsed, number_int); \
|
|
LONGS_EQUAL( \
|
|
__result, \
|
|
util_parse_long (__string, __base, NULL)); \
|
|
LONGS_EQUAL( \
|
|
__result, \
|
|
util_parse_long (__string, __base, &number_long)); \
|
|
if (__result) \
|
|
LONGS_EQUAL(__parsed, number_long); \
|
|
LONGS_EQUAL( \
|
|
__result, \
|
|
util_parse_longlong (__string, __base, NULL)); \
|
|
LONGS_EQUAL( \
|
|
__result, \
|
|
util_parse_longlong (__string, __base, \
|
|
&number_longlong)); \
|
|
if (__result) \
|
|
CHECK_EQUAL(__parsed, number_longlong);
|
|
|
|
#define WEE_PARSE_DATE(__result, __sec, __usec, __datetime) \
|
|
tv.tv_sec = 0; \
|
|
tv.tv_usec = 0; \
|
|
LONGS_EQUAL(__result, util_parse_time (__datetime, &tv)); \
|
|
LONGS_EQUAL(__sec, tv.tv_sec); \
|
|
LONGS_EQUAL(__usec, tv.tv_usec);
|
|
|
|
#define WEE_PARSE_DELAY(__result, __result_delay, \
|
|
__delay, __factor) \
|
|
delay = ULLONG_MAX; \
|
|
LONGS_EQUAL(__result, \
|
|
util_parse_delay (__delay, __factor, &delay)); \
|
|
CHECK(delay == __result_delay);
|
|
|
|
TEST_GROUP(CoreUtil)
|
|
{
|
|
};
|
|
|
|
/*
|
|
* Tests functions:
|
|
* util_parse_int
|
|
* util_parse_long
|
|
* util_parse_longlong
|
|
*/
|
|
|
|
TEST(CoreUtil, ParseNumber)
|
|
{
|
|
int number_int;
|
|
long number_long;
|
|
long long number_longlong;
|
|
char str_number[256];
|
|
|
|
/* NULL string */
|
|
WEE_PARSE_NUMBER(0, 0, NULL, 10);
|
|
|
|
/* invalid base */
|
|
WEE_PARSE_NUMBER(0, 0, "123", -1);
|
|
WEE_PARSE_NUMBER(0, 0, "123", 1);
|
|
WEE_PARSE_NUMBER(0, 0, "123", 37);
|
|
|
|
/* invalid number */
|
|
WEE_PARSE_NUMBER(0, 0, "", 10);
|
|
WEE_PARSE_NUMBER(0, 0, " ", 10);
|
|
WEE_PARSE_NUMBER(0, 0, "-", 10);
|
|
WEE_PARSE_NUMBER(0, 0, "+", 10);
|
|
WEE_PARSE_NUMBER(0, 0, "3-", 10);
|
|
WEE_PARSE_NUMBER(0, 0, "3+", 10);
|
|
WEE_PARSE_NUMBER(0, 0, "--3", 10);
|
|
WEE_PARSE_NUMBER(0, 0, "++3", 10);
|
|
WEE_PARSE_NUMBER(0, 0, ".1", 10);
|
|
WEE_PARSE_NUMBER(0, 0, "1.", 10);
|
|
WEE_PARSE_NUMBER(0, 0, "1.2", 10);
|
|
WEE_PARSE_NUMBER(0, 0, "1,2", 10);
|
|
WEE_PARSE_NUMBER(0, 0, "a", 10);
|
|
WEE_PARSE_NUMBER(0, 0, "1a", 10);
|
|
WEE_PARSE_NUMBER(0, 0, "a1", 10);
|
|
WEE_PARSE_NUMBER(0, 0, "123 ", 10);
|
|
WEE_PARSE_NUMBER(0, 0, "12", 2);
|
|
WEE_PARSE_NUMBER(0, 0, "18", 8);
|
|
WEE_PARSE_NUMBER(0, 0, "1g", 16);
|
|
|
|
/* invalid int: outside range (INT_MIN, INT_MAX) */
|
|
snprintf (str_number, sizeof (str_number), "%d1", INT_MIN);
|
|
LONGS_EQUAL(0, util_parse_int (str_number, 10, &number_int));
|
|
snprintf (str_number, sizeof (str_number), "%d1", INT_MAX);
|
|
LONGS_EQUAL(0, util_parse_int (str_number, 10, &number_int));
|
|
|
|
/* invalid long: outside range (LONG_MIN, LONG_MAX) */
|
|
snprintf (str_number, sizeof (str_number), "%ld1", LONG_MIN);
|
|
LONGS_EQUAL(0, util_parse_long (str_number, 10, &number_long));
|
|
snprintf (str_number, sizeof (str_number), "%ld1", LONG_MAX);
|
|
LONGS_EQUAL(0, util_parse_long (str_number, 10, &number_long));
|
|
|
|
/* invalid long long: outside range (LLONG_MIN, LLONG_MAX) */
|
|
snprintf (str_number, sizeof (str_number), "%lld1", LLONG_MIN);
|
|
LONGS_EQUAL(0, util_parse_longlong (str_number, 10, &number_longlong));
|
|
snprintf (str_number, sizeof (str_number), "%lld1", LLONG_MAX);
|
|
LONGS_EQUAL(0, util_parse_longlong (str_number, 10, &number_longlong));
|
|
|
|
/* OK */
|
|
WEE_PARSE_NUMBER(1, 12, "12", 10);
|
|
WEE_PARSE_NUMBER(1, 15, " 15", 10);
|
|
WEE_PARSE_NUMBER(1, -3, "-3", 10);
|
|
WEE_PARSE_NUMBER(1, 5, "101", 2);
|
|
WEE_PARSE_NUMBER(1, 71, "107", 8);
|
|
WEE_PARSE_NUMBER(1, 30, "1e", 16);
|
|
WEE_PARSE_NUMBER(1, 31, "1F", 16);
|
|
|
|
/* OK, boundary limits for int */
|
|
snprintf (str_number, sizeof (str_number), "%d", INT_MIN);
|
|
LONGS_EQUAL(1, util_parse_int (str_number, 10, &number_int));
|
|
LONGS_EQUAL(INT_MIN, number_int);
|
|
snprintf (str_number, sizeof (str_number), "%d", INT_MAX);
|
|
LONGS_EQUAL(1, util_parse_int (str_number, 10, &number_int));
|
|
LONGS_EQUAL(INT_MAX, number_int);
|
|
|
|
/* OK, boundary limits for long */
|
|
snprintf (str_number, sizeof (str_number), "%ld", LONG_MIN);
|
|
LONGS_EQUAL(1, util_parse_long (str_number, 10, &number_long));
|
|
LONGS_EQUAL(LONG_MIN, number_long);
|
|
snprintf (str_number, sizeof (str_number), "%ld", LONG_MAX);
|
|
LONGS_EQUAL(1, util_parse_long (str_number, 10, &number_long));
|
|
LONGS_EQUAL(LONG_MAX, number_long);
|
|
|
|
/* OK, boundary limits for long long */
|
|
snprintf (str_number, sizeof (str_number), "%lld", LLONG_MIN);
|
|
LONGS_EQUAL(1, util_parse_longlong (str_number, 10, &number_longlong));
|
|
CHECK_EQUAL(LLONG_MIN, number_longlong);
|
|
snprintf (str_number, sizeof (str_number), "%lld", LLONG_MAX);
|
|
LONGS_EQUAL(1, util_parse_longlong (str_number, 10, &number_longlong));
|
|
CHECK_EQUAL(LLONG_MAX, number_longlong);
|
|
}
|
|
|
|
/*
|
|
* Tests functions:
|
|
* util_timeval_cmp
|
|
* util_timeval_diff
|
|
* util_timeval_add
|
|
*/
|
|
|
|
TEST(CoreUtil, Timeval)
|
|
{
|
|
struct timeval tv_zero = { 0, 0 };
|
|
struct timeval tv1 = { 123456, 12000 };
|
|
struct timeval tv2 = { 123456, 15000 };
|
|
struct timeval tv3 = { 123457, 15000 };
|
|
struct timeval tv4 = { 1409288400, 0 }; /* 2014-08-29 05:00:00 GMT */
|
|
struct timeval tv;
|
|
|
|
/* comparison */
|
|
LONGS_EQUAL(0, util_timeval_cmp (NULL, NULL));
|
|
LONGS_EQUAL(-1, util_timeval_cmp (NULL, &tv1));
|
|
LONGS_EQUAL(1, util_timeval_cmp (&tv1, NULL));
|
|
LONGS_EQUAL(0, util_timeval_cmp (&tv1, &tv1));
|
|
LONGS_EQUAL(-1, util_timeval_cmp (&tv1, &tv2));
|
|
LONGS_EQUAL(1, util_timeval_cmp (&tv2, &tv1));
|
|
LONGS_EQUAL(-1, util_timeval_cmp (&tv1, &tv3));
|
|
LONGS_EQUAL(1, util_timeval_cmp (&tv3, &tv1));
|
|
|
|
/* difference */
|
|
LONGS_EQUAL(0, util_timeval_diff (NULL, NULL));
|
|
LONGS_EQUAL(0, util_timeval_diff (NULL, &tv1));
|
|
LONGS_EQUAL(0, util_timeval_diff (&tv1, NULL));
|
|
LONGS_EQUAL(3000, util_timeval_diff (&tv1, &tv2));
|
|
LONGS_EQUAL(-3000, util_timeval_diff (&tv2, &tv1));
|
|
LONGS_EQUAL(1003000, util_timeval_diff (&tv1, &tv3));
|
|
LONGS_EQUAL(-1003000, util_timeval_diff (&tv3, &tv1));
|
|
CHECK(1409288400 * 1000000LL == util_timeval_diff (&tv_zero, &tv4));
|
|
|
|
/* add interval */
|
|
util_timeval_add (NULL, 0);
|
|
tv.tv_sec = 123456;
|
|
tv.tv_usec = 12000;
|
|
util_timeval_add (&tv, 10000);
|
|
LONGS_EQUAL(123456, tv.tv_sec);
|
|
LONGS_EQUAL(22000, tv.tv_usec);
|
|
util_timeval_add (&tv, 4000000);
|
|
LONGS_EQUAL(123460, tv.tv_sec);
|
|
LONGS_EQUAL(22000, tv.tv_usec);
|
|
util_timeval_add (&tv, 999000);
|
|
LONGS_EQUAL(123461, tv.tv_sec);
|
|
LONGS_EQUAL(21000, tv.tv_usec);
|
|
}
|
|
|
|
/*
|
|
* Tests functions:
|
|
* util_get_microseconds_string
|
|
*/
|
|
|
|
TEST(CoreUtil, GetMicrosecondsString)
|
|
{
|
|
char *str;
|
|
|
|
/* zero */
|
|
WEE_TEST_STR("0:00:00.000000",
|
|
util_get_microseconds_string (0ULL));
|
|
|
|
/* microseconds */
|
|
WEE_TEST_STR("0:00:00.000001", util_get_microseconds_string (1ULL));
|
|
WEE_TEST_STR("0:00:00.000123", util_get_microseconds_string (123ULL));
|
|
|
|
/* microseconds */
|
|
WEE_TEST_STR("0:00:00.001000", util_get_microseconds_string (1ULL * 1000ULL));
|
|
WEE_TEST_STR("0:00:00.123000", util_get_microseconds_string (123ULL * 1000ULL));
|
|
|
|
/* seconds */
|
|
WEE_TEST_STR("0:00:01.000000", util_get_microseconds_string (1ULL * 1000ULL * 1000ULL));
|
|
WEE_TEST_STR("0:00:12.000000", util_get_microseconds_string (12ULL * 1000ULL * 1000ULL));
|
|
|
|
/* minutes */
|
|
WEE_TEST_STR("0:01:00.000000", util_get_microseconds_string (1ULL * 60ULL * 1000ULL * 1000ULL));
|
|
WEE_TEST_STR("0:34:00.000000", util_get_microseconds_string (34ULL * 60ULL * 1000ULL * 1000ULL));
|
|
|
|
/* hours */
|
|
WEE_TEST_STR("1:00:00.000000", util_get_microseconds_string (1ULL * 60ULL * 60ULL * 1000ULL * 1000ULL));
|
|
WEE_TEST_STR("34:00:00.000000", util_get_microseconds_string (34ULL * 60ULL * 60ULL * 1000ULL * 1000ULL));
|
|
|
|
/* hours + minutes + seconds + milliseconds + microseconds */
|
|
WEE_TEST_STR("3:25:45.678901", util_get_microseconds_string (12345678901ULL));
|
|
}
|
|
|
|
/*
|
|
* Tests functions:
|
|
* util_get_time_string
|
|
*/
|
|
|
|
TEST(CoreUtil, GetTimeString)
|
|
{
|
|
time_t date;
|
|
const char *str_date;
|
|
|
|
date = 946684800; /* 2000-01-01 00:00 */
|
|
str_date = util_get_time_string (&date);
|
|
STRCMP_EQUAL("Sat, 01 Jan 2000 00:00:00", str_date);
|
|
}
|
|
|
|
/*
|
|
* Tests functions:
|
|
* util_strftimeval
|
|
*/
|
|
|
|
TEST(CoreUtil, Strftimeval)
|
|
{
|
|
struct timeval tv;
|
|
char str_time[256];
|
|
|
|
/* test date: 2023-12-25T10:29:09.456789Z */
|
|
tv.tv_sec = 1703500149;
|
|
tv.tv_usec = 456789;
|
|
|
|
LONGS_EQUAL(0, util_strftimeval (NULL, 0, NULL, NULL));
|
|
LONGS_EQUAL(0, util_strftimeval (str_time, 0, NULL, NULL));
|
|
LONGS_EQUAL(0, util_strftimeval (str_time, 0, "", NULL));
|
|
LONGS_EQUAL(0, util_strftimeval (str_time, -1, "", &tv));
|
|
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(0, util_strftimeval (str_time, sizeof (str_time), "", &tv));
|
|
STRCMP_EQUAL("", str_time);
|
|
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(8, util_strftimeval (str_time, sizeof (str_time),
|
|
"%H:%M:%S", &tv));
|
|
STRCMP_EQUAL("10:29:09", str_time);
|
|
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(8, util_strftimeval (str_time, sizeof (str_time),
|
|
"%@%H:%M:%S", &tv));
|
|
STRCMP_EQUAL("10:29:09", str_time);
|
|
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(19, util_strftimeval (str_time, sizeof (str_time),
|
|
"%Y-%m-%d %H:%M:%S", &tv));
|
|
STRCMP_EQUAL("2023-12-25 10:29:09", str_time);
|
|
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(19, util_strftimeval (str_time, sizeof (str_time),
|
|
"%Y-%m-%d %H:%M:%S", &tv));
|
|
STRCMP_EQUAL("2023-12-25 10:29:09", str_time);
|
|
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(21, util_strftimeval (str_time, sizeof (str_time),
|
|
"%Y-%m-%d %% %H:%M:%S", &tv));
|
|
STRCMP_EQUAL("2023-12-25 % 10:29:09", str_time);
|
|
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(21, util_strftimeval (str_time, sizeof (str_time),
|
|
"%Y-%m-%d %H:%M:%S.%.1", &tv));
|
|
STRCMP_EQUAL("2023-12-25 10:29:09.4", str_time);
|
|
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(22, util_strftimeval (str_time, sizeof (str_time),
|
|
"%Y-%m-%d %H:%M:%S.%.2", &tv));
|
|
STRCMP_EQUAL("2023-12-25 10:29:09.45", str_time);
|
|
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(23, util_strftimeval (str_time, sizeof (str_time),
|
|
"%Y-%m-%d %H:%M:%S.%.3", &tv));
|
|
STRCMP_EQUAL("2023-12-25 10:29:09.456", str_time);
|
|
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(24, util_strftimeval (str_time, sizeof (str_time),
|
|
"%Y-%m-%d %H:%M:%S.%.4", &tv));
|
|
STRCMP_EQUAL("2023-12-25 10:29:09.4567", str_time);
|
|
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(25, util_strftimeval (str_time, sizeof (str_time),
|
|
"%Y-%m-%d %H:%M:%S.%.5", &tv));
|
|
STRCMP_EQUAL("2023-12-25 10:29:09.45678", str_time);
|
|
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(26, util_strftimeval (str_time, sizeof (str_time),
|
|
"%Y-%m-%d %H:%M:%S.%.6", &tv));
|
|
STRCMP_EQUAL("2023-12-25 10:29:09.456789", str_time);
|
|
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(26, util_strftimeval (str_time, sizeof (str_time),
|
|
"%Y-%m-%d %H:%M:%S.%f", &tv));
|
|
STRCMP_EQUAL("2023-12-25 10:29:09.456789", str_time);
|
|
|
|
/* invalid microseconds digits (must be 1-6) */
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(20, util_strftimeval (str_time, sizeof (str_time),
|
|
"%Y-%m-%d %H:%M:%S.%.0", &tv));
|
|
STRCMP_EQUAL("2023-12-25 10:29:09.", str_time);
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(20, util_strftimeval (str_time, sizeof (str_time),
|
|
"%Y-%m-%d %H:%M:%S.%.7", &tv));
|
|
STRCMP_EQUAL("2023-12-25 10:29:09.", str_time);
|
|
|
|
/* timestamp */
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(10, util_strftimeval (str_time, sizeof (str_time), "%!", &tv));
|
|
STRCMP_EQUAL("1703500149", str_time);
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(17, util_strftimeval (str_time, sizeof (str_time), "%!.%f", &tv));
|
|
STRCMP_EQUAL("1703500149.456789", str_time);
|
|
|
|
/* test date: 2023-12-25T10:29:09.000000Z (with microseconds < 0) */
|
|
tv.tv_sec = 1703500149;
|
|
tv.tv_usec = -1;
|
|
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(26, util_strftimeval (str_time, sizeof (str_time),
|
|
"%Y-%m-%d %H:%M:%S.%f", &tv));
|
|
STRCMP_EQUAL("2023-12-25 10:29:09.000000", str_time);
|
|
|
|
/* test date: 2023-12-25T10:29:09.999999Z (with microseconds > 999999) */
|
|
tv.tv_sec = 1703500149;
|
|
tv.tv_usec = 1000000;
|
|
|
|
strcpy (str_time, "test");
|
|
LONGS_EQUAL(26, util_strftimeval (str_time, sizeof (str_time),
|
|
"%Y-%m-%d %H:%M:%S.%f", &tv));
|
|
STRCMP_EQUAL("2023-12-25 10:29:09.999999", str_time);
|
|
}
|
|
|
|
/*
|
|
* Tests functions:
|
|
* util_parse_time
|
|
*/
|
|
|
|
TEST(CoreUtil, ParseTime)
|
|
{
|
|
struct timeval tv;
|
|
struct tm *local_time;
|
|
time_t date;
|
|
char str_time[128];
|
|
|
|
/* test with UTC timezone */
|
|
setenv ("TZ", "UTC", 1);
|
|
tzset ();
|
|
|
|
LONGS_EQUAL(0, util_parse_time (NULL, NULL));
|
|
LONGS_EQUAL(0, util_parse_time (NULL, &tv));
|
|
|
|
WEE_PARSE_DATE(0, 0, 0, "");
|
|
WEE_PARSE_DATE(0, 0, 0, "invalid");
|
|
|
|
/* invalid: negative microseconds */
|
|
WEE_PARSE_DATE(0, 0, 0, "1703500149.-456789");
|
|
|
|
/*
|
|
* expected: 2023-12-25T00:00:00Z == 1703462400
|
|
*/
|
|
WEE_PARSE_DATE(1, 1703462400, 0, "2023-12-25");
|
|
|
|
/* expected: current date with specified local time */
|
|
date = time (NULL);
|
|
local_time = localtime (&date);
|
|
strftime (str_time, sizeof (str_time), "%H:%M:%S", local_time);
|
|
LONGS_EQUAL(1, util_parse_time (str_time, &tv));
|
|
CHECK((tv.tv_sec >= date) && (tv.tv_sec <= date + 10));
|
|
LONGS_EQUAL(0, tv.tv_usec);
|
|
|
|
date = time (NULL);
|
|
local_time = localtime (&date);
|
|
strftime (str_time, sizeof (str_time), "%H:%M:%S.456789", local_time);
|
|
LONGS_EQUAL(1, util_parse_time (str_time, &tv));
|
|
CHECK((tv.tv_sec >= date) && (tv.tv_sec <= date + 10));
|
|
LONGS_EQUAL(456789, tv.tv_usec);
|
|
|
|
/* expected: current date with specified local time + timezone offset */
|
|
date = time (NULL);
|
|
local_time = localtime (&date);
|
|
strftime (str_time, sizeof (str_time), "%H:%M:%S+0100", local_time);
|
|
LONGS_EQUAL(1, util_parse_time (str_time, &tv));
|
|
CHECK((tv.tv_sec >= date - 3600) && (tv.tv_sec <= date - 3600 + 10));
|
|
LONGS_EQUAL(0, tv.tv_usec);
|
|
|
|
date = time (NULL);
|
|
local_time = localtime (&date);
|
|
strftime (str_time, sizeof (str_time), "%H:%M:%S +01:00", local_time);
|
|
LONGS_EQUAL(1, util_parse_time (str_time, &tv));
|
|
CHECK((tv.tv_sec >= date - 3600) && (tv.tv_sec <= date - 3600 + 10));
|
|
LONGS_EQUAL(0, tv.tv_usec);
|
|
|
|
date = time (NULL);
|
|
local_time = localtime (&date);
|
|
strftime (str_time, sizeof (str_time), "%H:%M:%S +02:00", local_time);
|
|
LONGS_EQUAL(1, util_parse_time (str_time, &tv));
|
|
CHECK((tv.tv_sec >= date - 7200) && (tv.tv_sec <= date - 7200 + 10));
|
|
LONGS_EQUAL(0, tv.tv_usec);
|
|
|
|
date = time (NULL);
|
|
local_time = localtime (&date);
|
|
strftime (str_time, sizeof (str_time), "%H:%M:%S.456789+0100", local_time);
|
|
LONGS_EQUAL(1, util_parse_time (str_time, &tv));
|
|
CHECK((tv.tv_sec >= date - 3600) && (tv.tv_sec <= date - 3600 + 10));
|
|
LONGS_EQUAL(456789, tv.tv_usec);
|
|
|
|
date = time (NULL);
|
|
local_time = localtime (&date);
|
|
strftime (str_time, sizeof (str_time), "%H:%M:%S.456789 +01:00", local_time);
|
|
LONGS_EQUAL(1, util_parse_time (str_time, &tv));
|
|
CHECK((tv.tv_sec >= date - 3600) && (tv.tv_sec <= date - 3600 + 10));
|
|
LONGS_EQUAL(456789, tv.tv_usec);
|
|
|
|
date = time (NULL);
|
|
local_time = localtime (&date);
|
|
strftime (str_time, sizeof (str_time), "%H:%M:%S.456789 +02:00", local_time);
|
|
LONGS_EQUAL(1, util_parse_time (str_time, &tv));
|
|
CHECK((tv.tv_sec >= date - 7200) && (tv.tv_sec <= date - 7200 + 10));
|
|
LONGS_EQUAL(456789, tv.tv_usec);
|
|
|
|
/* expected: current date with specified UTC time */
|
|
date = time (NULL);
|
|
local_time = localtime (&date);
|
|
strftime (str_time, sizeof (str_time), "%H:%M:%SZ", local_time);
|
|
LONGS_EQUAL(1, util_parse_time (str_time, &tv));
|
|
CHECK((tv.tv_sec >= date) && (tv.tv_sec <= date + 10));
|
|
LONGS_EQUAL(0, tv.tv_usec);
|
|
|
|
date = time (NULL);
|
|
local_time = localtime (&date);
|
|
strftime (str_time, sizeof (str_time), "%H:%M:%S.456789Z", local_time);
|
|
LONGS_EQUAL(1, util_parse_time (str_time, &tv));
|
|
CHECK((tv.tv_sec >= date) && (tv.tv_sec <= date + 10));
|
|
LONGS_EQUAL(456789, tv.tv_usec);
|
|
|
|
/*
|
|
* expected: 2023-12-25T10:29:09.456789Z == 1703500149.456789
|
|
*/
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25T10:29:09");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25t10:29:09");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25T10:29:09Z");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25t10:29:09z");
|
|
WEE_PARSE_DATE(1, 1703500149, 456000, "2023-12-25T10:29:09.456Z");
|
|
WEE_PARSE_DATE(1, 1703500149, 456789, "2023-12-25T10:29:09.456789Z");
|
|
WEE_PARSE_DATE(1, 1703500149, 456789, "2023-12-25t10:29:09.456789z");
|
|
|
|
/*
|
|
* expected: 2023-12-25T10:29:09.456789Z == 1703500149.456789
|
|
* with space instead of "T"
|
|
*/
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25 10:29:09");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25 10:29:09Z");
|
|
WEE_PARSE_DATE(1, 1703500149, 456000, "2023-12-25 10:29:09.456Z");
|
|
WEE_PARSE_DATE(1, 1703500149, 456789, "2023-12-25 10:29:09.456789Z");
|
|
|
|
/*
|
|
* expected: 2023-12-25T10:29:09.456789Z == 1703500149.456789
|
|
* with timezone offset
|
|
*/
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25T10:29:09+00");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25T10:29:09+0000");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25T10:29:09+00:00");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25T10:29:09-00");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25T10:29:09-0000");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25T10:29:09-00:00");
|
|
WEE_PARSE_DATE(1, 1703500149, 456789, "2023-12-25T10:29:09.456789-00:00");
|
|
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25T12:29:09+02");
|
|
WEE_PARSE_DATE(1, 1703500149 - 60, 0, "2023-12-25T10:29:09+0001");
|
|
WEE_PARSE_DATE(1, 1703500149 - 60, 456789, "2023-12-25T10:29:09.456789+0001");
|
|
|
|
WEE_PARSE_DATE(1, 1703500149 - 7200, 0, "2023-12-25T10:29:09+0200");
|
|
WEE_PARSE_DATE(1, 1703500149 - 7200, 0, "2023-12-25T10:29:09+02:00");
|
|
WEE_PARSE_DATE(1, 1703500149 - 3600 - 1800, 0, "2023-12-25T10:29:09+0130");
|
|
WEE_PARSE_DATE(1, 1703500149 - 3600 - 1800, 0, "2023-12-25T10:29:09+01:30");
|
|
WEE_PARSE_DATE(1, 1703500149 - 3600 - 1800, 456789, "2023-12-25T10:29:09.456789+01:30");
|
|
|
|
WEE_PARSE_DATE(1, 1703500149 + 60, 0, "2023-12-25T10:29:09-0001");
|
|
WEE_PARSE_DATE(1, 1703500149 + 3600 + 1800, 0, "2023-12-25T10:29:09-0130");
|
|
WEE_PARSE_DATE(1, 1703500149 + 3600 + 1800, 0, "2023-12-25T10:29:09-01:30");
|
|
WEE_PARSE_DATE(1, 1703500149 + 3600 + 1800, 456789, "2023-12-25T10:29:09.456789-01:30");
|
|
|
|
/*
|
|
* expected: 2023-12-25T10:29:09.456789Z == 1703500149.456789
|
|
* with space instead of "T" and timezone offset
|
|
*/
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25 10:29:09+00");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25 10:29:09+0000");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25 10:29:09+00:00");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25 10:29:09-00");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25 10:29:09-0000");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25 10:29:09-00:00");
|
|
WEE_PARSE_DATE(1, 1703500149, 456789, "2023-12-25 10:29:09.456789-00:00");
|
|
|
|
WEE_PARSE_DATE(1, 1703500149 - 7200, 0, "2023-12-25 10:29:09+02");
|
|
WEE_PARSE_DATE(1, 1703500149 - 60, 0, "2023-12-25 10:29:09+0001");
|
|
WEE_PARSE_DATE(1, 1703500149 - 60, 456789, "2023-12-25 10:29:09.456789+0001");
|
|
|
|
WEE_PARSE_DATE(1, 1703500149 - 7200, 0, "2023-12-25 10:29:09+0200");
|
|
WEE_PARSE_DATE(1, 1703500149 - 7200, 0, "2023-12-25 10:29:09+02:00");
|
|
WEE_PARSE_DATE(1, 1703500149 - 3600 - 1800, 0, "2023-12-25 10:29:09+0130");
|
|
WEE_PARSE_DATE(1, 1703500149 - 3600 - 1800, 0, "2023-12-25 10:29:09+01:30");
|
|
WEE_PARSE_DATE(1, 1703500149 - 3600 - 1800, 456789, "2023-12-25 10:29:09.456789+01:30");
|
|
|
|
WEE_PARSE_DATE(1, 1703500149 + 60, 0, "2023-12-25 10:29:09-0001");
|
|
WEE_PARSE_DATE(1, 1703500149 + 3600 + 1800, 0, "2023-12-25 10:29:09-0130");
|
|
WEE_PARSE_DATE(1, 1703500149 + 3600 + 1800, 0, "2023-12-25 10:29:09-01:30");
|
|
WEE_PARSE_DATE(1, 1703500149 + 3600 + 1800, 456789, "2023-12-25 10:29:09.456789-01:30");
|
|
|
|
/*
|
|
* expected: 2023-12-25T10:29:09.456789Z == 1703500149.456789
|
|
* with space instead of "T" and timezone offset after a space
|
|
*/
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25 10:29:09 +00");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25 10:29:09 +0000");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25 10:29:09 +00:00");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25 10:29:09 -00");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25 10:29:09 -0000");
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "2023-12-25 10:29:09 -00:00");
|
|
WEE_PARSE_DATE(1, 1703500149, 456789, "2023-12-25 10:29:09.456789 -00:00");
|
|
|
|
WEE_PARSE_DATE(1, 1703500149 - 7200, 0, "2023-12-25 10:29:09 +02");
|
|
WEE_PARSE_DATE(1, 1703500149 - 60, 0, "2023-12-25 10:29:09 +0001");
|
|
WEE_PARSE_DATE(1, 1703500149 - 60, 456789, "2023-12-25 10:29:09.456789 +0001");
|
|
|
|
WEE_PARSE_DATE(1, 1703500149 - 7200, 0, "2023-12-25 10:29:09 +0200");
|
|
WEE_PARSE_DATE(1, 1703500149 - 7200, 0, "2023-12-25 10:29:09 +02:00");
|
|
WEE_PARSE_DATE(1, 1703500149 - 3600 - 1800, 0, "2023-12-25 10:29:09 +0130");
|
|
WEE_PARSE_DATE(1, 1703500149 - 3600 - 1800, 0, "2023-12-25 10:29:09 +01:30");
|
|
WEE_PARSE_DATE(1, 1703500149 - 3600 - 1800, 456789, "2023-12-25 10:29:09.456789 +01:30");
|
|
|
|
WEE_PARSE_DATE(1, 1703500149 + 60, 0, "2023-12-25 10:29:09 -0001");
|
|
WEE_PARSE_DATE(1, 1703500149 + 3600 + 1800, 0, "2023-12-25 10:29:09 -0130");
|
|
WEE_PARSE_DATE(1, 1703500149 + 3600 + 1800, 0, "2023-12-25 10:29:09 -01:30");
|
|
WEE_PARSE_DATE(1, 1703500149 + 3600 + 1800, 456789, "2023-12-25 10:29:09.456789 -01:30");
|
|
|
|
/* expected: 2023-12-25T10:29:09.456789Z == 1703500149.456789 */
|
|
WEE_PARSE_DATE(1, 1703500149, 0, "1703500149");
|
|
WEE_PARSE_DATE(1, 1703500149, 456000, "1703500149.456");
|
|
WEE_PARSE_DATE(1, 1703500149, 456789, "1703500149.456789");
|
|
WEE_PARSE_DATE(1, 1703500149, 456000, "1703500149,456");
|
|
WEE_PARSE_DATE(1, 1703500149, 456789, "1703500149,456789");
|
|
|
|
/* expected: 2023-12-25T10:29:09.456789Z == 1703500149.456789 */
|
|
/* with extra digits after microseconds */
|
|
WEE_PARSE_DATE(1, 1703500149, 456789, "1703500149.4567891");
|
|
WEE_PARSE_DATE(1, 1703500149, 456789, "1703500149.456789123456789123456789123456789");
|
|
|
|
setenv ("TZ", "", 1);
|
|
tzset ();
|
|
}
|
|
|
|
/*
|
|
* Tests functions:
|
|
* util_get_time_diff
|
|
*/
|
|
|
|
TEST(CoreUtil, GetTimeDiff)
|
|
{
|
|
time_t date1, date2, total_seconds;
|
|
int days, hours, minutes, seconds;
|
|
|
|
util_get_time_diff (0, 0, NULL, NULL, NULL, NULL, NULL);
|
|
|
|
date1 = 946684800; /* 2000-01-01 00:00:00 */
|
|
|
|
date2 = 946684800; /* 2000-01-01 00:00:00 */
|
|
util_get_time_diff (date1, date2,
|
|
&total_seconds, &days, &hours, &minutes, &seconds);
|
|
LONGS_EQUAL(0, total_seconds);
|
|
LONGS_EQUAL(0, days);
|
|
LONGS_EQUAL(0, hours);
|
|
LONGS_EQUAL(0, minutes);
|
|
LONGS_EQUAL(0, seconds);
|
|
|
|
date2 = 946684801; /* 2000-01-01 00:00:01 */
|
|
util_get_time_diff (date1, date2,
|
|
&total_seconds, &days, &hours, &minutes, &seconds);
|
|
LONGS_EQUAL(1, total_seconds);
|
|
LONGS_EQUAL(0, days);
|
|
LONGS_EQUAL(0, hours);
|
|
LONGS_EQUAL(0, minutes);
|
|
LONGS_EQUAL(1, seconds);
|
|
|
|
date2 = 946684880; /* 2000-01-01 00:01:20 */
|
|
util_get_time_diff (date1, date2,
|
|
&total_seconds, &days, &hours, &minutes, &seconds);
|
|
LONGS_EQUAL(80, total_seconds);
|
|
LONGS_EQUAL(0, days);
|
|
LONGS_EQUAL(0, hours);
|
|
LONGS_EQUAL(1, minutes);
|
|
LONGS_EQUAL(20, seconds);
|
|
|
|
date2 = 946695680; /* 2000-01-01 03:01:20 */
|
|
util_get_time_diff (date1, date2,
|
|
&total_seconds, &days, &hours, &minutes, &seconds);
|
|
LONGS_EQUAL(10880, total_seconds);
|
|
LONGS_EQUAL(0, days);
|
|
LONGS_EQUAL(3, hours);
|
|
LONGS_EQUAL(1, minutes);
|
|
LONGS_EQUAL(20, seconds);
|
|
|
|
date2 = 947127680; /* 2000-01-06 03:01:20 */
|
|
util_get_time_diff (date1, date2,
|
|
&total_seconds, &days, &hours, &minutes, &seconds);
|
|
LONGS_EQUAL(442880, total_seconds);
|
|
LONGS_EQUAL(5, days);
|
|
LONGS_EQUAL(3, hours);
|
|
LONGS_EQUAL(1, minutes);
|
|
LONGS_EQUAL(20, seconds);
|
|
|
|
date2 = 979527680; /* 2001-01-15 03:01:20 */
|
|
util_get_time_diff (date1, date2,
|
|
&total_seconds, &days, &hours, &minutes, &seconds);
|
|
LONGS_EQUAL(32842880, total_seconds);
|
|
LONGS_EQUAL(380, days);
|
|
LONGS_EQUAL(3, hours);
|
|
LONGS_EQUAL(1, minutes);
|
|
LONGS_EQUAL(20, seconds);
|
|
}
|
|
|
|
/*
|
|
* Tests functions:
|
|
* util_parse_delay
|
|
*/
|
|
|
|
TEST(CoreUtil, ParseDelay)
|
|
{
|
|
unsigned long long delay;
|
|
|
|
/* error: no delay */
|
|
LONGS_EQUAL(0, util_parse_delay ("123", 1ULL, NULL));
|
|
|
|
/* error: no string */
|
|
WEE_PARSE_DELAY(0, 0ULL, NULL, 0ULL);
|
|
WEE_PARSE_DELAY(0, 0ULL, NULL, 1ULL);
|
|
WEE_PARSE_DELAY(0, 0ULL, "", 0ULL);
|
|
WEE_PARSE_DELAY(0, 0ULL, "", 1ULL);
|
|
|
|
/* error: bad default_factor */
|
|
WEE_PARSE_DELAY(0, 0ULL, "abcd", 0ULL);
|
|
WEE_PARSE_DELAY(0, 0ULL, "123", 0ULL);
|
|
|
|
/* error: bad unit */
|
|
WEE_PARSE_DELAY(0, 0ULL, "123a", 1ULL);
|
|
WEE_PARSE_DELAY(0, 0ULL, "123ss", 1ULL);
|
|
WEE_PARSE_DELAY(0, 0ULL, "123mss", 1ULL);
|
|
WEE_PARSE_DELAY(0, 0ULL, "123uss", 1ULL);
|
|
|
|
/* error: bad number */
|
|
WEE_PARSE_DELAY(0, 0ULL, "abcd", 1LL);
|
|
|
|
/* error: bad delay */
|
|
WEE_PARSE_DELAY(0, 0ULL, "-123", 1LL);
|
|
|
|
/* tests with delay == 0 */
|
|
WEE_PARSE_DELAY(1, 0ULL, "0", 1ULL);
|
|
WEE_PARSE_DELAY(1, 0ULL, "0us", 1ULL);
|
|
WEE_PARSE_DELAY(1, 0ULL, "0ms", 1ULL);
|
|
WEE_PARSE_DELAY(1, 0ULL, "0s", 1ULL);
|
|
WEE_PARSE_DELAY(1, 0ULL, "0m", 1ULL);
|
|
WEE_PARSE_DELAY(1, 0ULL, "0h", 1ULL);
|
|
|
|
/* tests with delay == 123, default_factor = 1 (1 microsecond) */
|
|
WEE_PARSE_DELAY(1, 123ULL, "123", 1ULL);
|
|
WEE_PARSE_DELAY(1, 123ULL, "123us", 1ULL);
|
|
WEE_PARSE_DELAY(1, 123ULL * 1000ULL, "123ms", 1ULL);
|
|
WEE_PARSE_DELAY(1, 123ULL * 1000ULL * 1000ULL, "123s", 1ULL);
|
|
WEE_PARSE_DELAY(1, 123ULL * 1000ULL * 1000ULL * 60ULL, "123m", 1ULL);
|
|
WEE_PARSE_DELAY(1, 123ULL * 1000ULL * 1000ULL * 60ULL * 60ULL, "123h", 1ULL);
|
|
|
|
/* tests with delay == 123, default_factor = 1000 (1 millisecond) */
|
|
WEE_PARSE_DELAY(1, 123ULL * 1000ULL, "123", 1000ULL);
|
|
WEE_PARSE_DELAY(1, 123ULL, "123us", 1000ULL);
|
|
WEE_PARSE_DELAY(1, 123ULL * 1000ULL, "123ms", 1000ULL);
|
|
WEE_PARSE_DELAY(1, 123ULL * 1000ULL * 1000ULL, "123s", 1000ULL);
|
|
WEE_PARSE_DELAY(1, 123ULL * 1000ULL * 1000ULL * 60ULL, "123m", 1000ULL);
|
|
WEE_PARSE_DELAY(1, 123ULL * 1000ULL * 1000ULL * 60ULL * 60ULL, "123h", 1000ULL);
|
|
|
|
/* tests with delay == 123, default_factor = 1000000 (1 second) */
|
|
WEE_PARSE_DELAY(1, 123ULL * 1000ULL * 1000ULL, "123", 1000000ULL);
|
|
WEE_PARSE_DELAY(1, 123ULL, "123us", 1000000ULL);
|
|
WEE_PARSE_DELAY(1, 123ULL * 1000ULL, "123ms", 1000000ULL);
|
|
WEE_PARSE_DELAY(1, 123ULL * 1000ULL * 1000ULL, "123s", 1000000ULL);
|
|
WEE_PARSE_DELAY(1, 123ULL * 1000ULL * 1000ULL * 60ULL, "123m", 1000000ULL);
|
|
WEE_PARSE_DELAY(1, 123ULL * 1000ULL * 1000ULL * 60ULL * 60ULL, "123h", 1000000ULL);
|
|
}
|
|
|
|
/*
|
|
* Tests functions:
|
|
* util_version_number
|
|
*/
|
|
|
|
TEST(CoreUtil, VersionNumber)
|
|
{
|
|
CHECK(util_version_number (NULL) == 0);
|
|
CHECK(util_version_number ("") == 0);
|
|
CHECK(util_version_number ("abc") == 0);
|
|
|
|
CHECK(util_version_number ("0.3.2-dev") == 0x00030200);
|
|
CHECK(util_version_number ("0.3.2-rc1") == 0x00030200);
|
|
CHECK(util_version_number ("0.3.2") == 0x00030200);
|
|
CHECK(util_version_number ("0.3.1.1") == 0x00030101);
|
|
CHECK(util_version_number ("0.3.1") == 0x00030100);
|
|
CHECK(util_version_number ("0.3.0") == 0x00030000);
|
|
CHECK(util_version_number ("1.0") == 0x01000000);
|
|
CHECK(util_version_number ("1.0.0") == 0x01000000);
|
|
CHECK(util_version_number ("1.0.0.0") == 0x01000000);
|
|
CHECK(util_version_number ("1.0.1") == 0x01000100);
|
|
CHECK(util_version_number ("1.0.2") == 0x01000200);
|
|
CHECK(util_version_number ("1.1") == 0x01010000);
|
|
CHECK(util_version_number ("1.1.1") == 0x01010100);
|
|
CHECK(util_version_number ("1.1.2") == 0x01010200);
|
|
CHECK(util_version_number ("1.2.3.4") == 0x01020304);
|
|
CHECK(util_version_number ("255.255.255.255") == 0xFFFFFFFF);
|
|
CHECK(util_version_number ("999999999.999999999.999999999.999999999") == 0xFFFFFFFF);
|
|
}
|