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

pkg/client: add Config method to ActionClient #424

Merged

Conversation

azych
Copy link
Contributor

@azych azych commented Feb 19, 2025

This PR exposes action.Configuration of a specific actionClient instance via new Config method.

General motivation behind it is for the users to have an 'escape hatch' access to the underlying dependency objects that action.Configuration holds, which include for example:

  • release records store
  • registry client
  • Kubernetes API client

More specific motivation comes from a scenario where an access to the underlying release store instance is needed in order to gracefully handle pending helm releases which were previously interrupted.

For additional context on this, see:
operator-framework/operator-controller#1776
and more specifically this thread: operator-framework/operator-controller#1776 (comment)

For additional context on the helm interruption issue, see:
helm/helm#5595 and helm/helm#7476

prerequisite and part of OCPBUGS-49729

cc @joelanford

@codecov-commenter
Copy link

codecov-commenter commented Feb 19, 2025

Codecov Report

Attention: Patch coverage is 55.55556% with 4 lines in your changes missing coverage. Please review.

Project coverage is 78.39%. Comparing base (08ab7fb) to head (b7952bb).
Report is 75 commits behind head on main.

Files with missing lines Patch % Lines
pkg/reconciler/internal/fake/actionclient.go 42.85% 3 Missing and 1 partial ⚠️

❗ There is a different number of reports uploaded between BASE (08ab7fb) and HEAD (b7952bb). Click for more details.

HEAD has 1 upload less than BASE
Flag BASE (08ab7fb) HEAD (b7952bb)
2 1
Additional details and impacted files
@@            Coverage Diff             @@
##             main     #424      +/-   ##
==========================================
- Coverage   85.06%   78.39%   -6.67%     
==========================================
  Files          19       31      +12     
  Lines        1346     2486    +1140     
==========================================
+ Hits         1145     1949     +804     
- Misses        125      447     +322     
- Partials       76       90      +14     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

Copy link
Member

@porridge porridge left a comment

Choose a reason for hiding this comment

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

No idea whether exposing the configuration is the best way (I guess it depends on what exactly you want to achieve), but other than the nitpick the code looks OK.

This exposes action.Configuration of a specific
actionClient instance.

General motivation behind it is for the users to have
an 'escape hatch' access to the underlying dependency
objects that action.Configuration holds, which include
for example:
- release records store
- registry client
- Kubernetes API client

More specific motivation comes from a scenario where
an access to the underlying release store instance
is needed in order to gracefully handle pending helm
releases which were previously interrupted.
For additional context on this, see:
operator-framework/operator-controller#1776

Signed-off-by: Artur Zych <[email protected]>
@azych azych force-pushed the expose-actionclient-configuration branch from d6d197d to b7952bb Compare February 20, 2025 13:04
@perdasilva perdasilva added this pull request to the merge queue Feb 22, 2025
Merged via the queue into operator-framework:main with commit 6261f25 Feb 22, 2025
5 of 6 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants