aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJack Lloyd <[email protected]>2017-01-06 20:29:22 -0500
committerJack Lloyd <[email protected]>2017-01-06 20:29:22 -0500
commit5d82fa42ca4943c89ee48830e3ad8927f287538d (patch)
tree95ea54437f904aedb5ddd8b0075ce81e439beb9c
parent7b9b0c41137e96eaaea9bf1725d8c6b9341585a7 (diff)
Work around an apparent problem with GCC on AIX
When compiled by GCC 4.8 on AIX 7.1 ppc32, the TLS policy tests fail because the exception thrown from the TLS policy check ends up not being caught at runtime by the test if the catch statement is for `std::exception&` or even `Botan::Exception&` but only if the actually thrown type `Botan::TLS::TLS_Exception` is caught.
-rw-r--r--src/tests/unit_tls_policy.cpp9
1 files changed, 5 insertions, 4 deletions
diff --git a/src/tests/unit_tls_policy.cpp b/src/tests/unit_tls_policy.cpp
index 95290b933..bd8be6e03 100644
--- a/src/tests/unit_tls_policy.cpp
+++ b/src/tests/unit_tls_policy.cpp
@@ -12,6 +12,7 @@
#include <botan/pubkey.h>
#include <botan/oids.h>
#include <botan/tls_policy.h>
+ #include <botan/tls_exceptn.h>
#endif
#if defined(BOTAN_HAS_RSA)
@@ -62,7 +63,7 @@ class TLS_Policy_Unit_Tests : public Test
policy.check_peer_key_acceptable(*rsa_key_1024);
result.test_failure("Incorrectly accepting 1024 bit RSA keys");
}
- catch(std::exception& e)
+ catch(Botan::TLS::TLS_Exception&)
{
result.test_success("Correctly rejecting 1024 bit RSA keys");
}
@@ -87,7 +88,7 @@ class TLS_Policy_Unit_Tests : public Test
policy.check_peer_key_acceptable(*ecdh_192);
result.test_failure("Incorrectly accepting 192 bit EC keys");
}
- catch(std::exception& e)
+ catch(Botan::TLS::TLS_Exception&)
{
result.test_success("Correctly rejecting 192 bit EC keys");
}
@@ -113,7 +114,7 @@ class TLS_Policy_Unit_Tests : public Test
policy.check_peer_key_acceptable(*ecdsa_192);
result.test_failure("Incorrectly accepting 192 bit EC keys");
}
- catch(std::exception& e)
+ catch(Botan::TLS::TLS_Exception&)
{
result.test_success("Correctly rejecting 192 bit EC keys");
}
@@ -142,7 +143,7 @@ class TLS_Policy_Unit_Tests : public Test
policy.check_peer_key_acceptable(*dhkey);
result.test_failure("Incorrectly accepting short bit DH keys");
}
- catch(std::exception& e)
+ catch(Botan::TLS::TLS_Exception&)
{
result.test_success("Correctly rejecting short bit DH keys");
}