summaryrefslogtreecommitdiff
path: root/test/benchmark_tests/security_tests/bm_remove_client_to_sec_client_mapping.cpp
diff options
context:
space:
mode:
authorDiogo Pedrosa <48529452+DiogoPedrozza@users.noreply.github.com>2023-03-13 14:09:12 +0000
committerGitHub <noreply@github.com>2023-03-13 14:09:12 +0000
commit1b427801352b5dcfdc2277f6343166c01afe97d6 (patch)
treed4e984dd100f3257ce784c9e30aefb6e60a93ab5 /test/benchmark_tests/security_tests/bm_remove_client_to_sec_client_mapping.cpp
parentfc73f40fa1501dc53210c63cb7c0d7623d106370 (diff)
parent826ebb8d352245a36ecaec32b6af61e7abf4696e (diff)
downloadvSomeIP-1b427801352b5dcfdc2277f6343166c01afe97d6.tar.gz
Merge pull request #416 from COVESA/update_3.3.03.3.0
vsomeip 3.3.0
Diffstat (limited to 'test/benchmark_tests/security_tests/bm_remove_client_to_sec_client_mapping.cpp')
-rw-r--r--test/benchmark_tests/security_tests/bm_remove_client_to_sec_client_mapping.cpp52
1 files changed, 52 insertions, 0 deletions
diff --git a/test/benchmark_tests/security_tests/bm_remove_client_to_sec_client_mapping.cpp b/test/benchmark_tests/security_tests/bm_remove_client_to_sec_client_mapping.cpp
new file mode 100644
index 0000000..9a529eb
--- /dev/null
+++ b/test/benchmark_tests/security_tests/bm_remove_client_to_sec_client_mapping.cpp
@@ -0,0 +1,52 @@
+// 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 = 10;
+vsomeip_v3::uid_t uid = 4003030;
+vsomeip_v3::gid_t gid = 4003032;
+
+std::pair<uint32_t, uint32_t> client_uid_gid{uid, gid};
+}
+
+static void BM_remove_client_to_sec_client_mapping_invalid_values(benchmark::State &state)
+{
+ std::unique_ptr<vsomeip_v3::policy_manager_impl> security(new vsomeip_v3::policy_manager_impl);
+
+ vsomeip_sec_client_t its_sec_client = utility::create_uds_client(uid, gid);
+
+ for (auto _ : state) {
+ security->get_client_to_sec_client_mapping(client, its_sec_client);
+ }
+
+ for (auto _ : state) {
+ security->remove_client_to_sec_client_mapping(client);
+ }
+}
+
+static void BM_remove_client_to_sec_client_mapping_valid_values(benchmark::State &state)
+{
+ std::unique_ptr<vsomeip_v3::policy_manager_impl> security(new vsomeip_v3::policy_manager_impl);
+
+ vsomeip_sec_client_t its_sec_client = utility::create_uds_client(uid, gid);
+
+ security->store_client_to_sec_client_mapping(client, &its_sec_client);
+ security->store_sec_client_to_client_mapping(&its_sec_client, client);
+
+ for (auto _ : state) {
+ security->get_client_to_sec_client_mapping(client, its_sec_client);
+ }
+
+ for (auto _ : state) {
+ security->remove_client_to_sec_client_mapping(client);
+ }
+}
+
+BENCHMARK(BM_remove_client_to_sec_client_mapping_invalid_values);
+BENCHMARK(BM_remove_client_to_sec_client_mapping_valid_values);