You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@subversion.apache.org by da...@apache.org on 2022/01/24 10:54:16 UTC
svn commit: r1897407 - /subversion/trunk/subversion/tests/cmdline/basic_tests.py
Author: danielsh
Date: Mon Jan 24 10:54:16 2022
New Revision: 1897407
URL: http://svn.apache.org/viewvc?rev=1897407&view=rev
Log:
* subversion/tests/cmdline/basic_tests.py
(keep_local_reverted_properly): New test.
(test_list): Run it.
Suggested by: hartmannathan
Modified:
subversion/trunk/subversion/tests/cmdline/basic_tests.py
Modified: subversion/trunk/subversion/tests/cmdline/basic_tests.py
URL: http://svn.apache.org/viewvc/subversion/trunk/subversion/tests/cmdline/basic_tests.py?rev=1897407&r1=1897406&r2=1897407&view=diff
==============================================================================
--- subversion/trunk/subversion/tests/cmdline/basic_tests.py (original)
+++ subversion/trunk/subversion/tests/cmdline/basic_tests.py Mon Jan 24 10:54:16 2022
@@ -3242,6 +3242,42 @@ def filtered_ls_top_level_path(sbox):
exit_code, output, error = svntest.actions.run_and_verify_svn(
[], [], 'ls', f_path, '--search=*/*', *extra_opts)
+def keep_local_reverted_properly(sbox):
+ "rm --keep-local, /bin/rm, revert"
+
+ sbox.build(read_only=True)
+ wc_dir = sbox.wc_dir
+
+ lambda_path = sbox.ospath('A/B/lambda')
+ E_path = sbox.ospath('A/B/E')
+ targets = [ lambda_path, E_path ]
+
+ # Modify
+ sbox.simple_append('A/B/lambda', "added text\n")
+ svntest.main.run_svn(None, 'ps', 'k', 'v', E_path)
+
+ # Schedule for removal
+ svntest.main.run_svn(None, 'rm', '--keep-local', *targets)
+
+ # Remove from disk
+ os.unlink(lambda_path)
+ shutil.rmtree(E_path)
+
+ # Revert
+ svntest.main.run_svn(None, 'revert', *targets)
+
+ # Check that the modifications are absent
+ #
+ # alpha and beta are still scheduled for deletion because 'revert' doesn't
+ # recurse by default.
+ expected_disk = svntest.main.greek_state.copy()
+ expected_disk.remove('A/B/E/alpha', 'A/B/E/beta')
+ expected_output = svntest.actions.get_virginal_state(wc_dir, 1)
+ expected_output.tweak('A/B/E/alpha', 'A/B/E/beta', status='D ')
+ #
+ svntest.actions.verify_disk(sbox.wc_dir, expected_disk, check_props=True)
+ svntest.actions.run_and_verify_status(wc_dir, expected_output)
+
########################################################################
# Run the tests
@@ -3318,6 +3354,7 @@ test_list = [ None,
null_update_last_changed_revision,
null_prop_update_last_changed_revision,
filtered_ls_top_level_path,
+ keep_local_reverted_properly,
]
if __name__ == '__main__':