2 * Copyright (c) 2014 Samsung Electronics Co., Ltd All Rights Reserved
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
17 * @file test/cyad/policy_collection.cpp
18 * @author Aleksander Zdyb <a.zdyb@samsung.com>
20 * @brief Tests for CynaraAdminPolicies
26 #include <gmock/gmock.h>
27 #include <gtest/gtest.h>
29 #include <cynara-admin-types.h>
30 #include <cynara-policy-types.h>
32 #include <cyad/CynaraAdminPolicies.h>
36 TEST(CynaraAdminPolicies, notSealed) {
37 Cynara::CynaraAdminPolicies policies;
38 ASSERT_THROW(policies.data(), std::logic_error);
41 TEST(CynaraAdminPolicies, sealEmpty) {
42 Cynara::CynaraAdminPolicies policies;
44 ASSERT_EQ(nullptr, policies.data()[0]);
47 TEST(CynaraAdminPolicies, addToSealed) {
48 Cynara::CynaraAdminPolicies policies;
50 ASSERT_THROW(policies.add("", { CYNARA_ADMIN_ALLOW, "" }, { "", "", ""} ), std::logic_error);
53 TEST(CynaraAdminPolicies, addOne) {
54 using ::testing::ElementsAreArray;
56 Cynara::CynaraAdminPolicies policies;
57 policies.add("test-bucket", { CYNARA_ADMIN_ALLOW, "" }, { "client", "user", "privilege"} );
59 ASSERT_NO_THROW(policies.data());
61 cynara_admin_policy policy = { strdup("test-bucket"), strdup("client"), strdup("user"),
62 strdup("privilege"), CYNARA_ADMIN_ALLOW, nullptr };
64 ASSERT_EQ(policy, *policies.data()[0]);
65 ASSERT_EQ(nullptr, policies.data()[1]);
67 Cynara::Helpers::freeAdminPolicyMembers(&policy);