[openssl-commits] [openssl] master update

Dr. Stephen Henson steve at openssl.org
Sun Nov 20 17:13:28 UTC 2016


The branch master has been updated
       via  52fe14e6628781f78ebe5468200e6c895c9bb47c (commit)
      from  7524c520173c2dcf75c50d9748d2aa62e163d58a (commit)


- Log -----------------------------------------------------------------
commit 52fe14e6628781f78ebe5468200e6c895c9bb47c
Author: Dr. Stephen Henson <steve at openssl.org>
Date:   Sat Nov 19 21:52:34 2016 +0000

    Add test to check EVP_PKEY method ordering.
    
    Reviewed-by: Rich Salz <rsalz at openssl.org>

-----------------------------------------------------------------------

Summary of changes:
 test/build.info                                    |  7 ++-
 test/pkey_meth_test.c                              | 63 ++++++++++++++++++++++
 .../{01-test_sanity.t => 30-test_pkey_meth.t}      |  2 +-
 3 files changed, 70 insertions(+), 2 deletions(-)
 create mode 100644 test/pkey_meth_test.c
 copy test/recipes/{01-test_sanity.t => 30-test_pkey_meth.t} (88%)

diff --git a/test/build.info b/test/build.info
index e25050b..31fa67d 100644
--- a/test/build.info
+++ b/test/build.info
@@ -24,7 +24,8 @@ IF[{- !$disabled{tests} -}]
           packettest asynctest secmemtest srptest memleaktest \
           dtlsv1listentest ct_test threadstest afalgtest d2i_test \
           ssl_test_ctx_test ssl_test x509aux cipherlist_test asynciotest \
-          bioprinttest sslapitest dtlstest sslcorrupttest bio_enc_test
+          bioprinttest sslapitest dtlstest sslcorrupttest bio_enc_test \
+          pkey_meth_test
 
   SOURCE[aborttest]=aborttest.c
   INCLUDE[aborttest]=../include
@@ -283,6 +284,10 @@ IF[{- !$disabled{tests} -}]
   INCLUDE[bio_enc_test]=../include
   DEPEND[bio_enc_test]=../libcrypto
 
+  SOURCE[pkey_meth_test]=pkey_meth_test.c testutil.c test_main.c
+  INCLUDE[pkey_meth_test]=../include
+  DEPEND[pkey_meth_test]=../libcrypto
+
   IF[{- !$disabled{psk} -}]
     PROGRAMS_NO_INST=dtls_mtu_test
     SOURCE[dtls_mtu_test]=dtls_mtu_test.c ssltestlib.c
diff --git a/test/pkey_meth_test.c b/test/pkey_meth_test.c
new file mode 100644
index 0000000..c76a54f
--- /dev/null
+++ b/test/pkey_meth_test.c
@@ -0,0 +1,63 @@
+/*
+ * Copyright 2016 The OpenSSL Project Authors. All Rights Reserved.
+ *
+ * Licensed under the OpenSSL license (the "License").  You may not use
+ * this file except in compliance with the License.  You can obtain a copy
+ * in the file LICENSE in the source distribution or at
+ * https://www.openssl.org/source/license.html
+ */
+
+/* Internal tests for EVP_PKEY method ordering */
+
+#include <stdio.h>
+#include <string.h>
+
+#include <openssl/evp.h>
+#include "testutil.h"
+#include "test_main.h"
+
+/**********************************************************************
+ *
+ * Test of EVP_PKEY_ASN1 method ordering
+ *
+ ***/
+
+static int test_asn1_meths()
+{
+    int i;
+    int prev = -1;
+    int good = 1;
+    int pkey_id;
+    const EVP_PKEY_ASN1_METHOD *ameth;
+
+    for (i = 0; i < EVP_PKEY_asn1_get_count(); i++) {
+        ameth = EVP_PKEY_asn1_get0(i);
+        EVP_PKEY_asn1_get0_info(&pkey_id, NULL, NULL, NULL, NULL, ameth);
+        if (pkey_id < prev)
+            good = 0;
+        prev = pkey_id;
+
+    }
+    if (!good) {
+        fprintf(stderr, "EVP_PKEY_ASN1_METHOD table out of order!\n");
+        for (i = 0; i < EVP_PKEY_asn1_get_count(); i++) {
+            const char *info;
+
+            ameth = EVP_PKEY_asn1_get0(i);
+            EVP_PKEY_asn1_get0_info(&pkey_id, NULL, NULL, &info, NULL, ameth);
+            if (info == NULL)
+                info = "<NO NAME>";
+            fprintf(stderr, "%d : %s : %s\n", pkey_id, OBJ_nid2ln(pkey_id),
+                    info);
+        }
+    } else {
+        fprintf(stderr, "Order OK\n");
+    }
+
+    return good;
+}
+
+void register_tests()
+{
+    ADD_TEST(test_asn1_meths);
+}
diff --git a/test/recipes/01-test_sanity.t b/test/recipes/30-test_pkey_meth.t
similarity index 88%
copy from test/recipes/01-test_sanity.t
copy to test/recipes/30-test_pkey_meth.t
index f01466d..1b78c25 100644
--- a/test/recipes/01-test_sanity.t
+++ b/test/recipes/30-test_pkey_meth.t
@@ -9,4 +9,4 @@
 
 use OpenSSL::Test::Simple;
 
-simple_test("test_sanity", "sanitytest");
+simple_test("test_pkey_meth", "pkey_meth_test");


More information about the openssl-commits mailing list