##// END OF EJS Templates
debugcommands: stop using the `pycompat.open()` shim...
debugcommands: stop using the `pycompat.open()` shim Some of these callers were already compatible.

File last commit:

r53247:d4e30c15 default
r53265:9746e618 default
Show More
ps_util.py
53 lines | 1.3 KiB | text/x-python | PythonLexer
Matt Harbison
tests: add a module that can perform the equivalent of `SIGKILL` on any OS...
r52889 # This python code can be imported into tests in order to terminate a process
# with signal.SIGKILL on posix, or a roughly equivalent procedure on Windows.
Matt Harbison
typing: add missing `from __future__ import annotations` to core modules
r53247
from __future__ import annotations
Matt Harbison
tests: add a module that can perform the equivalent of `SIGKILL` on any OS...
r52889 import os
import signal
import subprocess
import sys
import tempfile
from .. import (
encoding,
pycompat,
)
from ..utils import procutil
def kill_nt(pid: int, exit_code: int):
fd, pidfile = tempfile.mkstemp(
prefix=b"sigkill-", dir=encoding.environ[b"HGTMP"], text=False
)
try:
os.write(fd, b'%d\n' % pid)
finally:
os.close(fd)
env = dict(encoding.environ)
env[b"DAEMON_EXITCODE"] = b"%d" % exit_code
# Simulate the message written to stderr for this process on non-Windows
# platforms, for test consistency.
print("Killed!", file=sys.stderr)
subprocess.run(
[
encoding.environ[b"PYTHON"],
b"%s/killdaemons.py"
% encoding.environ[b'RUNTESTDIR_FORWARD_SLASH'],
pidfile,
],
env=procutil.tonativeenv(env),
)
def kill(pid: int):
"""Kill the process with the given PID with SIGKILL or equivalent."""
if pycompat.iswindows:
exit_code = 128 + 9
kill_nt(pid, exit_code)
else:
os.kill(pid, signal.SIGKILL)