From: Florian Eder Subject: [PATCH 27/41] robocopy/tests: add conformance tests for /L Message-Id: <20210906145518.346132-27-others.meder@gmail.com> Date: Mon, 6 Sep 2021 14:55:04 +0000 In-Reply-To: <20210906145518.346132-1-others.meder@gmail.com> References: <20210906145518.346132-1-others.meder@gmail.com> Signed-off-by: Florian Eder --- programs/robocopy/tests/robocopy.c | 53 ++++++++++++++++++++++++++++++ 1 file changed, 53 insertions(+) diff --git a/programs/robocopy/tests/robocopy.c b/programs/robocopy/tests/robocopy.c index 6ded4e98650..0f6e07b3d71 100644 --- a/programs/robocopy/tests/robocopy.c +++ b/programs/robocopy/tests/robocopy.c @@ -517,6 +517,37 @@ static void check_lev_1_test(void) check_folder_and_delete(L"robocopy_destination", TRUE); } +static void check_dry_test(void) +{ + check_file_and_delete(L"robocopy_source\\fileA.a", TRUE); + check_file_and_delete(L"robocopy_source\\fileB.b", TRUE); + check_file_and_delete(L"robocopy_source\\folderA\\fileC.c", TRUE); + check_file_and_delete(L"robocopy_source\\folderA\\fileD.d", TRUE); + check_file_and_delete(L"robocopy_source\\folderA\\folderD\\fileE.e", TRUE); + check_file_and_delete(L"robocopy_source\\folderB\\fileF.f", TRUE); + check_file_and_delete(L"robocopy_source\\folderB\\fileG.g", TRUE); + check_folder_and_delete(L"robocopy_source\\folderA\\folderD", TRUE); + check_folder_and_delete(L"robocopy_source\\folderA\\folderE", TRUE); + check_folder_and_delete(L"robocopy_source\\folderA", TRUE); + check_folder_and_delete(L"robocopy_source\\folderB", TRUE); + check_folder_and_delete(L"robocopy_source\\folderC", TRUE); + check_folder_and_delete(L"robocopy_source", TRUE); + + check_file_and_delete(L"robocopy_destination\\fileA.a", FALSE); + check_file_and_delete(L"robocopy_destination\\fileB.b", FALSE); + check_file_and_delete(L"robocopy_destination\\folderA\\fileC.c", FALSE); + check_file_and_delete(L"robocopy_destination\\folderA\\fileD.d", FALSE); + check_file_and_delete(L"robocopy_destination\\folderA\\folderD\\fileE.e", FALSE); + check_file_and_delete(L"robocopy_destination\\folderB\\fileF.f", FALSE); + check_file_and_delete(L"robocopy_destination\\folderB\\fileG.g", FALSE); + check_folder_and_delete(L"robocopy_destination\\folderA\\folderD", FALSE); + check_folder_and_delete(L"robocopy_destination\\folderA\\folderE", FALSE); + check_folder_and_delete(L"robocopy_destination\\folderA", FALSE); + check_folder_and_delete(L"robocopy_destination\\folderB", FALSE); + check_folder_and_delete(L"robocopy_destination\\folderC", FALSE); + check_folder_and_delete(L"robocopy_destination", FALSE); +} + START_TEST(robocopy) { WCHAR temp_command_line[2048], previous_cwd_path[4096], temp_path[4096]; @@ -669,6 +700,28 @@ START_TEST(robocopy) check_lev_1_test(); winetest_pop_context(); + winetest_push_context("dry test 1"); + create_test_source_folder(); + execute_robocopy(L"robocopy.exe robocopy_source robocopy_destination /mir /l /r:1 /w:0", 1); + check_dry_test(); + winetest_pop_context(); + + winetest_push_context("dry test 2"); + create_test_source_folder(); + execute_robocopy(L"robocopy.exe robocopy_source robocopy_destination /move /s /l /r:1 /w:0", 1); + check_dry_test(); + winetest_pop_context(); + + winetest_push_context("dry test 3"); + create_test_source_folder(); + create_test_folder(L"robocopy_destination"); + create_test_file(L"robocopy_destination\\extraFile", 9000, 0, -10); + execute_robocopy(L"robocopy.exe robocopy_source robocopy_destination /move /s /l /r:1 /w:0", 3); + check_file_and_delete(L"robocopy_destination\\extraFile", TRUE); + check_folder_and_delete(L"robocopy_destination", TRUE); + check_dry_test(); + winetest_pop_context(); + /* Reset CWD to previous folder */ ok(SetCurrentDirectoryW(previous_cwd_path), "couldn't set CWD to previous CWD folder \"%S\"", previous_cwd_path); } \ No newline at end of file -- 2.32.0