mirror of
https://github.com/openssl/openssl.git
synced 2024-11-27 05:21:51 +08:00
2fae041d6c
Reviewed-by: Richard Levitte <levitte@openssl.org> Reviewed-by: Emilia Käsper <emilia@openssl.org> Reviewed-by: Tim Hudson <tjh@openssl.org> Reviewed-by: Rich Salz <rsalz@openssl.org> (Merged from https://github.com/openssl/openssl/pull/3011)
64 lines
1.6 KiB
C
64 lines
1.6 KiB
C
/*
|
|
* 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) {
|
|
TEST_error("EVP_PKEY_ASN1_METHOD table out of order");
|
|
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);
|
|
}
|