diff options
author | Jussi Pakkanen <jpakkane@gmail.com> | 2017-05-18 18:55:33 +0300 |
---|---|---|
committer | Jussi Pakkanen <jpakkane@gmail.com> | 2017-05-21 21:47:24 +0300 |
commit | effe4fb13416279eecad52504e5ce1e0b4c7e5e3 (patch) | |
tree | e1c9d7469ee295e63919743ae1fef03e1014bcd4 /run_project_tests.py | |
parent | 189784b47404a7ab8b9443e4604721df2941a042 (diff) | |
download | meson-effe4fb13416279eecad52504e5ce1e0b4c7e5e3.zip meson-effe4fb13416279eecad52504e5ce1e0b4c7e5e3.tar.gz meson-effe4fb13416279eecad52504e5ce1e0b4c7e5e3.tar.bz2 |
Create helper function for a rmtree that works reliably on Windows.
Diffstat (limited to 'run_project_tests.py')
-rwxr-xr-x | run_project_tests.py | 23 |
1 files changed, 5 insertions, 18 deletions
diff --git a/run_project_tests.py b/run_project_tests.py index 7f7cfdc..822286b 100755 --- a/run_project_tests.py +++ b/run_project_tests.py @@ -114,24 +114,11 @@ class AutoDeletedDir: return self.dir def __exit__(self, _type, value, traceback): - # On Windows, shutil.rmtree fails sometimes, because 'the directory is not empty'. - # Retrying fixes this. - # That's why we don't use tempfile.TemporaryDirectory, but wrap the deletion in the AutoDeletedDir class. - retries = 5 - for i in range(0, retries): - try: - shutil.rmtree(self.dir) - return - # Sometimes we get: ValueError: I/O operation on closed file. - except ValueError: - return - # Deleting can raise OSError or PermissionError on Windows - # (most likely because of anti-virus locking the file) - except (OSError, PermissionError): - if i == retries - 1: - mlog.warning('Could not delete temporary directory.') - return - time.sleep(0.1 * (2**i)) + # We don't use tempfile.TemporaryDirectory, but wrap the + # deletion in the AutoDeletedDir class because + # it fails on Windows due antivirus programs + # holding files open. + mesonlib.windows_proof_rmtree(self.dir) failing_logs = [] print_debug = 'MESON_PRINT_TEST_OUTPUT' in os.environ |