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: implement direct controller for MonitoringDashboard #1863

Conversation

justinsb
Copy link
Collaborator

@justinsb justinsb commented May 21, 2024

  • feat: implement direct controller for MonitoringDashboard
  • chore: update monitoringdashboard golden output

@justinsb
Copy link
Collaborator Author

I think we should merge this after we have more tests (at least #1806) - then I can also make the ref-test real

@justinsb justinsb force-pushed the monitoring_dashboard_controller branch from bde11ea to b8be512 Compare May 22, 2024 14:25
@justinsb justinsb force-pushed the monitoring_dashboard_controller branch 6 times, most recently from a5fc35d to 25883aa Compare June 6, 2024 11:15
"widgets": [
{
"title": "Widget 1",
"xyChart": {
"dataSets": [
{
"plotType": "LINE",
"plotType": 1,
Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Kind of annoying, but the official client uses integer enum encoding, messing up our diffs. I can try the proto form and see if it is any better.

Copy link
Collaborator

@yuwenma yuwenma Jun 7, 2024

Choose a reason for hiding this comment

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

I missed this. Please ignore my other comment.

Content-Type: application/json
User-Agent: kcc/controller-manager DeclarativeClientLib/0.0.1
Copy link
Collaborator Author

Choose a reason for hiding this comment

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

I think the diff is confused here because we don't do a GET before DELETE. Maybe we should just do the GET!

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

I added a semi-superfluous GET to delete, the diff now looks much better!

@justinsb justinsb changed the title WIP: feat: implement direct controller for MonitoringDashboard feat: implement direct controller for MonitoringDashboard Jun 6, 2024
@justinsb justinsb force-pushed the monitoring_dashboard_controller branch from 5b333d9 to 9ac8098 Compare June 6, 2024 15:33

func newDashboardModel(config *controller.Config) directbase.Model {
ctx := context.TODO()
gcpClient, err := newGCPClient(ctx, config)
Copy link
Collaborator

Choose a reason for hiding this comment

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

or we can move this to AdapterForObject so as we can use the passed in context.Context parameter.
The AdapterForObject will be initialized in each Reconcile loop.

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

My one concern is that building the client may be expensive: if we have to open a new TCP connection, or if we have to get the token again. But I don't want to block this PR on it, so I'll move it!

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Ah, I guess we're calling the expensive call every time anyway :-)

scripts/github-actions/tests-e2e-direct.sh Show resolved Hide resolved
@@ -3,7 +3,6 @@ kind: MonitoringDashboard
metadata:
annotations:
cnrm.cloud.google.com/management-conflict-prevention-policy: none
cnrm.cloud.google.com/state-into-spec: merge
Copy link
Collaborator

Choose a reason for hiding this comment

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

👍

)

func GetResourceID(u *unstructured.Unstructured) (string, error) {
resourceID, _, err := unstructured.NestedString(u.Object, "spec", "resourceID")
Copy link
Collaborator

Choose a reason for hiding this comment

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

I recalled to see a team discussion about the camel case for projectId rather than projectID. Shall this be resourceId or resourceID?
(Not a blocker to this PR, just want to align the names here since this is a shareable function under direct/references)

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

So ... go says "ID". KRM style guide says "ID". Google APIs use "Id" (in JSON). Most KCC fields use Id, but I guess here we use resourceID.

If the KCC field was called resourceId, I don't know whether I would follow go conventions or try to match the name of the field.

In this case though, we're reading a field, and I think that field's name is resourceID. That's correct against KRM style guide, but possibly inconsistent with most other GCP-generated fields.

I think it's your decision @yuwenma , and it's going to be interesting!

(Our best bet might be to stop adding fields that end in Id at all, maybe it's another marker that something is actually a ref ... or we could just drop ID arguing that it is the "type" of the field, and we don't say "fooString" so why do we say "fooID" or "fooURL" ? )

"sigs.k8s.io/controller-runtime/pkg/client"
)

func normalizeResourceName(ctx context.Context, reader client.Reader, src client.Object, ref *v1alpha1.ResourceRef) (*v1alpha1.ResourceRef, error) {
Copy link
Collaborator

@yuwenma yuwenma Jun 7, 2024

Choose a reason for hiding this comment

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

Do you want to move this to controller/direct/reference/ or something that can be sharable? I feel like this is a good piece to reuse and continue improving as we building up more resources.

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Yes, but my "rule of thumb" is to move it when we have two copies. For this particular one, we only have one copy (this is actually very specialized - there's a field called "resourceName" in MonitoringDashboard. Note that this method does call into shared functions for most of its logic!

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Actually I guess this is resolving a resource of arbitrary kind, so is more reusable than I first thought. Still, it's our first ... let's move it when we have two or three instances.

Comment on lines +96 to +113
func setStatus(u *unstructured.Unstructured, typedStatus any) error {
status, err := runtime.DefaultUnstructuredConverter.ToUnstructured(typedStatus)
if err != nil {
return fmt.Errorf("error converting status to unstructured: %w", err)
}

// Use existing values for conditions/observedGeneration; they are managed in k8s not the GCP API
old, _, _ := unstructured.NestedMap(u.Object, "status")
if old != nil {
status["conditions"] = old["conditions"]
status["observedGeneration"] = old["observedGeneration"]
}

u.Object["status"] = status

return nil
}

Copy link
Collaborator

Choose a reason for hiding this comment

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

qq: do you think we shall move this to the direct_controllerReconcile?

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

We should move it, along with most/all of the functions in utils. I just don't think we know where to move it to yet!

@justinsb justinsb force-pushed the monitoring_dashboard_controller branch 3 times, most recently from 3bdaf3f to a680eec Compare June 7, 2024 18:29
@yuwenma
Copy link
Collaborator

yuwenma commented Jun 13, 2024

/lgtm
/approve

I think the presubmit should be fixed in #1979. Could you rebase this PR and re-write the golden logs? It looks great!

Copy link
Contributor

[APPROVALNOTIFIER] This PR is APPROVED

This pull-request has been approved by: yuwenma

The full list of commands accepted by this bot can be found here.

The pull request process is described here

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@justinsb justinsb force-pushed the monitoring_dashboard_controller branch from a680eec to 0f25e8c Compare June 17, 2024 19:36
@google-oss-prow google-oss-prow bot removed the lgtm label Jun 17, 2024
@justinsb justinsb force-pushed the monitoring_dashboard_controller branch from 0f25e8c to 6d3b114 Compare June 17, 2024 22:35
@justinsb justinsb force-pushed the monitoring_dashboard_controller branch from 6d3b114 to 81db68b Compare June 18, 2024 02:00
@yuwenma
Copy link
Collaborator

yuwenma commented Jun 18, 2024

/lgtm

@google-oss-prow google-oss-prow bot added the lgtm label Jun 18, 2024
@yuwenma yuwenma added this to the 1.119 milestone Jun 18, 2024
@google-oss-prow google-oss-prow bot merged commit 27c6cbf into GoogleCloudPlatform:master Jun 18, 2024
13 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.

2 participants