Mercurial > vim
view src/testdir/thread_util.py @ 32697:e5cd5e8627da v9.0.1679
patch 9.0.1679: Cleanup Tests from leftover files
Commit: https://github.com/vim/vim/commit/84bc00e9b52b1174888f2f696f8b628a83c49988
Author: Christian Brabandt <cb@256bit.org>
Date: Thu Jul 13 11:45:54 2023 +0200
patch 9.0.1679: Cleanup Tests from leftover files
Problem: Tests may leave leftover files around
Solution: Clean up tests and remove files
There were a few failures in 'linux (huge, gcc, testgui, true, true)'
e.g. here: https://github.com/vim/vim/actions/runs/5497376153/jobs/10018060156
,----
| Error detected while processing command line..script /home/runner/work/vim/vim/src/testdir/runtest.vim[585]..function RunTheTest[54]..Test_lvimgrep_crash[16]..TestTimeout[12]..VimLeavePre Autocommands for "*"..function EarlyExit[7]..FinishTesting:
| line 70:
| E445: Other window contains changes
| E937: Attempt to delete a buffer that is in use: Xtest_stable_xxd.txt
| E937: Attempt to delete a buffer that is in use: Xtest_stable_xxd.txt
| E937: Attempt to delete a buffer that is in use: Xtest_stable_xxd.txtmalloc(): unsorted double linked list corrupted
`----
Which is puzzling, because the Xtest_stable_xxd file should have been
long gone after test_crypt.vim is run (and definitely no longer be
staying around in test_quickfix.vim).
So try to clean up properly after a test script is run, just in case any
X<file> is still around. During testing, a found a few leftover files,
which I also fixed in the relevant test-file.
Unfortunately, the test workflow 'linux (huge, gcc, testgui, true,
true)' now seems to fail with 'E1230: Encryption: sodium_mlock()' in
test_crypt.vim. Hopefully this is only temporary.
author | Christian Brabandt <cb@256bit.org> |
---|---|
date | Tue, 08 Aug 2023 20:45:05 +0200 |
parents | 06e3c6bac36d |
children |
line wrap: on
line source
import platform if platform.system() == 'Darwin': from ctypes import ( CDLL, POINTER, Structure, byref, c_int, c_uint, c_uint32, c_void_p, sizeof ) from ctypes.util import find_library class ThreadTimeConstraintPolicy(Structure): _fields_ = [ ("period", c_uint32), ("computation", c_uint32), ("constraint", c_uint32), ("preemptible", c_uint) ] _libc = CDLL(find_library('c')) THREAD_TIME_CONSTRAINT_POLICY = c_uint(2) THREAD_TIME_CONSTRAINT_POLICY_COUNT = c_uint( int(sizeof(ThreadTimeConstraintPolicy) / sizeof(c_int))) _libc.pthread_self.restype = c_void_p _libc.pthread_mach_thread_np.restype = c_uint _libc.pthread_mach_thread_np.argtypes = [c_void_p] _libc.thread_policy_get.restype = c_int _libc.thread_policy_get.argtypes = [ c_uint, c_uint, c_void_p, POINTER(c_uint), POINTER(c_uint) ] _libc.thread_policy_set.restype = c_int _libc.thread_policy_set.argtypes = [ c_uint, c_uint, c_void_p, c_uint ] def _mach_thread_self(): return _libc.pthread_mach_thread_np(_libc.pthread_self()) def _get_time_constraint_policy(default=False): thread = _mach_thread_self() policy_info = ThreadTimeConstraintPolicy() policy_infoCnt = THREAD_TIME_CONSTRAINT_POLICY_COUNT get_default = c_uint(default) kret = _libc.thread_policy_get( thread, THREAD_TIME_CONSTRAINT_POLICY, byref(policy_info), byref(policy_infoCnt), byref(get_default)) if kret != 0: return None return policy_info def _set_time_constraint_policy(policy_info): thread = _mach_thread_self() policy_infoCnt = THREAD_TIME_CONSTRAINT_POLICY_COUNT kret = _libc.thread_policy_set( thread, THREAD_TIME_CONSTRAINT_POLICY, byref(policy_info), policy_infoCnt) if kret != 0: raise OSError(kret) def set_high_priority(): policy_info = _get_time_constraint_policy(default=True) if not policy_info: return policy_info.preemptible = c_uint(False) _set_time_constraint_policy(policy_info)