mirror of
https://gitlab.torproject.org/tpo/core/tor.git
synced 2024-11-30 23:53:32 +01:00
Fix parse_http_time and add tests
* It seems parse_http_time wasn't parsing correctly any date with commas (RFCs 1123 and 850). Fix that. * It seems parse_http_time was reporting the wrong month (they start at 0, not 1). Fix that. * Add some tests for parse_http_time, covering all three formats.
This commit is contained in:
parent
3ed4c5dc05
commit
d0d9c3d71e
@ -1416,13 +1416,13 @@ parse_http_time(const char *date, struct tm *tm)
|
|||||||
|
|
||||||
/* First, try RFC1123 or RFC850 format: skip the weekday. */
|
/* First, try RFC1123 or RFC850 format: skip the weekday. */
|
||||||
if ((cp = strchr(date, ','))) {
|
if ((cp = strchr(date, ','))) {
|
||||||
++cp;
|
cp += 2;
|
||||||
if (tor_sscanf(date, "%2u %3s %4u %2u:%2u:%2u GMT",
|
if (tor_sscanf(cp, "%2u %3s %4u %2u:%2u:%2u GMT",
|
||||||
&tm_mday, month, &tm_year,
|
&tm_mday, month, &tm_year,
|
||||||
&tm_hour, &tm_min, &tm_sec) == 6) {
|
&tm_hour, &tm_min, &tm_sec) == 6) {
|
||||||
/* rfc1123-date */
|
/* rfc1123-date */
|
||||||
tm_year -= 1900;
|
tm_year -= 1900;
|
||||||
} else if (tor_sscanf(date, "%2u-%3s-%2u %2u:%2u:%2u GMT",
|
} else if (tor_sscanf(cp, "%2u-%3s-%2u %2u:%2u:%2u GMT",
|
||||||
&tm_mday, month, &tm_year,
|
&tm_mday, month, &tm_year,
|
||||||
&tm_hour, &tm_min, &tm_sec) == 6) {
|
&tm_hour, &tm_min, &tm_sec) == 6) {
|
||||||
/* rfc850-date */
|
/* rfc850-date */
|
||||||
@ -1449,7 +1449,7 @@ parse_http_time(const char *date, struct tm *tm)
|
|||||||
/* Okay, now decode the month. */
|
/* Okay, now decode the month. */
|
||||||
for (i = 0; i < 12; ++i) {
|
for (i = 0; i < 12; ++i) {
|
||||||
if (!strcasecmp(MONTH_NAMES[i], month)) {
|
if (!strcasecmp(MONTH_NAMES[i], month)) {
|
||||||
tm->tm_mon = i+1;
|
tm->tm_mon = i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -86,6 +86,53 @@ test_util_time(void)
|
|||||||
;
|
;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_util_parse_http_time(void *arg)
|
||||||
|
{
|
||||||
|
struct tm a_time;
|
||||||
|
|
||||||
|
(void)arg;
|
||||||
|
|
||||||
|
/* Test parse_http_time */
|
||||||
|
|
||||||
|
test_eq(-1, parse_http_time("", &a_time));
|
||||||
|
test_eq(-1, parse_http_time("Sunday, 32 Aug 2004 00:48:22 GMT", &a_time));
|
||||||
|
test_eq(-1, parse_http_time("Sunday, 3 Aug 1869 00:48:22 GMT", &a_time));
|
||||||
|
test_eq(-1, parse_http_time("Sunday, 32-Aug-94 00:48:22 GMT", &a_time));
|
||||||
|
test_eq(-1, parse_http_time("Sunday, 3-Ago-04 00:48:22", &a_time));
|
||||||
|
test_eq(-1, parse_http_time("Sunday, August the third", &a_time));
|
||||||
|
|
||||||
|
test_eq(0, parse_http_time("Wednesday, 04 Aug 1994 00:48:22 GMT", &a_time));
|
||||||
|
test_eq((time_t)775961302UL, tor_timegm(&a_time));
|
||||||
|
test_eq(0, parse_http_time("Wednesday, 4 Aug 1994 0:48:22 GMT", &a_time));
|
||||||
|
test_eq((time_t)775961302UL, tor_timegm(&a_time));
|
||||||
|
test_eq(0, parse_http_time("Miercoles, 4 Aug 1994 0:48:22 GMT", &a_time));
|
||||||
|
test_eq((time_t)775961302UL, tor_timegm(&a_time));
|
||||||
|
test_eq(0, parse_http_time("Wednesday, 04-Aug-94 00:48:22 GMT", &a_time));
|
||||||
|
test_eq((time_t)775961302UL, tor_timegm(&a_time));
|
||||||
|
test_eq(0, parse_http_time("Wednesday, 4-Aug-94 0:48:22 GMT", &a_time));
|
||||||
|
test_eq((time_t)775961302UL, tor_timegm(&a_time));
|
||||||
|
test_eq(0, parse_http_time("Miercoles, 4-Aug-94 0:48:22 GMT", &a_time));
|
||||||
|
test_eq((time_t)775961302UL, tor_timegm(&a_time));
|
||||||
|
test_eq(0, parse_http_time("Wed Aug 04 00:48:22 1994", &a_time));
|
||||||
|
test_eq((time_t)775961302UL, tor_timegm(&a_time));
|
||||||
|
test_eq(0, parse_http_time("Wed Aug 4 0:48:22 1994", &a_time));
|
||||||
|
test_eq((time_t)775961302UL, tor_timegm(&a_time));
|
||||||
|
test_eq(0, parse_http_time("Mie Aug 4 0:48:22 1994", &a_time));
|
||||||
|
test_eq((time_t)775961302UL, tor_timegm(&a_time));
|
||||||
|
test_eq(-1, parse_http_time("2004-08-zz 99-99x99 GMT", &a_time));
|
||||||
|
test_eq(-1, parse_http_time("2011-03-32 00:00:00 GMT", &a_time));
|
||||||
|
test_eq(-1, parse_http_time("2011-03-30 24:00:00 GMT", &a_time));
|
||||||
|
test_eq(-1, parse_http_time("2011-03-30 23:60:00 GMT", &a_time));
|
||||||
|
test_eq(-1, parse_http_time("2011-03-30 23:59:62 GMT", &a_time));
|
||||||
|
test_eq(-1, parse_http_time("1969-03-30 23:59:59 GMT", &a_time));
|
||||||
|
test_eq(-1, parse_http_time("2011-00-30 23:59:59 GMT", &a_time));
|
||||||
|
test_eq(-1, parse_http_time("2011-03-30 23:59", &a_time));
|
||||||
|
|
||||||
|
done:
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
test_util_config_line(void)
|
test_util_config_line(void)
|
||||||
{
|
{
|
||||||
@ -1314,6 +1361,7 @@ test_util_di_ops(void)
|
|||||||
|
|
||||||
struct testcase_t util_tests[] = {
|
struct testcase_t util_tests[] = {
|
||||||
UTIL_LEGACY(time),
|
UTIL_LEGACY(time),
|
||||||
|
UTIL_TEST(parse_http_time, 0),
|
||||||
UTIL_LEGACY(config_line),
|
UTIL_LEGACY(config_line),
|
||||||
UTIL_LEGACY(strmisc),
|
UTIL_LEGACY(strmisc),
|
||||||
UTIL_LEGACY(pow2),
|
UTIL_LEGACY(pow2),
|
||||||
|
Loading…
Reference in New Issue
Block a user