Add InsertOrUpdateBucketRequest unit tests 86/234786/5
authorZofia Abramowska <z.abramowska@samsung.com>
Thu, 28 May 2020 16:16:27 +0000 (18:16 +0200)
committerZofia Abramowska <z.abramowska@samsung.com>
Thu, 9 Jul 2020 18:06:21 +0000 (20:06 +0200)
Change-Id: I5c5eae53ee460a12fe0215a08d1fd02434e888eb

test/CMakeLists.txt
test/common/protocols/TestDataCollection.h
test/common/protocols/admin/insertorupdatebucketrequest.cpp [new file with mode: 0644]

index 5d080e7c4425cddc35ba0555a5524e03b65ea173..06ca1a2d404163a1e83be5e262e62e330143eb6b 100644 (file)
@@ -121,6 +121,7 @@ SET(CYNARA_TESTS_SOURCES
     common/protocols/admin/descriptionlistrequest.cpp
     common/protocols/admin/descriptionlistresponse.cpp
     common/protocols/admin/eraserequest.cpp
+    common/protocols/admin/insertorupdatebucketrequest.cpp
     common/protocols/admin/listrequest.cpp
     common/protocols/admin/listresponse.cpp
     common/protocols/monitor/flushrequest.cpp
index 254398bb4d53430d6cea8bdb7c352597ad8820e7..d784bed07ab016e03e0f9d2581a07ec23494ba50 100644 (file)
@@ -61,18 +61,28 @@ namespace Keys {
 } /* namespace Keys */
 
 namespace SN {
-    static const Cynara::ProtocolFrameSequenceNumber min(0);
-    static const Cynara::ProtocolFrameSequenceNumber min_1(min + 1);
-    static const Cynara::ProtocolFrameSequenceNumber min_2(min + 2);
-    static const Cynara::ProtocolFrameSequenceNumber max(UINT16_MAX);
-    static const Cynara::ProtocolFrameSequenceNumber max_1(max - 1);
-    static const Cynara::ProtocolFrameSequenceNumber max_2(max - 2);
-    static const Cynara::ProtocolFrameSequenceNumber mid((min + max) / 2);
+
+const Cynara::ProtocolFrameSequenceNumber min(0);
+const Cynara::ProtocolFrameSequenceNumber min_1(min + 1);
+const Cynara::ProtocolFrameSequenceNumber min_2(min + 2);
+const Cynara::ProtocolFrameSequenceNumber max(UINT16_MAX);
+const Cynara::ProtocolFrameSequenceNumber max_1(max - 1);
+const Cynara::ProtocolFrameSequenceNumber max_2(max - 2);
+const Cynara::ProtocolFrameSequenceNumber mid((min + max) / 2);
+const Cynara::ProtocolFrameSequenceNumber all[] = {
+    min, min_1, min_2, max, max_1, max_2, mid
+};
+
 } /* namespace SN */
 
 namespace Buckets {
-    static const Cynara::PolicyBucketId empty("");
-    static const Cynara::PolicyBucketId not_empty("testBucket_1");
+
+const Cynara::PolicyBucketId empty("");
+const Cynara::PolicyBucketId not_empty("testBucket_1");
+const Cynara::PolicyBucketId all[] = {
+    empty, not_empty
+};
+
 } /* namespace Buckets */
 
 namespace Types {
@@ -84,13 +94,18 @@ namespace Types {
 } /* namespace Types */
 
 namespace Results {
-    static const Cynara::PolicyResult allow(Types::allow, "");
-    static const Cynara::PolicyResult deny(Types::deny, "");
-    static const Cynara::PolicyResult bucket_empty(Types::bucket, Buckets::empty);
-    static const Cynara::PolicyResult bucket_not_empty(Types::bucket, Buckets::not_empty);
-    static const Cynara::PolicyResult none(Types::none, "");
-    static const Cynara::PolicyResult plugin_1(Types::plugin_type, "");
-    static const Cynara::PolicyResult plugin_2(Types::plugin_type, "meta_data_2");
+
+const Cynara::PolicyResult allow(Types::allow, "");
+const Cynara::PolicyResult deny(Types::deny, "");
+const Cynara::PolicyResult bucket_empty(Types::bucket, Buckets::empty);
+const Cynara::PolicyResult bucket_not_empty(Types::bucket, Buckets::not_empty);
+const Cynara::PolicyResult none(Types::none, "");
+const Cynara::PolicyResult plugin_1(Types::plugin_type, "");
+const Cynara::PolicyResult plugin_2(Types::plugin_type, "meta_data_2");
+const Cynara::PolicyResult all[] = {
+    allow, deny, bucket_empty, bucket_not_empty, none, plugin_1, plugin_2
+};
+
 } /* namespace Results */
 } /* namespace TestDataCollection */
 } /* namespace anonymous */
