summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--regress/lib/libcrypto/asn1/asn1time.c46
1 files changed, 43 insertions, 3 deletions
diff --git a/regress/lib/libcrypto/asn1/asn1time.c b/regress/lib/libcrypto/asn1/asn1time.c
index d3927929ca9..2bcf3d69cae 100644
--- a/regress/lib/libcrypto/asn1/asn1time.c
+++ b/regress/lib/libcrypto/asn1/asn1time.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: asn1time.c,v 1.10 2022/06/27 13:54:58 beck Exp $ */
+/* $OpenBSD: asn1time.c,v 1.11 2022/06/30 08:32:26 beck Exp $ */
/*
* Copyright (c) 2015 Joel Sing <jsing@openbsd.org>
*
@@ -66,6 +66,32 @@ struct asn1_time_test asn1_invtime_tests[] = {
{
.str = "aaaaaaaaaaaaaaZ",
},
+ /* utc time with omitted seconds, should fail */
+ {
+ .str = "1609082343Z",
+ },
+};
+
+struct asn1_time_test asn1_invgentime_tests[] = {
+ /* Generalized time with omitted seconds, should fail */
+ {
+ .str = "201612081934Z",
+ },
+};
+
+struct asn1_time_test asn1_goodtime_tests[] = {
+ {
+ .str = "99990908234339Z",
+ .time = 1,
+ },
+ {
+ .str = "201612081934Z",
+ .time = 1,
+ },
+ {
+ .str = "1609082343Z",
+ .time = 0,
+ },
};
struct asn1_time_test asn1_gentime_tests[] = {
@@ -132,6 +158,8 @@ struct asn1_time_test asn1_utctime_tests[] = {
#define N_INVTIME_TESTS \
(sizeof(asn1_invtime_tests) / sizeof(*asn1_invtime_tests))
+#define N_INVGENTIME_TESTS \
+ (sizeof(asn1_invgentime_tests) / sizeof(*asn1_invgentime_tests))
#define N_GENTIME_TESTS \
(sizeof(asn1_gentime_tests) / sizeof(*asn1_gentime_tests))
#define N_UTCTIME_TESTS \
@@ -188,7 +216,7 @@ asn1_compare_str(int test_no, struct asn1_string_st *asn1str, const char *str)
}
static int
-asn1_invtime_test(int test_no, struct asn1_time_test *att)
+asn1_invtime_test(int test_no, struct asn1_time_test *att, int gen)
{
ASN1_GENERALIZEDTIME *gt = NULL;
ASN1_UTCTIME *ut = NULL;
@@ -207,6 +235,12 @@ asn1_invtime_test(int test_no, struct asn1_time_test *att)
"GENERALIZEDTIME string '%s'\n", test_no, att->str);
goto done;
}
+
+ if (gen) {
+ failure = 0;
+ goto done;
+ }
+
if (ASN1_UTCTIME_set_string(ut, att->str) != 0) {
fprintf(stderr, "FAIL: test %i - successfully set UTCTIME "
"string '%s'\n", test_no, att->str);
@@ -433,7 +467,13 @@ main(int argc, char **argv)
fprintf(stderr, "Invalid time tests...\n");
for (i = 0; i < N_INVTIME_TESTS; i++) {
att = &asn1_invtime_tests[i];
- failed |= asn1_invtime_test(i, att);
+ failed |= asn1_invtime_test(i, att, 0);
+ }
+
+ fprintf(stderr, "Invalid generalized time tests...\n");
+ for (i = 0; i < N_INVGENTIME_TESTS; i++) {
+ att = &asn1_invgentime_tests[i];
+ failed |= asn1_invtime_test(i, att, 0);
}
fprintf(stderr, "GENERALIZEDTIME tests...\n");