2019-06-14 06:03:48 +02:00
|
|
|
/* $OpenBSD: tests.c,v 1.2 2019/06/14 04:03:48 djm Exp $ */
|
2017-03-14 02:20:29 +01:00
|
|
|
/*
|
|
|
|
* Regress test for conversions
|
|
|
|
*
|
|
|
|
* Placed in the public domain
|
|
|
|
*/
|
|
|
|
|
2017-03-16 04:05:46 +01:00
|
|
|
#include "includes.h"
|
|
|
|
|
2017-03-14 02:20:29 +01:00
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/param.h>
|
|
|
|
#include <stdio.h>
|
2017-03-16 03:45:17 +01:00
|
|
|
#ifdef HAVE_STDINT_H
|
2017-03-14 02:20:29 +01:00
|
|
|
#include <stdint.h>
|
2017-03-16 03:45:17 +01:00
|
|
|
#endif
|
2017-03-14 02:20:29 +01:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
2017-03-14 04:19:36 +01:00
|
|
|
#include "../test_helper/test_helper.h"
|
2017-03-14 02:20:29 +01:00
|
|
|
|
|
|
|
#include "misc.h"
|
|
|
|
|
|
|
|
void
|
|
|
|
tests(void)
|
|
|
|
{
|
|
|
|
char buf[1024];
|
|
|
|
|
|
|
|
TEST_START("conversion_convtime");
|
|
|
|
ASSERT_LONG_EQ(convtime("0"), 0);
|
|
|
|
ASSERT_LONG_EQ(convtime("1"), 1);
|
|
|
|
ASSERT_LONG_EQ(convtime("1S"), 1);
|
|
|
|
/* from the examples in the comment above the function */
|
|
|
|
ASSERT_LONG_EQ(convtime("90m"), 5400);
|
|
|
|
ASSERT_LONG_EQ(convtime("1h30m"), 5400);
|
|
|
|
ASSERT_LONG_EQ(convtime("2d"), 172800);
|
|
|
|
ASSERT_LONG_EQ(convtime("1w"), 604800);
|
|
|
|
|
|
|
|
/* negative time is not allowed */
|
|
|
|
ASSERT_LONG_EQ(convtime("-7"), -1);
|
|
|
|
ASSERT_LONG_EQ(convtime("-9d"), -1);
|
|
|
|
|
|
|
|
/* overflow */
|
2019-06-14 06:03:48 +02:00
|
|
|
snprintf(buf, sizeof buf, "%llu", (unsigned long long)LONG_MAX);
|
|
|
|
ASSERT_LONG_EQ(convtime(buf), -1);
|
2017-03-14 02:20:29 +01:00
|
|
|
snprintf(buf, sizeof buf, "%llu", (unsigned long long)LONG_MAX + 1);
|
|
|
|
ASSERT_LONG_EQ(convtime(buf), -1);
|
|
|
|
|
|
|
|
/* overflow with multiplier */
|
|
|
|
snprintf(buf, sizeof buf, "%lluM", (unsigned long long)LONG_MAX/60 + 1);
|
|
|
|
ASSERT_LONG_EQ(convtime(buf), -1);
|
|
|
|
ASSERT_LONG_EQ(convtime("1000000000000000000000w"), -1);
|
|
|
|
TEST_DONE();
|
|
|
|
}
|