diff --git a/test/common/protocols/admin/insertorupdatebucketrequest.cpp b/test/common/protocols/admin/insertorupdatebucketrequest.cpp
new file mode 100644 (file)
index 0000000..ff9af07
--- /dev/null
@@ -0,0 +1,74 @@
+/*
+ * Copyright (c) 2020 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ *    Licensed under the Apache License, Version 2.0 (the "License");
+ *    you may not use this file except in compliance with the License.
+ *    You may obtain a copy of the License at
+ *
+ *        http://www.apache.org/licenses/LICENSE-2.0
+ *
+ *    Unless required by applicable law or agreed to in writing, software
+ *    distributed under the License is distributed on an "AS IS" BASIS,
+ *    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ *    See the License for the specific language governing permissions and
+ *    limitations under the License.
+ */
+/**
+ * @file        test/common/protocols/admin/insertorupdatebucketrequest.cpp
+ * @author      Zofia Abramowska <z.abramowska@samsung.com>
+ * @version     1.0
+ * @brief       Tests for Cynara::InsertOrUpdateBucketRequest usage in Cynara::ProtocolAdmin
+ */
+
+#include <gtest/gtest.h>
+
+#include <protocol/ProtocolAdmin.h>
+#include <request/InsertOrUpdateBucketRequest.h>
+
+#include <RequestTestHelper.h>
+#include <TestDataCollection.h>
+
+namespace {
+
+template<>
+void compare(const Cynara::InsertOrUpdateBucketRequest &req1,
+             const Cynara::InsertOrUpdateBucketRequest &req2)
+{
+    EXPECT_EQ(req1.bucketId(), req2.bucketId());
+    EXPECT_EQ(req1.result(), req2.result());
+    EXPECT_EQ(req1.sequenceNumber(), req2.sequenceNumber());
+}
+
+} /* namespace anonymous */
+
+using namespace Cynara;
+using namespace RequestTestHelper;
+using namespace TestDataCollection;
+
+/* *** compare by objects test cases *** */
+
+TEST(ProtocolAdmin, InsertOrUpdateBucketRequestPositive) {
+    for (auto &bucket : Buckets::all) {
+        for (auto &result : Results::all) {
+            for (auto &sequenceNumber : SN::all) {
+                auto request = std::make_shared<InsertOrUpdateBucketRequest>(
+                    bucket, result, sequenceNumber);
+                auto protocol = std::make_shared<ProtocolAdmin>();
+                testRequest(request, protocol);
+            }
+        }
+    }
+}
+
+TEST(ProtocolAdmin, InsertOrUpdateBucketRequestBinaryPositive) {
+    for (auto &bucket : Buckets::all) {
+        for (auto &result : Results::all) {
+            for (auto &sequenceNumber : SN::all) {
+                auto request = std::make_shared<InsertOrUpdateBucketRequest>(
+                    bucket, result, sequenceNumber);
+                auto protocol = std::make_shared<ProtocolAdmin>();
+                binaryTestRequest(request, protocol);
+            }
+        }
+    }
+}