|
|
28bab8 |
From 71b1c4b5322051320574f4de113e139e8aeb4b89 Mon Sep 17 00:00:00 2001
|
|
|
28bab8 |
From: Jakub Filak <jfilak@redhat.com>
|
|
|
28bab8 |
Date: Tue, 4 Nov 2014 15:29:06 +0100
|
|
|
28bab8 |
Subject: [LIBREPORT PATCH 117/118] testsuite: do not expected ureport exiting
|
|
|
28bab8 |
on rhsm cert errors
|
|
|
28bab8 |
|
|
|
28bab8 |
Related #1140224
|
|
|
28bab8 |
|
|
|
28bab8 |
Signed-off-by: Jakub Filak <jfilak@redhat.com>
|
|
|
28bab8 |
---
|
|
|
28bab8 |
tests/Makefile.am | 2 +-
|
|
|
28bab8 |
tests/ureport.at | 66 +++++++++++++++++++++++++++++++++++++++++--------------
|
|
|
28bab8 |
2 files changed, 51 insertions(+), 17 deletions(-)
|
|
|
28bab8 |
|
|
|
28bab8 |
diff --git a/tests/Makefile.am b/tests/Makefile.am
|
|
|
28bab8 |
index cda9375..1cfc206 100644
|
|
|
28bab8 |
--- a/tests/Makefile.am
|
|
|
28bab8 |
+++ b/tests/Makefile.am
|
|
|
28bab8 |
@@ -49,7 +49,7 @@ TESTSUITE = $(srcdir)/testsuite
|
|
|
28bab8 |
MAINTAINERCLEANFILES = Makefile.in $(TESTSUITE)
|
|
|
28bab8 |
check_DATA = atconfig atlocal $(TESTSUITE)
|
|
|
28bab8 |
DISTCLEANFILES = atconfig
|
|
|
28bab8 |
-EXTRA_DIST += atlocal.in conf
|
|
|
28bab8 |
+EXTRA_DIST += atlocal.in conf ureport
|
|
|
28bab8 |
|
|
|
28bab8 |
atconfig: $(top_builddir)/config.status
|
|
|
28bab8 |
(cd ${top_builddir} && ./config.status ${subdir}/atconfig)
|
|
|
28bab8 |
diff --git a/tests/ureport.at b/tests/ureport.at
|
|
|
28bab8 |
index 22d34e9..76e2f7a 100644
|
|
|
28bab8 |
--- a/tests/ureport.at
|
|
|
28bab8 |
+++ b/tests/ureport.at
|
|
|
28bab8 |
@@ -339,12 +339,24 @@ void set_ureport_server_config(struct ureport_server_config *config,
|
|
|
28bab8 |
|
|
|
28bab8 |
void my_assert(const char *str1, const char *str2)
|
|
|
28bab8 |
{
|
|
|
28bab8 |
- if (str1 == NULL || str2 == NULL)
|
|
|
28bab8 |
- assert( str1 == NULL && str2 == NULL );
|
|
|
28bab8 |
- else
|
|
|
28bab8 |
- assert(strcmp(str1, str2) == 0);
|
|
|
28bab8 |
+ if (str1 == str2)
|
|
|
28bab8 |
+ return;
|
|
|
28bab8 |
|
|
|
28bab8 |
- return;
|
|
|
28bab8 |
+ if (str1 == NULL && str2 != NULL)
|
|
|
28bab8 |
+ {
|
|
|
28bab8 |
+ fprintf(stderr, "Assertion failed: NULL == '%s'\n", str2);
|
|
|
28bab8 |
+ abort();
|
|
|
28bab8 |
+ }
|
|
|
28bab8 |
+ else if (str1 != NULL && str2 == NULL)
|
|
|
28bab8 |
+ {
|
|
|
28bab8 |
+ fprintf(stderr, "Assertion failed: '%s' == NULL\n", str1);
|
|
|
28bab8 |
+ abort();
|
|
|
28bab8 |
+ }
|
|
|
28bab8 |
+ else if (strcmp(str1, str2) != 0)
|
|
|
28bab8 |
+ {
|
|
|
28bab8 |
+ fprintf(stderr, "Assertion failed: '%s' == '%s'\n", str1, str2);
|
|
|
28bab8 |
+ abort();
|
|
|
28bab8 |
+ }
|
|
|
28bab8 |
}
|
|
|
28bab8 |
|
|
|
28bab8 |
void assert_ureport_server_config(struct ureport_server_config *config,
|
|
|
28bab8 |
@@ -365,8 +377,10 @@ void assert_ureport_server_config(struct ureport_server_config *config,
|
|
|
28bab8 |
return;
|
|
|
28bab8 |
}
|
|
|
28bab8 |
|
|
|
28bab8 |
-int test_ureport_server_config_set_client_auth_exit_code(struct ureport_server_config *config,
|
|
|
28bab8 |
- const char *client_auth)
|
|
|
28bab8 |
+int test_ureport_server_config_set_client_auth_exit_code_ext(struct ureport_server_config *config,
|
|
|
28bab8 |
+ const char *client_auth,
|
|
|
28bab8 |
+ const char *cert_file,
|
|
|
28bab8 |
+ const char *key_file)
|
|
|
28bab8 |
{
|
|
|
28bab8 |
ureport_server_config_init(config);
|
|
|
28bab8 |
|
|
|
28bab8 |
@@ -380,6 +394,8 @@ int test_ureport_server_config_set_client_auth_exit_code(struct ureport_server_c
|
|
|
28bab8 |
if (pid == 0)
|
|
|
28bab8 |
{
|
|
|
28bab8 |
ureport_server_config_set_client_auth(config, client_auth);
|
|
|
28bab8 |
+ assert((cert_file == (void *)-1) || (cert_file == NULL && config->ur_client_cert == NULL) || (strcmp(cert_file, config->ur_client_cert) == 0));
|
|
|
28bab8 |
+ assert((key_file == (void *)-1) || (key_file == NULL && config->ur_client_cert == NULL) || (strcmp(key_file, config->ur_client_key) == 0));
|
|
|
28bab8 |
exit(0);
|
|
|
28bab8 |
}
|
|
|
28bab8 |
int status;
|
|
|
28bab8 |
@@ -390,6 +406,12 @@ int test_ureport_server_config_set_client_auth_exit_code(struct ureport_server_c
|
|
|
28bab8 |
return status;
|
|
|
28bab8 |
}
|
|
|
28bab8 |
|
|
|
28bab8 |
+int test_ureport_server_config_set_client_auth_exit_code(struct ureport_server_config *config,
|
|
|
28bab8 |
+ const char *client_auth)
|
|
|
28bab8 |
+{
|
|
|
28bab8 |
+ return test_ureport_server_config_set_client_auth_exit_code_ext(config, client_auth, (void *)-1, (void *)-1);
|
|
|
28bab8 |
+}
|
|
|
28bab8 |
+
|
|
|
28bab8 |
int main(void)
|
|
|
28bab8 |
{
|
|
|
28bab8 |
g_verbose=3;
|
|
|
28bab8 |
@@ -418,8 +440,8 @@ int main(void)
|
|
|
28bab8 |
assert(empty_cert_dir);
|
|
|
28bab8 |
setenv("LIBREPORT_DEBUG_RHSMENT_PEM_DIR_PATH", empty_cert_dir, 1);
|
|
|
28bab8 |
|
|
|
28bab8 |
- int status = test_ureport_server_config_set_client_auth_exit_code(&config, "rhsm");
|
|
|
28bab8 |
- assert(status != 0 && status != -1);
|
|
|
28bab8 |
+ int status = test_ureport_server_config_set_client_auth_exit_code_ext(&config, "rhsm", NULL, NULL);
|
|
|
28bab8 |
+ assert(status == 0);
|
|
|
28bab8 |
|
|
|
28bab8 |
assert(rmdir(empty_cert_dir) == 0);
|
|
|
28bab8 |
|
|
|
28bab8 |
@@ -429,8 +451,8 @@ int main(void)
|
|
|
28bab8 |
|
|
|
28bab8 |
setenv("LIBREPORT_DEBUG_RHSMENT_PEM_DIR_PATH", TESTING_CERTS_INCORRECT_CONTENT_DIR_PATH, 1);
|
|
|
28bab8 |
|
|
|
28bab8 |
- status = test_ureport_server_config_set_client_auth_exit_code(&config, "rhsm");
|
|
|
28bab8 |
- assert(status != 0 && status != -1);
|
|
|
28bab8 |
+ status = test_ureport_server_config_set_client_auth_exit_code_ext(&config, "rhsm", NULL, NULL);
|
|
|
28bab8 |
+ assert(status == 0);
|
|
|
28bab8 |
|
|
|
28bab8 |
/* client_auth == rhsm */
|
|
|
28bab8 |
/* ur_url == NULL */
|
|
|
28bab8 |
@@ -548,12 +570,24 @@ AT_TESTFUN([ureport_server_config_set_basic_auth],
|
|
|
28bab8 |
|
|
|
28bab8 |
void my_assert(const char *str1, const char *str2)
|
|
|
28bab8 |
{
|
|
|
28bab8 |
- if (str1 == NULL || str2 == NULL)
|
|
|
28bab8 |
- assert( str1 == NULL && str2 == NULL );
|
|
|
28bab8 |
- else
|
|
|
28bab8 |
- assert(strcmp(str1, str2) == 0);
|
|
|
28bab8 |
+ if (str1 == str2)
|
|
|
28bab8 |
+ return;
|
|
|
28bab8 |
|
|
|
28bab8 |
- return;
|
|
|
28bab8 |
+ if (str1 == NULL && str2 != NULL)
|
|
|
28bab8 |
+ {
|
|
|
28bab8 |
+ fprintf(stderr, "Assertion failed: NULL == '%s'\n", str2);
|
|
|
28bab8 |
+ abort();
|
|
|
28bab8 |
+ }
|
|
|
28bab8 |
+ else if (str1 != NULL && str2 == NULL)
|
|
|
28bab8 |
+ {
|
|
|
28bab8 |
+ fprintf(stderr, "Assertion failed: '%s' == NULL\n", str1);
|
|
|
28bab8 |
+ abort();
|
|
|
28bab8 |
+ }
|
|
|
28bab8 |
+ else if (strcmp(str1, str2) != 0)
|
|
|
28bab8 |
+ {
|
|
|
28bab8 |
+ fprintf(stderr, "Assertion failed: '%s' == '%s'\n", str1, str2);
|
|
|
28bab8 |
+ abort();
|
|
|
28bab8 |
+ }
|
|
|
28bab8 |
}
|
|
|
28bab8 |
|
|
|
28bab8 |
void assert_ureport_server_config(struct ureport_server_config *config,
|
|
|
28bab8 |
--
|
|
|
28bab8 |
1.8.3.1
|
|
|
28bab8 |
|