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

use mixin class for QuantumESPRESSO #212

Open
wants to merge 9 commits into
base: main
Choose a base branch
from
Open

Conversation

smoors
Copy link
Collaborator

@smoors smoors commented Nov 30, 2024

notes:

  • this change may affect performance as process binding is now on by default
    - the mixin class no longer raises an error if bench_name is not defined as it's not really needed, and it helps making the QE test a bit simpler.

@casparvl casparvl added this to the v0.4.1 milestone Dec 11, 2024
@@ -435,7 +434,7 @@ def _set_or_append_valid_systems(test: rfm.RegressionTest, valid_systems: str):
warn_msg = f"valid_systems has multiple ({len(test.valid_systems)}) items,"
warn_msg += " which is not supported by this hook."
warn_msg += " Make sure to handle filtering yourself."
warnings.warn(warn_msg)
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Just to double check: these changes were not accidental, right?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't mind too much, but you could set bench_name=None in the class body. Then, with the current logic of setting self.banch_name=self.bench_name_ci in that one particular case in the init hook, that should work, right? I.e. it's essentially only one extra line in the test (a default bench_name).

Copy link
Collaborator Author

@smoors smoors Dec 12, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

you're right, i re-added the bench_name check in the mixin class.
i've now also set bench_name_ci only for the CI test to avoid that bench_name always has to be set to something.

Copy link
Collaborator Author

@smoors smoors Dec 12, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

and yes, those warning changes are again not accidental :)
they're done to make sure we're now always using reframe warnings, and also to avoid creating logger object in a separate step.

Copy link
Collaborator

@casparvl casparvl left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@smoors if you can just double check that the changes to the hooks.py were intentional and check if you'd still like to chance anything regarding the bench_name approach, I'm ok with this PR. Even if you don't change the bench_name approach, I'm ok.

Tested the CI case on all core counts: works like a charm.

@smoors smoors requested a review from casparvl December 12, 2024 10:54
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