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

Enforce Protocol settings at instantiation #405

Open
ianmkenney opened this issue Nov 13, 2024 · 0 comments · May be fixed by #461
Open

Enforce Protocol settings at instantiation #405

ianmkenney opened this issue Nov 13, 2024 · 0 comments · May be fixed by #461
Assignees
Milestone

Comments

@ianmkenney
Copy link
Member

Problem

The Settings provided to a Protocol are never validated at runtime and incorrect settings can be passed to a Protocol only to cause failures during execution. Since most protocols will require custom settings objects, the types of these settings should be confirmed during instantiation of the Protocols themselves, catching failures early.

Solution

We should add a new class attribute _settings_cls: type[Settings] to the Protocol base class. This attribute should be left unbound. In the Protocol's __init__ method, we can perform the following checks:

  1. Check if the _settings_cls attribute has been defined in the class
  2. Check if the provided settings are an instance of the _settings_cls

If either of these checks fail, raise:

  1. NotImplementedError if _settings_cls is not defined
  2. ValueError if the settings provided do not match the expected type

I've implemented a similar pattern in stratocaster to validate custom settings at instantiation. I believe this approach would be beneficial for Protocols.

Additional considerations

Note that this will break backwards compatibility for existing Protocols.

@dotsdl dotsdl added this to the Release 1.3 milestone Nov 26, 2024
@dotsdl dotsdl moved this to Upcoming Sprint - Queued in gufe : advancement sprints Jan 7, 2025
@dotsdl dotsdl moved this from Upcoming Sprint - Queued to Sprint - Available in gufe : advancement sprints Jan 7, 2025
@ianmkenney ianmkenney linked a pull request Jan 16, 2025 that will close this issue
2 tasks
@ianmkenney ianmkenney moved this from Sprint - Available to Sprint - In Progress in gufe : advancement sprints Jan 16, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Status: Sprint - In Progress
Development

Successfully merging a pull request may close this issue.

2 participants