2 * Copyright 2002-2016 The OpenSSL Project Authors. All Rights Reserved.
4 * Licensed under the OpenSSL license (the "License"). You may not use
5 * this file except in compliance with the License. You can obtain a copy
6 * in the file LICENSE in the source distribution or at
7 * https://www.openssl.org/source/license.html
12 #include <openssl/err.h>
13 #include <openssl/ui.h>
14 #include "../apps/apps.h"
17 #include "test_main_custom.h"
19 /* apps/apps.c depend on these */
20 char *default_config_file = NULL;
23 /* Old style PEM password callback */
24 static int test_pem_password_cb(char *buf, int size, int rwflag, void *userdata)
26 OPENSSL_strlcpy(buf, (char *)userdata, (size_t)size);
31 * Test wrapping old style PEM password callback in a UI method through the
32 * use of UI utility functions
36 UI_METHOD *ui_method = NULL;
38 char defpass[] = "password";
43 UI_UTIL_wrap_read_pem_callback(test_pem_password_cb, 0)) == NULL
44 || (ui = UI_new_method(ui_method)) == NULL)
47 /* The wrapper passes the UI userdata as the callback userdata param */
48 UI_add_user_data(ui, defpass);
50 if (!UI_add_input_string(ui, "prompt", UI_INPUT_FLAG_DEFAULT_PWD,
51 pass, 0, sizeof(pass) - 1))
54 switch (UI_process(ui)) {
56 BIO_printf(bio_err, "test_old: UI process interrupted or cancelled\n");
64 if (strcmp(pass, defpass) == 0)
67 BIO_printf(bio_err, "test_old: password failure\n");
71 ERR_print_errors_fp(stderr);
73 UI_destroy_method(ui_method);
78 /* Test of UI. This uses the UI method defined in apps/apps.c */
79 static int test_new_ui()
81 PW_CB_DATA cb_data = {
89 if (password_callback(pass, sizeof(pass), 0, &cb_data) > 0
90 && strcmp(pass, cb_data.password) == 0)
93 BIO_printf(bio_err, "test_new: password failure\n");
96 ERR_print_errors_fp(stderr);
102 int test_main(int argc, char *argv[])
106 bio_err = dup_bio_err(FORMAT_TEXT);
109 ADD_TEST(test_new_ui);
111 ret = run_tests(argv[0]);
113 (void)BIO_flush(bio_err);