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

Add running workflow for worker index to cache #599

Merged
merged 1 commit into from
Apr 4, 2022

Conversation

micahhausler
Copy link
Contributor

Description

Adds indexer so clients can query for running workflows by a particular worker address

Signed-off-by: Micah Hausler [email protected]

Why is this needed

Boots needs to import this logic and query for these workflows

Fixes: # N/A

How Has This Been Tested?

Added unit tests for existing and new index functions

How are existing users impacted? What migration steps/scripts do we need?

N/A

Checklist:

I have:

  • updated the documentation and/or roadmap (if required)
  • added unit or e2e tests
  • provided instructions on how to upgrade

@codecov
Copy link

codecov bot commented Mar 22, 2022

Codecov Report

Merging #599 (eb40dae) into main (1d4fd95) will decrease coverage by 0.26%.
The diff coverage is 61.40%.

@@            Coverage Diff             @@
##             main     #599      +/-   ##
==========================================
- Coverage   45.94%   45.68%   -0.27%     
==========================================
  Files          53       55       +2     
  Lines        3182     3301     +119     
==========================================
+ Hits         1462     1508      +46     
- Misses       1634     1707      +73     
  Partials       86       86              
Impacted Files Coverage Δ
pkg/controllers/manager.go 40.00% <61.40%> (ø)
pkg/controllers/retry.go 0.00% <0.00%> (ø)

Continue to review full report at Codecov.

Legend - Click here to learn more
Δ = absolute <relative> (impact), ø = not affected, ? = missing data
Powered by Codecov. Last update 1d4fd95...eb40dae. Read the comment docs.

displague
displague previously approved these changes Mar 22, 2022
Copy link
Member

@displague displague left a comment

Choose a reason for hiding this comment

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

This looks good and is consistent with our existing index.

I have some questions about the format of keys (should they start with a .), names of meta keys (is the snake case field name conventional), and return values (Indexer documentation says only return a single string for Kubernetes compatibility), but our existing index brings up the same questions. (I wont hold this up on that)

https://github.com/kubernetes-sigs/controller-runtime/blob/v0.11.1/pkg/client/interfaces.go#L125-L136

@micahhausler
Copy link
Contributor Author

I have some questions about the format of keys (should they start with a .),

I'm happy to prefix with a period

names of meta keys (is the snake case field name conventional)

Good catch, I'll fix this to be more inline with the API field name convention

and return values (Indexer documentation says only return a single string for Kubernetes compatibility), but our existing index brings up the same questions.

I believe this only matters if you wanted to compatibility with a field-selector in the API, which we don't here. We intentionally want all the workers for a particular workflow.

displague
displague previously approved these changes Mar 22, 2022
Copy link
Contributor

@detiber detiber left a comment

Choose a reason for hiding this comment

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

A couple of questions on the index itself, but I'm curious why this is part of pkg/controllers/manager.go if it's expected to be consumed by boots or other clients, would it make more sense to have it in a separate package to be consumed by the clients?

@@ -17,7 +17,8 @@ import (
)

const (
WorkerAddr = "status.tasks.workeraddr"
WorkerAddrIndex = ".status.tasks.workerAddr"
NonTerminalStateIndex = ".status.state.nonTerminalWorker"
Copy link
Contributor

Choose a reason for hiding this comment

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

Curious to see if it would make sense to break this out on a per-state basis instead of just non-terminal states.

I'm also wondering if we might run into issues based on the field naming here, given the comment about the FieldIndexer interface here: https://pkg.go.dev/sigs.k8s.io/[email protected]/pkg/client#FieldIndexer

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Curious to see if it would make sense to break this out on a per-state basis instead of just non-terminal states

I've added an additional index for state, WorkflowStateIndex and I've updated the index variable names for clarity. Take a look at the documented example under FieldIndexer, the Index name is just a key to lookup an object based on shared understanding of what that index means. In the documented example, the field name is spec.volumes.secret.secretName and returns all the secret names mounted on a pod.

@micahhausler
Copy link
Contributor Author

A couple of questions on the index itself, but I'm curious why this is part of pkg/controllers/manager.go if it's expected to be consumed by boots or other clients, would it make more sense to have it in a separate package to be consumed by the clients?

Is there anywhere else you're thinking of specifically? This code is importable by Boots in the current package. Boots will become just a client of Kubernetes, as opposed to the Tinkerbell API. In that architecture, Boots will need still need indexes on Hardware by MAC and IP, as well as workflows for a particular worker.

@micahhausler micahhausler force-pushed the controller/indexer branch 3 times, most recently from a40de6e to 13455f4 Compare March 24, 2022 21:51
thebsdbox
thebsdbox previously approved these changes Mar 30, 2022
Copy link
Contributor

@thebsdbox thebsdbox left a comment

Choose a reason for hiding this comment

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

This looks OK to me, based upon reading through the code and a review of the comments. Unless @detiber has any strong feelings on the convo re:boots.

Copy link
Contributor

@mmlb mmlb left a comment

Choose a reason for hiding this comment

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

lgtm after the func comment is fixed

pkg/controllers/manager.go Outdated Show resolved Hide resolved
@mmlb
Copy link
Contributor

mmlb commented Apr 4, 2022

After taking a look at #600, does it make more sense to get that merged first and then use the defined constants instead of bare strings here?

@micahhausler
Copy link
Contributor Author

After taking a look at #600, does it make more sense to get that merged first and then use the defined constants instead of bare strings here?

Yep! I'll rebase this and reference the constants once #600 merges

* Add tests on index functions
* Add constants for action states

Signed-off-by: Micah Hausler <[email protected]>
Copy link
Contributor

@mmlb mmlb left a comment

Choose a reason for hiding this comment

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

lgtm!

@mmlb mmlb added the ready-to-merge Signal to Mergify to merge the PR. label Apr 4, 2022
@mergify mergify bot merged commit dbe434f into tinkerbell:main Apr 4, 2022
@micahhausler micahhausler deleted the controller/indexer branch April 4, 2022 22:40
@displague displague added this to the 0.7.0 milestone Aug 15, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
ready-to-merge Signal to Mergify to merge the PR.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants