summaryrefslogtreecommitdiff
path: root/test/benchmark_tests/security_tests/bm_check_credentials.cpp
blob: 756cd5f449773833baea2bedbbc7298bc5260b09 (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
94
95
96
97
98
99
100
101
102
103
104
105
106
// Copyright (C) 2022 Bayerische Motoren Werke Aktiengesellschaft (BMW AG)
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.

#include <benchmark/benchmark.h>

#include "../../common/utility.hpp"

namespace {
    vsomeip_v3::client_t client = 1;
    vsomeip_v3::uid_t invalid_uid = 1;
    vsomeip_v3::uid_t valid_uid = 4004201;
    vsomeip_v3::gid_t invalid_gid = 1;
    vsomeip_v3::gid_t valid_gid = 4004200;
}

static void BM_check_credentials_policies_not_loaded(benchmark::State& state) {
    std::unique_ptr<vsomeip_v3::policy_manager_impl> its_manager(new vsomeip_v3::policy_manager_impl);

    // create security clients
    vsomeip_sec_client_t its_sec_client_invalid = utility::create_uds_client(invalid_uid, invalid_gid);

    for (auto _ : state)
        its_manager->check_credentials(client, &its_sec_client_invalid);
}

static void BM_check_credentials_policies_loaded_invalid_values(benchmark::State& state) {
    std::unique_ptr<vsomeip_v3::policy_manager_impl> its_manager(new vsomeip_v3::policy_manager_impl);

    std::set<std::string> its_failed;
    std::vector<vsomeip_v3::configuration_element> policy_elements;
    std::vector<std::string> dir_skip;
    utility::read_data(utility::get_all_files_in_dir(utility::get_policies_path(), dir_skip), policy_elements, its_failed);
    for (const auto& e : policy_elements) {
        its_manager->load(e, false);
    }

    // create security clients
    vsomeip_sec_client_t its_sec_client_invalid = utility::create_uds_client(invalid_uid, invalid_gid);

    for (auto _ : state)
        its_manager->check_credentials(client, &its_sec_client_invalid);
}

static void BM_check_credentials_policies_loaded_valid_values(benchmark::State& state) {
    std::unique_ptr<vsomeip_v3::policy_manager_impl> its_manager(new vsomeip_v3::policy_manager_impl);

    std::set<std::string> its_failed;
    std::vector<vsomeip_v3::configuration_element> policy_elements;
    std::vector<std::string> dir_skip;
    utility::read_data(utility::get_all_files_in_dir(utility::get_policies_path(), dir_skip), policy_elements, its_failed);
    for (const auto& e : policy_elements) {
        its_manager->load(e, false);
    }

    // create security clients
    vsomeip_sec_client_t its_sec_client_valid = utility::create_uds_client(valid_uid, valid_gid);

    for (auto _ : state)
        its_manager->check_credentials(client, &its_sec_client_valid);
}

static void BM_check_credentials_policies_loaded_audit_mode_invalid_values(benchmark::State& state) {
    std::unique_ptr<vsomeip_v3::policy_manager_impl> its_manager(new vsomeip_v3::policy_manager_impl);

    std::set<std::string> its_failed;
    std::vector<vsomeip_v3::configuration_element> policy_elements;
    std::vector<std::string> dir_skip;
    utility::read_data(utility::get_all_files_in_dir(utility::get_policies_path(), dir_skip), policy_elements, its_failed);
    utility::force_check_credentials(policy_elements, "false");
    for (const auto& e : policy_elements) {
        its_manager->load(e, false);
    }

    // create security clients
    vsomeip_sec_client_t its_sec_client_invalid = utility::create_uds_client(invalid_uid, invalid_gid);

    for (auto _ : state)
        its_manager->check_credentials(client, &its_sec_client_invalid);
}

static void BM_check_credentials_policies_loaded_audit_mode_valid_values(benchmark::State& state) {
    std::unique_ptr<vsomeip_v3::policy_manager_impl> its_manager(new vsomeip_v3::policy_manager_impl);

    std::set<std::string> its_failed;
    std::vector<vsomeip_v3::configuration_element> policy_elements;
    std::vector<std::string> dir_skip;
    utility::read_data(utility::get_all_files_in_dir(utility::get_policies_path(), dir_skip), policy_elements, its_failed);
    utility::force_check_credentials(policy_elements, "false");
    for (const auto& e : policy_elements) {
        its_manager->load(e, false);
    }

    // create security clients
    vsomeip_sec_client_t its_sec_client_valid = utility::create_uds_client(valid_uid, valid_gid);

    for (auto _ : state)
        its_manager->check_credentials(client, &its_sec_client_valid);
}

BENCHMARK(BM_check_credentials_policies_not_loaded);
BENCHMARK(BM_check_credentials_policies_loaded_invalid_values);
BENCHMARK(BM_check_credentials_policies_loaded_valid_values);
BENCHMARK(BM_check_credentials_policies_loaded_audit_mode_invalid_values);
BENCHMARK(BM_check_credentials_policies_loaded_audit_mode_valid_values);