]> git.proxmox.com Git - ceph.git/blame - ceph/src/test/librbd/managed_lock/test_mock_GetLockerRequest.cc
update sources to v12.2.1
[ceph.git] / ceph / src / test / librbd / managed_lock / test_mock_GetLockerRequest.cc
CommitLineData
7c673cae
FG
1// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
2// vim: ts=8 sw=2 smarttab
3
4#include "test/librbd/test_mock_fixture.h"
5#include "test/librbd/test_support.h"
6#include "test/librbd/mock/MockImageCtx.h"
7#include "test/librados_test_stub/MockTestMemIoCtxImpl.h"
8#include "test/librados_test_stub/MockTestMemRadosClient.h"
9#include "cls/lock/cls_lock_ops.h"
10#include "librbd/managed_lock/GetLockerRequest.h"
11#include "librbd/managed_lock/Types.h"
12#include "librbd/managed_lock/Utils.h"
13#include "gmock/gmock.h"
14#include "gtest/gtest.h"
15#include <arpa/inet.h>
16#include <list>
17
18namespace librbd {
19namespace {
20
21struct MockTestImageCtx : public librbd::MockImageCtx {
22 MockTestImageCtx(librbd::ImageCtx &image_ctx)
23 : librbd::MockImageCtx(image_ctx) {
24 }
25};
26
27} // anonymous namespace
28} // namespace librbd
29
30// template definitions
31#include "librbd/managed_lock/GetLockerRequest.cc"
32
33namespace librbd {
34namespace managed_lock {
35
36using ::testing::_;
37using ::testing::DoAll;
38using ::testing::InSequence;
39using ::testing::Return;
40using ::testing::StrEq;
41using ::testing::WithArg;
42
43class TestMockManagedLockGetLockerRequest : public TestMockFixture {
44public:
45 typedef GetLockerRequest<MockTestImageCtx> MockGetLockerRequest;
46
47 void expect_get_lock_info(MockTestImageCtx &mock_image_ctx, int r,
48 const entity_name_t &locker_entity,
49 const std::string &locker_address,
50 const std::string &locker_cookie,
51 const std::string &lock_tag,
52 ClsLockType lock_type) {
53 auto &expect = EXPECT_CALL(get_mock_io_ctx(mock_image_ctx.md_ctx),
54 exec(mock_image_ctx.header_oid, _, StrEq("lock"),
55 StrEq("get_info"), _, _, _));
56 if (r < 0 && r != -ENOENT) {
57 expect.WillOnce(Return(r));
58 } else {
59 entity_name_t entity(locker_entity);
60 entity_addr_t entity_addr;
61 entity_addr.parse(locker_address.c_str(), NULL);
62
63 cls_lock_get_info_reply reply;
64 if (r != -ENOENT) {
65 reply.lockers = decltype(reply.lockers){
66 {rados::cls::lock::locker_id_t(entity, locker_cookie),
67 rados::cls::lock::locker_info_t(utime_t(), entity_addr, "")}};
68 reply.tag = lock_tag;
69 reply.lock_type = lock_type;
70 }
71
72 bufferlist bl;
73 ::encode(reply, bl, CEPH_FEATURES_SUPPORTED_DEFAULT);
74
75 std::string str(bl.c_str(), bl.length());
76 expect.WillOnce(DoAll(WithArg<5>(CopyInBufferlist(str)), Return(0)));
77 }
78 }
79};
80
81TEST_F(TestMockManagedLockGetLockerRequest, SuccessExclusive) {
82 REQUIRE_FEATURE(RBD_FEATURE_EXCLUSIVE_LOCK);
83
84 librbd::ImageCtx *ictx;
85 ASSERT_EQ(0, open_image(m_image_name, &ictx));
86
87 MockTestImageCtx mock_image_ctx(*ictx);
88 expect_op_work_queue(mock_image_ctx);
89
90 InSequence seq;
91 expect_get_lock_info(mock_image_ctx, 0, entity_name_t::CLIENT(1), "1.2.3.4",
92 "auto 123", util::get_watcher_lock_tag(),
93 LOCK_EXCLUSIVE);
94
95 C_SaferCond ctx;
96 Locker locker;
97 MockGetLockerRequest *req = MockGetLockerRequest::create(
98 mock_image_ctx.md_ctx, mock_image_ctx.header_oid, true, &locker, &ctx);
99 req->send();
100 ASSERT_EQ(0, ctx.wait());
101
102 ASSERT_EQ(entity_name_t::CLIENT(1), locker.entity);
103 ASSERT_EQ("1.2.3.4:0/0", locker.address);
104 ASSERT_EQ("auto 123", locker.cookie);
105 ASSERT_EQ(123U, locker.handle);
106}
107
108TEST_F(TestMockManagedLockGetLockerRequest, SuccessShared) {
109 REQUIRE_FEATURE(RBD_FEATURE_EXCLUSIVE_LOCK);
110
111 librbd::ImageCtx *ictx;
112 ASSERT_EQ(0, open_image(m_image_name, &ictx));
113
114 MockTestImageCtx mock_image_ctx(*ictx);
115 expect_op_work_queue(mock_image_ctx);
116
117 InSequence seq;
118 expect_get_lock_info(mock_image_ctx, 0, entity_name_t::CLIENT(1), "1.2.3.4",
119 "auto 123", util::get_watcher_lock_tag(),
120 LOCK_SHARED);
121
122 C_SaferCond ctx;
123 Locker locker;
124 MockGetLockerRequest *req = MockGetLockerRequest::create(
125 mock_image_ctx.md_ctx, mock_image_ctx.header_oid, false, &locker, &ctx);
126 req->send();
127 ASSERT_EQ(0, ctx.wait());
128
129 ASSERT_EQ(entity_name_t::CLIENT(1), locker.entity);
130 ASSERT_EQ("1.2.3.4:0/0", locker.address);
131 ASSERT_EQ("auto 123", locker.cookie);
132 ASSERT_EQ(123U, locker.handle);
133}
134
135TEST_F(TestMockManagedLockGetLockerRequest, GetLockInfoError) {
136 REQUIRE_FEATURE(RBD_FEATURE_EXCLUSIVE_LOCK);
137
138 librbd::ImageCtx *ictx;
139 ASSERT_EQ(0, open_image(m_image_name, &ictx));
140
141 MockTestImageCtx mock_image_ctx(*ictx);
142 expect_op_work_queue(mock_image_ctx);
143
144 InSequence seq;
145 expect_get_lock_info(mock_image_ctx, -EINVAL, entity_name_t::CLIENT(1), "",
146 "", "", LOCK_EXCLUSIVE);
147
148 C_SaferCond ctx;
149 Locker locker;
150 MockGetLockerRequest *req = MockGetLockerRequest::create(
151 mock_image_ctx.md_ctx, mock_image_ctx.header_oid, true, &locker, &ctx);
152 req->send();
153 ASSERT_EQ(-EINVAL, ctx.wait());
154}
155
156TEST_F(TestMockManagedLockGetLockerRequest, GetLockInfoEmpty) {
157 REQUIRE_FEATURE(RBD_FEATURE_EXCLUSIVE_LOCK);
158
159 librbd::ImageCtx *ictx;
160 ASSERT_EQ(0, open_image(m_image_name, &ictx));
161
162 MockTestImageCtx mock_image_ctx(*ictx);
163 expect_op_work_queue(mock_image_ctx);
164
165 InSequence seq;
166 expect_get_lock_info(mock_image_ctx, -ENOENT, entity_name_t::CLIENT(1), "",
167 "", "", LOCK_EXCLUSIVE);
168
169 C_SaferCond ctx;
170 Locker locker;
171 MockGetLockerRequest *req = MockGetLockerRequest::create(
172 mock_image_ctx.md_ctx, mock_image_ctx.header_oid, true, &locker, &ctx);
173 req->send();
174 ASSERT_EQ(-ENOENT, ctx.wait());
175}
176
177TEST_F(TestMockManagedLockGetLockerRequest, GetLockInfoExternalTag) {
178 REQUIRE_FEATURE(RBD_FEATURE_EXCLUSIVE_LOCK);
179
180 librbd::ImageCtx *ictx;
181 ASSERT_EQ(0, open_image(m_image_name, &ictx));
182
183 MockTestImageCtx mock_image_ctx(*ictx);
184 expect_op_work_queue(mock_image_ctx);
185
186 InSequence seq;
187 expect_get_lock_info(mock_image_ctx, 0, entity_name_t::CLIENT(1), "1.2.3.4",
188 "auto 123", "external tag", LOCK_EXCLUSIVE);
189
190 C_SaferCond ctx;
191 Locker locker;
192 MockGetLockerRequest *req = MockGetLockerRequest::create(
193 mock_image_ctx.md_ctx, mock_image_ctx.header_oid, true, &locker, &ctx);
194 req->send();
195 ASSERT_EQ(-EBUSY, ctx.wait());
196}
197
198TEST_F(TestMockManagedLockGetLockerRequest, GetLockInfoIncompatibleShared) {
199 REQUIRE_FEATURE(RBD_FEATURE_EXCLUSIVE_LOCK);
200
201 librbd::ImageCtx *ictx;
202 ASSERT_EQ(0, open_image(m_image_name, &ictx));
203
204 MockTestImageCtx mock_image_ctx(*ictx);
205 expect_op_work_queue(mock_image_ctx);
206
207 InSequence seq;
208 expect_get_lock_info(mock_image_ctx, 0, entity_name_t::CLIENT(1), "1.2.3.4",
209 "auto 123", util::get_watcher_lock_tag(),
210 LOCK_SHARED);
211
212 C_SaferCond ctx;
213 Locker locker;
214 MockGetLockerRequest *req = MockGetLockerRequest::create(
215 mock_image_ctx.md_ctx, mock_image_ctx.header_oid, true, &locker, &ctx);
216 req->send();
217 ASSERT_EQ(-EBUSY, ctx.wait());
218}
219
220TEST_F(TestMockManagedLockGetLockerRequest, GetLockInfoIncompatibleExclusive) {
221 REQUIRE_FEATURE(RBD_FEATURE_EXCLUSIVE_LOCK);
222
223 librbd::ImageCtx *ictx;
224 ASSERT_EQ(0, open_image(m_image_name, &ictx));
225
226 MockTestImageCtx mock_image_ctx(*ictx);
227 expect_op_work_queue(mock_image_ctx);
228
229 InSequence seq;
230 expect_get_lock_info(mock_image_ctx, 0, entity_name_t::CLIENT(1), "1.2.3.4",
231 "auto 123", util::get_watcher_lock_tag(),
232 LOCK_EXCLUSIVE);
233
234 C_SaferCond ctx;
235 Locker locker;
236 MockGetLockerRequest *req = MockGetLockerRequest::create(
237 mock_image_ctx.md_ctx, mock_image_ctx.header_oid, false, &locker, &ctx);
238 req->send();
239 ASSERT_EQ(-EBUSY, ctx.wait());
240}
241
242TEST_F(TestMockManagedLockGetLockerRequest, GetLockInfoExternalCookie) {
243 REQUIRE_FEATURE(RBD_FEATURE_EXCLUSIVE_LOCK);
244
245 librbd::ImageCtx *ictx;
246 ASSERT_EQ(0, open_image(m_image_name, &ictx));
247
248 MockTestImageCtx mock_image_ctx(*ictx);
249 expect_op_work_queue(mock_image_ctx);
250
251 InSequence seq;
252 expect_get_lock_info(mock_image_ctx, 0, entity_name_t::CLIENT(1), "1.2.3.4",
253 "external cookie", util::get_watcher_lock_tag(),
254 LOCK_EXCLUSIVE);
255
256 C_SaferCond ctx;
257 Locker locker;
258 MockGetLockerRequest *req = MockGetLockerRequest::create(
259 mock_image_ctx.md_ctx, mock_image_ctx.header_oid, true, &locker, &ctx);
260 req->send();
261 ASSERT_EQ(-EBUSY, ctx.wait());
262}
263
264} // namespace managed_lock
265} // namespace librbd