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
	
	 Cheng Chang
						Cheng Chang