aboutsummaryrefslogtreecommitdiff
path: root/components/service/crypto/test/service/packed-c/crypto_service_packedc_tests.cpp
blob: 5a620b4023527e18dbf6b503939f81f5742773b0 (plain)
1
2
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
/*
 * Copyright (c) 2020-2021, Arm Limited and Contributors. All rights reserved.
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */

#include <service/crypto/client/cpp/packed-c/packedc_crypto_client.h>
#include <service/crypto/test/service/crypto_service_scenarios.h>
#include <protocols/rpc/common/packed-c/encoding.h>
#include <service_locator.h>
#include <CppUTest/TestHarness.h>

/*
 * Service-level tests that use the packed-c access protocol serialization
 */
TEST_GROUP(CryptoServicePackedcTests)
{
    void setup()
    {
        struct rpc_caller *caller;
        int status;

        m_rpc_session_handle = NULL;
        m_crypto_service_context = NULL;
        m_scenarios = NULL;

        service_locator_init();

        m_crypto_service_context = service_locator_query("sn:trustedfirmware.org:crypto:0", &status);
        CHECK_TRUE(m_crypto_service_context);

        m_rpc_session_handle = service_context_open(m_crypto_service_context, TS_RPC_ENCODING_PACKED_C, &caller);
        CHECK_TRUE(m_rpc_session_handle);

        m_scenarios = new crypto_service_scenarios(new packedc_crypto_client(caller));
    }

    void teardown()
    {
        delete m_scenarios;
        m_scenarios = NULL;

        service_context_close(m_crypto_service_context, m_rpc_session_handle);
        m_rpc_session_handle = NULL;

        service_context_relinquish(m_crypto_service_context);
        m_crypto_service_context = NULL;
    }

    rpc_session_handle m_rpc_session_handle;
    struct service_context *m_crypto_service_context;
    crypto_service_scenarios *m_scenarios;
};

TEST(CryptoServicePackedcTests, generateVolatileKeys)
{
    m_scenarios->generateVolatileKeys();
}

TEST(CryptoServicePackedcTests, generatePersistentKeys)
{
    m_scenarios->generatePersistentKeys();
}

TEST(CryptoServicePackedcTests, exportPublicKey)
{
    m_scenarios->exportPublicKey();
}

TEST(CryptoServicePackedcTests, exportAndImportKeyPair)
{
    m_scenarios->exportAndImportKeyPair();
}

TEST(CryptoServicePackedcTests, signAndVerifyHash)
{
    m_scenarios->signAndVerifyHash();
}

TEST(CryptoServicePackedcTests, asymEncryptDecrypt)
{
    m_scenarios->asymEncryptDecrypt();
}

TEST(CryptoServicePackedcTests, asymEncryptDecryptWithSalt)
{
    m_scenarios->asymEncryptDecryptWithSalt();
}

TEST(CryptoServicePackedcTests, generateRandomNumbers)
{
    m_scenarios->generateRandomNumbers();
}