mirror of
https://github.com/scylladb/scylladb.git
synced 2026-05-30 03:30:49 +00:00
The database.hh is the central recursive-headers knot -- it has ~50 includes. This patch leaves only 34 (it remains the champion though). Similar thing for database.cc. Both changes help the latter compile ~4% faster :) Signed-off-by: Pavel Emelyanov <xemul@scylladb.com> Message-Id: <20210414183107.30374-1-xemul@scylladb.com>
133 lines
5.0 KiB
C++
133 lines
5.0 KiB
C++
/*
|
|
* Copyright (C) 2020 ScyllaDB
|
|
*/
|
|
|
|
/*
|
|
* This file is part of Scylla.
|
|
*
|
|
* Scylla is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Scylla is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with Scylla. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include <filesystem>
|
|
#include <seastar/testing/test_case.hh>
|
|
#include <seastar/testing/thread_test_case.hh>
|
|
|
|
#include "lister.hh"
|
|
#include "test/lib/tmpdir.hh"
|
|
#include "test/lib/sstable_test_env.hh"
|
|
#include "sstable_test.hh"
|
|
|
|
using namespace sstables;
|
|
namespace fs = std::filesystem;
|
|
|
|
// Must be called from a seastar thread
|
|
static auto copy_sst_to_tmpdir(fs::path tmp_path, test_env& env, sstables::schema_ptr schema_ptr, fs::path src_path, unsigned long gen) {
|
|
auto sst = env.reusable_sst(schema_ptr, src_path.native(), gen).get0();
|
|
auto dst_path = tmp_path / src_path.filename() / format("gen-{}", gen);
|
|
recursive_touch_directory(dst_path.native()).get();
|
|
for (auto p : sst->all_components()) {
|
|
auto src_path = fs::path(sst->filename(p.first));
|
|
copy_file(src_path, dst_path / src_path.filename());
|
|
}
|
|
return env.reusable_sst(schema_ptr, dst_path.native(), gen).get0();
|
|
}
|
|
|
|
SEASTAR_THREAD_TEST_CASE(test_sstable_move) {
|
|
tmpdir tmp;
|
|
auto env = test_env();
|
|
auto stop_env = defer([&env] { env.stop().get(); });
|
|
|
|
int64_t gen = 1;
|
|
auto sst = copy_sst_to_tmpdir(tmp.path(), env, uncompressed_schema(), fs::path(uncompressed_dir()), gen);
|
|
|
|
for (auto i = 0; i < 2; i++) {
|
|
++gen;
|
|
auto cur_dir = sst->get_dir();
|
|
auto new_dir = format("{}/gen-{}", fs::path(cur_dir).parent_path().native(), gen);
|
|
touch_directory(new_dir).get();
|
|
sst->move_to_new_dir(new_dir, gen, true).get();
|
|
// the source directory must be empty now
|
|
remove_file(cur_dir).get();
|
|
}
|
|
|
|
// close the sst and make we can load it from the new directory.
|
|
auto new_dir = sst->get_dir();
|
|
sst->close_files().get();
|
|
sst = env.reusable_sst(uncompressed_schema(), new_dir, gen).get0();
|
|
}
|
|
|
|
// Simulate a crashed create_links.
|
|
// This implementation simulates create_links;
|
|
// ideally, we should have error injection points in create_links
|
|
// to cause it to return mid-way.
|
|
//
|
|
// Returns true when done
|
|
//
|
|
// Must be called from a seastar thread
|
|
static bool partial_create_links(sstable_ptr sst, fs::path dst_path, int64_t gen, int count) {
|
|
auto schema = sst->get_schema();
|
|
auto tmp_toc = sstable::filename(dst_path.native(), schema->ks_name(), schema->cf_name(), sst->get_version(), gen, sstable_format_types::big, component_type::TemporaryTOC);
|
|
link_file(sst->filename(component_type::TOC), tmp_toc).get();
|
|
for (auto& [c, s] : sst->all_components()) {
|
|
if (count-- <= 0) {
|
|
return false;
|
|
}
|
|
auto src = sst->filename(c);
|
|
auto dst = sstable::filename(dst_path.native(), schema->ks_name(), schema->cf_name(), sst->get_version(), gen, sstable_format_types::big, c);
|
|
link_file(src, dst).get();
|
|
}
|
|
if (count-- <= 0) {
|
|
return false;
|
|
}
|
|
auto dst = sstable::filename(dst_path.native(), schema->ks_name(), schema->cf_name(), sst->get_version(), gen, sstable_format_types::big, component_type::TOC);
|
|
remove_file(tmp_toc).get();
|
|
return true;
|
|
}
|
|
|
|
SEASTAR_THREAD_TEST_CASE(test_sstable_move_replay) {
|
|
tmpdir tmp;
|
|
auto env = test_env();
|
|
auto stop_env = defer([&env] { env.stop().get(); });
|
|
|
|
int64_t gen = 1;
|
|
auto sst = copy_sst_to_tmpdir(tmp.path(), env, uncompressed_schema(), fs::path(uncompressed_dir()), gen);
|
|
|
|
bool done;
|
|
int count = 0;
|
|
do {
|
|
++gen;
|
|
auto cur_dir = sst->get_dir();
|
|
auto new_dir = format("{}/gen-{}", fs::path(cur_dir).parent_path().native(), gen);
|
|
touch_directory(new_dir).get();
|
|
done = partial_create_links(sst, fs::path(new_dir), gen, count++);
|
|
sst->move_to_new_dir(new_dir, gen, true).get();
|
|
remove_file(cur_dir).get();
|
|
} while (!done);
|
|
}
|
|
|
|
SEASTAR_THREAD_TEST_CASE(test_sstable_move_exists_failure) {
|
|
tmpdir tmp;
|
|
auto env = test_env();
|
|
auto stop_env = defer([&env] { env.stop().get(); });
|
|
|
|
int64_t gen = 1;
|
|
auto src_sst = copy_sst_to_tmpdir(tmp.path(), env, uncompressed_schema(), fs::path(uncompressed_dir()), gen);
|
|
auto dst_sst = copy_sst_to_tmpdir(tmp.path(), env, uncompressed_schema(), fs::path(uncompressed_dir()), ++gen);
|
|
|
|
auto cur_dir = src_sst->get_dir();
|
|
auto new_dir = dst_sst->get_dir();
|
|
dst_sst->close_files().get();
|
|
BOOST_REQUIRE_THROW(src_sst->move_to_new_dir(new_dir, gen, true).get(), malformed_sstable_exception);
|
|
}
|