test: parse_timestamp UTC and fractional seconds tests

This commit is contained in:
Hristo Venev 2015-10-15 02:56:57 +03:00
parent e4eaf99a31
commit 063bc36469

View file

@ -23,12 +23,12 @@
#include "util.h"
static void test_one(const char *p) {
static void test_should_pass(const char *p) {
usec_t t, q;
char buf[FORMAT_TIMESTAMP_MAX], buf_relative[FORMAT_TIMESTAMP_RELATIVE_MAX];
assert_se(parse_timestamp(p, &t) >= 0);
format_timestamp(buf, sizeof(buf), t);
format_timestamp_us(buf, sizeof(buf), t);
log_info("%s", buf);
/* Chop off timezone */
@ -42,23 +42,50 @@ static void test_one(const char *p) {
assert_se(parse_timestamp(buf, &q) >= 0);
}
static void test_should_fail(const char *p) {
usec_t t;
assert_se(parse_timestamp(p, &t) < 0);
}
static void test_one(const char *p) {
_cleanup_free_ char *with_utc;
log_info("Test: %s", p);
with_utc = strjoin(p, " UTC", NULL);
test_should_pass(p);
test_should_pass(with_utc);
}
static void test_one_noutc(const char *p) {
_cleanup_free_ char *with_utc;
log_info("Test: %s", p);
with_utc = strjoin(p, " UTC", NULL);
test_should_pass(p);
test_should_fail(with_utc);
}
int main(int argc, char *argv[]) {
test_one("17:41");
test_one("18:42:44");
test_one("18:42:44.0");
test_one("18:42:44.999999999999");
test_one("12-10-02 12:13:14");
test_one("12-10-2 12:13:14");
test_one("12-10-03 12:13");
test_one("2012-12-30 18:42");
test_one("2012-10-02");
test_one("Tue 2012-10-02");
test_one("now");
test_one_noutc("now");
test_one("yesterday");
test_one("today");
test_one("tomorrow");
test_one("+2d");
test_one("+2y 4d");
test_one("5months ago");
test_one("@1395716396");
test_one_noutc("+2d");
test_one_noutc("+2y 4d");
test_one_noutc("5months ago");
test_one_noutc("@1395716396");
test_one_noutc("today UTC");
return 0;
}