From 9350ee13a27d9ab6dda700175adf64066d814582 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?G=C3=BCnter=20Obiltschnig?= Date: Thu, 23 Jan 2020 09:38:25 +0100 Subject: [PATCH] fixed memory leak in testsuite --- Crypto/testsuite/src/EVPTest.cpp | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/Crypto/testsuite/src/EVPTest.cpp b/Crypto/testsuite/src/EVPTest.cpp index f53ec81b1..f5921b35c 100644 --- a/Crypto/testsuite/src/EVPTest.cpp +++ b/Crypto/testsuite/src/EVPTest.cpp @@ -16,6 +16,7 @@ #include "Poco/StreamCopier.h" #include "CppUnit/TestCaller.h" #include "CppUnit/TestSuite.h" +#include #include #include #include @@ -41,12 +42,12 @@ void EVPTest::testRSAEVPPKey() { try { - RSAKey* key = new RSAKey(RSAKey::KL_1024, RSAKey::EXP_SMALL); + std::unique_ptr key(new RSAKey(RSAKey::KL_1024, RSAKey::EXP_SMALL)); assertTrue(key->type() == Poco::Crypto::KeyPair::KT_RSA); // construct EVPPKey from RSAKey* - EVPPKey* pKey = new EVPPKey(key); + EVPPKey* pKey = new EVPPKey(key.get()); // EVPPKey increments reference count, so freeing the original must be ok - delete key; + key.reset(); assertTrue (!pKey->isSupported(0)); assertTrue (!pKey->isSupported(-1)); @@ -54,11 +55,11 @@ void EVPTest::testRSAEVPPKey() assertTrue (pKey->type() == EVP_PKEY_RSA); // construct RSAKey from const EVPPKey& - key = new RSAKey(*pKey); + key.reset(new RSAKey(*pKey)); delete pKey; assertTrue(key->type() == Poco::Crypto::KeyPair::KT_RSA); // construct EVPPKey from RSAKey* - pKey = new EVPPKey(key); + pKey = new EVPPKey(key.get()); assertTrue (pKey->type() == EVP_PKEY_RSA); BIO* bioPriv1 = BIO_new(BIO_s_mem());