-
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
Conversation
using watchdog to monitoring the daemon log in tmp pytest folder and emit in the debug logger level.
The implementation is a bit hacky, since it open a thread to run watchdog to monitoring the file and emit content to log. |
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 comment
The 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 comment
The 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
tests/brokers/test_rabbitmq.py 01/07/2025 12:21:45 PM <19376> aiida.broker.rabbitmq: [WARNING] RabbitMQ v3.13.6 is not supported and will cause unexpected problems!
for more information, see https://pre-commit.ci
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## main #6671 +/- ##
==========================================
+ Coverage 77.94% 77.95% +0.02%
==========================================
Files 563 563
Lines 41761 41796 +35
==========================================
+ Hits 32545 32579 +34
- Misses 9216 9217 +1 ☔ View full report in Codecov by Sentry. |
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 comment
The 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
tests/brokers/test_rabbitmq.py 01/07/2025 12:21:45 PM <19376> aiida.broker.rabbitmq: [WARNING] RabbitMQ v3.13.6 is not supported and will cause unexpected problems!
|
||
logger = logging.getLogger('tests.daemon:started_daemon_client') | ||
|
||
logger.debug(f'Daemon log file is located at: {daemon_client.daemon_log_file}') |
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 message
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.
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's Process::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
pytest --maxfail=1 -s --log-cli-level=DEBUG tests/engine/processes/test_control.py -k test_pause_processes
I am checking the prints in plumpy/processes.py::Process.paused
@property
def paused(self) -> bool:
"""Return whether the process was being paused."""
print("PAUSE")
return self._paused is not None
I see the PAUSE in the log but not printed to the screen.
I close this one for the moment and only include writing log path to debug level to #6698 as we discussed yesterday. |
using watchdog to monitoring the daemon log in tmp pytest folder and emit in the debug logger level.
(I think there should be a better way to do this by not using circus to start the daemon in pytest)
To get the log in the daemon.log file, run test with: