Make DestroyDir destroy directories recursively (#6934)
Summary: Currently, `DeleteDir` only deletes the directory if there are no other directories under the target dir. This PR makes it delete directories recursively. Pull Request resolved: https://github.com/facebook/rocksdb/pull/6934 Test Plan: Added a new unit test in testutil_test.cc. `make testutil_test` Reviewed By: zhichao-cao Differential Revision: D21884211 Pulled By: cheng-chang fbshipit-source-id: 0b9a48a200f494ee007aef5d1763b4aa331f8b5amain
parent
2677bd5967
commit
1bee0fca05
@ -0,0 +1,42 @@ |
||||
// Copyright (c) 2011-present, Facebook, Inc. All rights reserved.
|
||||
// This source code is licensed under both the GPLv2 (found in the
|
||||
// COPYING file in the root directory) and Apache 2.0 License
|
||||
// (found in the LICENSE.Apache file in the root directory).
|
||||
|
||||
#include "test_util/testutil.h" |
||||
|
||||
#include "port/port.h" |
||||
#include "port/stack_trace.h" |
||||
#include "test_util/testharness.h" |
||||
|
||||
namespace ROCKSDB_NAMESPACE { |
||||
|
||||
void CreateFile(Env* env, const std::string& path) { |
||||
std::unique_ptr<WritableFile> f; |
||||
ASSERT_OK(env->NewWritableFile(path, &f, EnvOptions())); |
||||
f->Close(); |
||||
} |
||||
|
||||
TEST(TestUtil, DestroyDirRecursively) { |
||||
auto env = Env::Default(); |
||||
// test_util/file
|
||||
// /dir
|
||||
// /dir/file
|
||||
std::string test_dir = test::PerThreadDBPath("test_util"); |
||||
ASSERT_OK(env->CreateDir(test_dir)); |
||||
CreateFile(env, test_dir + "/file"); |
||||
ASSERT_OK(env->CreateDir(test_dir + "/dir")); |
||||
CreateFile(env, test_dir + "/dir/file"); |
||||
|
||||
ASSERT_OK(test::DestroyDir(env, test_dir)); |
||||
auto s = env->FileExists(test_dir); |
||||
ASSERT_TRUE(s.IsNotFound()); |
||||
} |
||||
|
||||
} // namespace ROCKSDB_NAMESPACE
|
||||
|
||||
int main(int argc, char** argv) { |
||||
ROCKSDB_NAMESPACE::port::InstallStackTraceHandler(); |
||||
::testing::InitGoogleTest(&argc, argv); |
||||
return RUN_ALL_TESTS(); |
||||
} |
Loading…
Reference in new issue