tlstest.cpp 2.89 KB
Newer Older
1
/*
Adrien Béraud's avatar
Adrien Béraud committed
2
 *  Copyright (C) 2004-2015 Savoir-Faire Linux Inc.
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38
 *  Author: Alexandre Lision <alexandre.lision@savoirfairelinux.com>
 *
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 3 of the License, or
 *  (at your option) any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program; if not, write to the Free Software
 *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301 USA.
 *
 *  Additional permission under GNU GPL version 3 section 7:
 *
 *  If you modify this program, or any covered work, by linking or
 *  combining it with the OpenSSL project's OpenSSL library (or a
 *  modified version of that library), containing parts covered by the
 *  terms of the OpenSSL or SSLeay licenses, Savoir-Faire Linux Inc.
 *  grants you additional permission to convey the resulting work.
 *  Corresponding Source for a non-source form of such a combination
 *  shall include the source code for the parts of OpenSSL used as well
 *  as that of the covered work.
 */

#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#include "tlstest.h"
#include "account.h"
#include "test_utils.h"
#include "logger.h"

39
#include "sip/tlsvalidator.h"
40

Guillaume Roguez's avatar
Guillaume Roguez committed
41 42
namespace ring { namespace test {

43 44 45 46
void TlsTest::testKey()
{
    TITLE();

Tristan Matthews's avatar
Tristan Matthews committed
47 48 49
    const char *validKey = WORKSPACE "tlsSample/keyonly.pem";
    const char *validCertWithKey = WORKSPACE "tlsSample/certwithkey.pem";
    const char *corruptedKey = WORKSPACE "tlsSample/corruptedkey.pem";
50 51 52 53 54 55 56 57

    CPPUNIT_ASSERT(containsPrivateKey(validKey) == 0);

    CPPUNIT_ASSERT(containsPrivateKey(validCertWithKey) == 0);

    CPPUNIT_ASSERT(containsPrivateKey(corruptedKey) != 0);
}

58 59 60 61
void TlsTest::testCertificate()
{
    TITLE();

Tristan Matthews's avatar
Tristan Matthews committed
62 63 64 65
    const char *validCa = WORKSPACE "tlsSample/ca.crt";
    const char *validCertificate = WORKSPACE "tlsSample/cert.crt";
    const char *fakeCertificate = WORKSPACE "tlsSample/fake.crt";
    const char *expiredCertificate = WORKSPACE "tlsSample/expired.crt";
66

67 68 69
    CPPUNIT_ASSERT(certificateIsValid(NULL, validCa) == 0);

    CPPUNIT_ASSERT(certificateIsValid(validCa, validCertificate) == 0);
70 71

    // This is a png
72
    CPPUNIT_ASSERT(certificateIsValid(NULL, fakeCertificate) != 0);
73 74 75

    // This would need a CA to be valid
    CPPUNIT_ASSERT(certificateIsValid(NULL, validCertificate) != 0);
76 77 78

    // This is an invalid CA
    CPPUNIT_ASSERT(certificateIsValid(validCertificate, validCertificate) != 0);
79 80 81

    // This certificate is expired
    CPPUNIT_ASSERT(certificateIsValid(NULL, expiredCertificate) != 0);
82
}
83

Guillaume Roguez's avatar
Guillaume Roguez committed
84
}} // namespace ring::test