Skip to content
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

Closed

Conversation

unkcpz
Copy link
Member

@unkcpz unkcpz commented Dec 19, 2024

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:

pytest tests --log-cli-level=DEBUG -s

using watchdog to monitoring the daemon log in tmp pytest folder and
emit in the debug logger level.
@unkcpz unkcpz requested review from sphuber and agoscinski December 19, 2024 15:22
@unkcpz
Copy link
Member Author

unkcpz commented Dec 19, 2024

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)
Copy link
Member Author

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.

Copy link
Contributor

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!

Copy link

codecov bot commented Dec 19, 2024

Codecov Report

Attention: Patch coverage is 97.29730% with 1 line in your changes missing coverage. Please review.

Project coverage is 77.95%. Comparing base (02cbe0c) to head (b689d3a).
Report is 7 commits behind head on main.

Files with missing lines Patch % Lines
src/aiida/tools/pytest_fixtures/daemon.py 97.30% 1 Missing ⚠️
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.
📢 Have feedback on the report? Share it here.

@unkcpz unkcpz changed the title Emit Daemon logs for pytest test run DevOps: Emit Daemon logs for pytest test run Dec 20, 2024
@unkcpz unkcpz changed the title DevOps: Emit Daemon logs for pytest test run feat: Emit Daemon logs for pytest test run Dec 20, 2024
f.seek(self._pos)
new_output = f.read()
if new_output:
logger.debug(new_output)
Copy link
Contributor

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}')
Copy link
Contributor

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

Copy link
Member Author

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.

Copy link
Contributor

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

Copy link
Member Author

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.

Copy link
Member Author

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?

Copy link
Contributor

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.

@unkcpz
Copy link
Member Author

unkcpz commented Jan 10, 2025

I close this one for the moment and only include writing log path to debug level to #6698 as we discussed yesterday.

@unkcpz unkcpz closed this Jan 10, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants