Skip unsupported digests in evp_test
authorDr. Stephen Henson <steve@openssl.org>
Thu, 26 Feb 2015 19:58:20 +0000 (19:58 +0000)
committerDr. Stephen Henson <steve@openssl.org>
Fri, 27 Feb 2015 00:18:10 +0000 (00:18 +0000)
Reviewed-by: Matt Caswell <matt@openssl.org>
crypto/evp/evp_test.c

index 97269931632b045be95921faec9bda7ed6a99ddc..44375bfa6a31f766688b69d6b61b371b40dfd952 100644 (file)
@@ -290,6 +290,7 @@ static int setup_test(struct evp_test *t, const struct evp_test_method *tmeth)
     if (t->meth) {
         t->ntests++;
         if (t->skip) {
+            t->meth = tmeth;
             t->nskip++;
             return 1;
         }
@@ -543,8 +544,14 @@ static int digest_test_init(struct evp_test *t, const char *alg)
     const EVP_MD *digest;
     struct digest_data *mdat = t->data;
     digest = EVP_get_digestbyname(alg);
-    if (!digest)
+    if (!digest) {
+        /* If alg has an OID assume disabled algorithm */
+        if (OBJ_sn2nid(alg) != NID_undef || OBJ_ln2nid(alg) != NID_undef) {
+            t->skip = 1;
+            return 1;
+        }
         return 0;
+    }
     mdat = OPENSSL_malloc(sizeof(struct digest_data));
     mdat->digest = digest;
     mdat->input = NULL;