mirror of
https://github.com/curl/curl.git
synced 2026-05-22 09:16:20 +03:00
- use `curlx_safefree()`.
- drop redundant blocks.
Follow-up to 7541ae569d #21667
Closes #21684
125 lines
4.1 KiB
C
125 lines
4.1 KiB
C
/***************************************************************************
|
|
* _ _ ____ _
|
|
* Project ___| | | | _ \| |
|
|
* / __| | | | |_) | |
|
|
* | (__| |_| | _ <| |___
|
|
* \___|\___/|_| \_\_____|
|
|
*
|
|
* Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
|
|
*
|
|
* This software is licensed as described in the file COPYING, which
|
|
* you should have received as part of this distribution. The terms
|
|
* are also available at https://curl.se/docs/copyright.html.
|
|
*
|
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
|
* copies of the Software, and permit persons to whom the Software is
|
|
* furnished to do so, under the terms of the COPYING file.
|
|
*
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
* KIND, either express or implied.
|
|
*
|
|
* SPDX-License-Identifier: curl
|
|
*
|
|
***************************************************************************/
|
|
#include "unitcheck.h"
|
|
#include "urldata.h"
|
|
|
|
#ifdef USE_SSL
|
|
#include "vtls/vtls.h"
|
|
#endif
|
|
|
|
static CURLcode test_unit3303(const char *arg)
|
|
{
|
|
UNITTEST_BEGIN_SIMPLE
|
|
|
|
#ifdef USE_SSL
|
|
CURL *curl;
|
|
struct connectdata *conn;
|
|
struct ssl_primary_config *primary;
|
|
char *saved;
|
|
static char alt_passwd[] = "wrong";
|
|
static char alt_key[] = "other.key";
|
|
static char alt_ktype[] = "DER";
|
|
static char alt_ctype[] = "P12";
|
|
|
|
curl_global_init(CURL_GLOBAL_ALL);
|
|
curl = curl_easy_init();
|
|
if(!curl) {
|
|
curl_global_cleanup();
|
|
goto unit_test_abort;
|
|
}
|
|
|
|
curl_easy_setopt(curl, CURLOPT_SSLCERT, "client.pem");
|
|
curl_easy_setopt(curl, CURLOPT_SSLKEY, "client.key");
|
|
curl_easy_setopt(curl, CURLOPT_KEYPASSWD, "secret");
|
|
curl_easy_setopt(curl, CURLOPT_SSLCERTTYPE, "PEM");
|
|
curl_easy_setopt(curl, CURLOPT_SSLKEYTYPE, "PEM");
|
|
|
|
if(Curl_ssl_easy_config_complete((struct Curl_easy *)curl)) {
|
|
curl_easy_cleanup(curl);
|
|
curl_global_cleanup();
|
|
goto unit_test_abort;
|
|
}
|
|
|
|
conn = curlx_calloc(1, sizeof(*conn));
|
|
if(!conn || Curl_ssl_conn_config_init((struct Curl_easy *)curl, conn)) {
|
|
if(conn)
|
|
Curl_ssl_conn_config_cleanup(conn);
|
|
curlx_free(conn);
|
|
curl_easy_cleanup(curl);
|
|
curl_global_cleanup();
|
|
goto unit_test_abort;
|
|
}
|
|
|
|
/* Baseline: identical config must match. */
|
|
fail_unless(Curl_ssl_conn_config_match((struct Curl_easy *)curl, conn,
|
|
FALSE),
|
|
"identical mTLS config should match");
|
|
|
|
primary = &((struct Curl_easy *)curl)->set.ssl.primary;
|
|
|
|
/* Different key_passwd must not match. */
|
|
saved = primary->key_passwd;
|
|
primary->key_passwd = alt_passwd;
|
|
fail_unless(!Curl_ssl_conn_config_match((struct Curl_easy *)curl, conn,
|
|
FALSE),
|
|
"different key_passwd must not reuse conn");
|
|
primary->key_passwd = saved;
|
|
|
|
/* Different key path must not match. */
|
|
saved = primary->key;
|
|
primary->key = alt_key;
|
|
fail_unless(!Curl_ssl_conn_config_match((struct Curl_easy *)curl, conn,
|
|
FALSE),
|
|
"different key must not reuse conn");
|
|
primary->key = saved;
|
|
|
|
/* Different key type must not match. */
|
|
saved = primary->key_type;
|
|
primary->key_type = alt_ktype;
|
|
fail_unless(!Curl_ssl_conn_config_match((struct Curl_easy *)curl, conn,
|
|
FALSE),
|
|
"different key_type must not reuse conn");
|
|
primary->key_type = saved;
|
|
|
|
/* Different cert type must not match. */
|
|
saved = primary->cert_type;
|
|
primary->cert_type = alt_ctype;
|
|
fail_unless(!Curl_ssl_conn_config_match((struct Curl_easy *)curl, conn,
|
|
FALSE),
|
|
"different cert_type must not reuse conn");
|
|
primary->cert_type = saved;
|
|
|
|
/* All fields restored: must match again. */
|
|
fail_unless(Curl_ssl_conn_config_match((struct Curl_easy *)curl, conn,
|
|
FALSE),
|
|
"restored mTLS config should match");
|
|
|
|
Curl_ssl_conn_config_cleanup(conn);
|
|
curlx_free(conn);
|
|
curl_easy_cleanup(curl);
|
|
curl_global_cleanup();
|
|
#endif /* USE_SSL */
|
|
|
|
UNITTEST_END_SIMPLE
|
|
}
|