]>
git.proxmox.com Git - ceph.git/blob - ceph/src/test/objectstore/test_memstore_clone.cc
1 // -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
2 // vim: ts=8 sw=2 smarttab
4 * Ceph - scalable distributed file system
6 * Copyright (C) 2015 Red Hat
8 * This is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU Lesser General Public
10 * License version 2.1, as published by the Free Software
11 * Foundation. See file COPYING.
14 #include <boost/intrusive_ptr.hpp>
15 #include "global/global_init.h"
16 #include "common/ceph_argparse.h"
17 #include "os/ObjectStore.h"
18 #include <gtest/gtest.h>
19 #include "include/assert.h"
20 #include "common/errno.h"
21 #include "store_test_fixture.h"
23 #define dout_context g_ceph_context
29 ghobject_t
make_ghobject(const char *oid
)
31 return ghobject_t
{hobject_t
{oid
, "", CEPH_NOSNAP
, 0, 0, ""}};
34 } // anonymous namespace
36 class MemStoreClone
: public StoreTestFixture
{
39 : StoreTestFixture("memstore")
41 void SetUp() override
{
42 StoreTestFixture::SetUp();
46 ObjectStore::Transaction t
;
47 t
.create_collection(cid
, 4);
48 unsigned r
= store
->apply_transaction(nullptr, std::move(t
));
50 derr
<< "failed to create collection with " << cpp_strerror(r
) << dendl
;
56 // src 11[11 11 11 11]11
57 // dst 22 22 22 22 22 22
58 // res 22 11 11 11 11 22
59 TEST_F(MemStoreClone
, CloneRangeAllocated
)
63 const auto src
= make_ghobject("src1");
64 const auto dst
= make_ghobject("dst1");
66 bufferlist srcbl
, dstbl
, result
, expected
;
67 srcbl
.append("111111111111");
68 dstbl
.append("222222222222");
69 expected
.append("221111111122");
71 ObjectStore::Transaction t
;
72 t
.write(cid
, src
, 0, 12, srcbl
);
73 t
.write(cid
, dst
, 0, 12, dstbl
);
74 t
.clone_range(cid
, src
, dst
, 2, 8, 2);
75 ASSERT_EQ(0u, store
->apply_transaction(nullptr, std::move(t
)));
76 ASSERT_EQ(12, store
->read(cid
, dst
, 0, 12, result
));
77 ASSERT_EQ(expected
, result
);
80 // src __[__ __ __ __]__ 11 11
81 // dst 22 22 22 22 22 22
82 // res 22 00 00 00 00 22
83 TEST_F(MemStoreClone
, CloneRangeHole
)
87 const auto src
= make_ghobject("src2");
88 const auto dst
= make_ghobject("dst2");
90 bufferlist srcbl
, dstbl
, result
, expected
;
92 dstbl
.append("222222222222");
93 expected
.append("22\000\000\000\000\000\000\000\00022", 12);
95 ObjectStore::Transaction t
;
96 t
.write(cid
, src
, 12, 4, srcbl
);
97 t
.write(cid
, dst
, 0, 12, dstbl
);
98 t
.clone_range(cid
, src
, dst
, 2, 8, 2);
99 ASSERT_EQ(0u, store
->apply_transaction(nullptr, std::move(t
)));
100 ASSERT_EQ(12, store
->read(cid
, dst
, 0, 12, result
));
101 ASSERT_EQ(expected
, result
);
104 // src __[__ __ __ 11]11
105 // dst 22 22 22 22 22 22
106 // res 22 00 00 00 11 22
107 TEST_F(MemStoreClone
, CloneRangeHoleStart
)
111 const auto src
= make_ghobject("src3");
112 const auto dst
= make_ghobject("dst3");
114 bufferlist srcbl
, dstbl
, result
, expected
;
115 srcbl
.append("1111");
116 dstbl
.append("222222222222");
117 expected
.append("22\000\000\000\000\000\0001122", 12);
119 ObjectStore::Transaction t
;
120 t
.write(cid
, src
, 8, 4, srcbl
);
121 t
.write(cid
, dst
, 0, 12, dstbl
);
122 t
.clone_range(cid
, src
, dst
, 2, 8, 2);
123 ASSERT_EQ(0u, store
->apply_transaction(nullptr, std::move(t
)));
124 ASSERT_EQ(12, store
->read(cid
, dst
, 0, 12, result
));
125 ASSERT_EQ(expected
, result
);
128 // src 11[11 __ __ 11]11
129 // dst 22 22 22 22 22 22
130 // res 22 11 00 00 11 22
131 TEST_F(MemStoreClone
, CloneRangeHoleMiddle
)
135 const auto src
= make_ghobject("src4");
136 const auto dst
= make_ghobject("dst4");
138 bufferlist srcbl
, dstbl
, result
, expected
;
139 srcbl
.append("1111");
140 dstbl
.append("222222222222");
141 expected
.append("2211\000\000\000\0001122", 12);
143 ObjectStore::Transaction t
;
144 t
.write(cid
, src
, 0, 4, srcbl
);
145 t
.write(cid
, src
, 8, 4, srcbl
);
146 t
.write(cid
, dst
, 0, 12, dstbl
);
147 t
.clone_range(cid
, src
, dst
, 2, 8, 2);
148 ASSERT_EQ(0u, store
->apply_transaction(nullptr, std::move(t
)));
149 ASSERT_EQ(12, store
->read(cid
, dst
, 0, 12, result
));
150 ASSERT_EQ(expected
, result
);
153 // src 11[11 __ __ __]__ 11 11
154 // dst 22 22 22 22 22 22
155 // res 22 11 00 00 00 22
156 TEST_F(MemStoreClone
, CloneRangeHoleEnd
)
160 const auto src
= make_ghobject("src5");
161 const auto dst
= make_ghobject("dst5");
163 bufferlist srcbl
, dstbl
, result
, expected
;
164 srcbl
.append("1111");
165 dstbl
.append("222222222222");
166 expected
.append("2211\000\000\000\000\000\00022", 12);
168 ObjectStore::Transaction t
;
169 t
.write(cid
, src
, 0, 4, srcbl
);
170 t
.write(cid
, src
, 12, 4, srcbl
);
171 t
.write(cid
, dst
, 0, 12, dstbl
);
172 t
.clone_range(cid
, src
, dst
, 2, 8, 2);
173 ASSERT_EQ(0u, store
->apply_transaction(nullptr, std::move(t
)));
174 ASSERT_EQ(12, store
->read(cid
, dst
, 0, 12, result
));
175 ASSERT_EQ(expected
, result
);
178 int main(int argc
, char** argv
)
180 // default to memstore
181 vector
<const char*> defaults
{
182 "--osd_objectstore", "memstore",
183 "--osd_data", "msc.test_temp_dir",
184 "--memstore_page_size", "4",
187 vector
<const char*> args
;
188 argv_to_vec(argc
, (const char **)argv
, args
);
190 auto cct
= global_init(&defaults
, args
, CEPH_ENTITY_TYPE_CLIENT
,
191 CODE_ENVIRONMENT_UTILITY
, 0);
192 common_init_finish(g_ceph_context
);
194 ::testing::InitGoogleTest(&argc
, argv
);
195 return RUN_ALL_TESTS();