-
Notifications
You must be signed in to change notification settings - Fork 192
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: Emit Daemon logs for pytest test run #6671
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,13 +2,15 @@ | |
|
||
from __future__ import annotations | ||
|
||
import logging | ||
import pathlib | ||
import typing as t | ||
|
||
import pytest | ||
|
||
if t.TYPE_CHECKING: | ||
from aiida.engine import Process, ProcessBuilder | ||
from aiida.engine.daemon.client import DaemonClient | ||
from aiida.orm import ProcessNode | ||
|
||
|
||
|
@@ -47,7 +49,7 @@ | |
|
||
|
||
@pytest.fixture | ||
def started_daemon_client(daemon_client): | ||
def started_daemon_client(daemon_client: 'DaemonClient'): | ||
"""Ensure that the daemon is running for the test profile and return the associated client. | ||
|
||
Usage:: | ||
|
@@ -60,11 +62,61 @@ | |
daemon_client.start_daemon() | ||
assert daemon_client.is_daemon_running | ||
|
||
import threading | ||
import time | ||
|
||
from watchdog.events import FileSystemEventHandler | ||
from watchdog.observers import Observer | ||
|
||
logger = logging.getLogger('tests.daemon:started_daemon_client') | ||
|
||
logger.debug(f'Daemon log file is located at: {daemon_client.daemon_log_file}') | ||
|
||
# This flag will be used to stop the thread when the fixture is torn down | ||
stop_thread = False | ||
|
||
class LogFileEventHandler(FileSystemEventHandler): | ||
def __init__(self, filepath): | ||
self.filepath = filepath | ||
# Keep track of how many bytes have been read so we print only new data | ||
self._pos = 0 | ||
|
||
def on_modified(self, event): | ||
if event.src_path == self.filepath: | ||
# The file was modified, read from the last known position | ||
with open(self.filepath, 'r') as f: | ||
f.seek(self._pos) | ||
new_output = f.read() | ||
if new_output: | ||
logger.debug(new_output) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Maybe I should not use logger here since the content of the log file is in log format. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think we also have other things printed to the terminal in log format. At least the warnings I get are in it
|
||
self._pos = f.tell() | ||
|
||
def print_log_content(check_interval=0.1): | ||
event_handler = LogFileEventHandler(daemon_client.daemon_log_file) | ||
observer = Observer() | ||
_ = observer.schedule(event_handler, str(pathlib.Path(daemon_client.daemon_log_file)), recursive=False) | ||
observer.start() | ||
|
||
try: | ||
while not stop_thread: | ||
time.sleep(check_interval) | ||
finally: | ||
observer.stop() | ||
observer.join() | ||
|
||
# Start a background thread to continuously print new log lines | ||
t = threading.Thread(target=print_log_content, daemon=True) | ||
t.start() | ||
|
||
yield daemon_client | ||
|
||
# After the test finishes, signal the thread to stop and join it | ||
stop_thread = True | ||
t.join(timeout=5) | ||
|
||
|
||
@pytest.fixture | ||
def stopped_daemon_client(daemon_client): | ||
def stopped_daemon_client(daemon_client: 'DaemonClient'): | ||
"""Ensure that the daemon is not running for the test profile and return the associated client. | ||
|
||
Usage:: | ||
|
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Which log level do I have to change to debug to see this message? It tried to run
pytest -s --pdb
but I don't see this messageThere was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You need to run
pytest tests --log-cli-level=DEBUG
as mentioned in the description of PR.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
sorry 😞 I dont know why I did not see it
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The way to reproduce the write to the daemon log is to run test
tests/engine/processes/test_control.py::test_pause_processes -v --log-cli-level=DEBUG -s
with print some text in plumpy'sProcess::pause
method. The reason that the print would show things to the REPL where pytest is running since it calls from a rpc call and runs in a daemon worker. The print output will be then written to the daemon log.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Since you encounter a problem that seems when the RMQ not start, the daemon failed to start and the daemon log is written but not dump to debug message, I'll revert the change after. It still help quite a lot by printing the daemon log path so we can go the check manually. What do you think?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It also does not work for me with rabbitmq, I am running
I am checking the prints in
plumpy/processes.py::Process.paused
I see the PAUSE in the log but not printed to the screen.