From cecb219f7b085c588da15c7b426e7b6dcfa725f5 Mon Sep 17 00:00:00 2001 From: Navid Shaikh Date: Tue, 18 Aug 2020 12:28:22 +0530 Subject: [PATCH] Set client custom GVK for source list for machine readable output - Use custom GVK {Group: client.knative.dev, Version: v1alpha1, Kind: SourceList} - Source list may contain different source types CO and machine readable output (using -o) requires List object to have GVK set, since the list contains different types of source COs, we set a custom client GVK on it. Fixes #953 --- CHANGELOG.adoc | 4 ++++ pkg/dynamic/client.go | 31 +++++++++++-------------------- pkg/dynamic/client_test.go | 3 +++ 3 files changed, 18 insertions(+), 20 deletions(-) diff --git a/CHANGELOG.adoc b/CHANGELOG.adoc index 7cf0f45987..089409beae 100644 --- a/CHANGELOG.adoc +++ b/CHANGELOG.adoc @@ -45,6 +45,10 @@ | 🐛 | Fix client side volume name generation | https://github.com/knative/client/pull/975[#975] + +| ✨ +| `kn source list` output now has client custom GVK set as `{Group: client.knative.dev, Version: v1alpha1, Kind: SourceList}` +| https://github.com/knative/client/pull/980[#980] |=== ## v0.16.0 (2020-07-14) diff --git a/pkg/dynamic/client.go b/pkg/dynamic/client.go index fb97beaf9d..78bea88b8d 100644 --- a/pkg/dynamic/client.go +++ b/pkg/dynamic/client.go @@ -34,6 +34,9 @@ const ( crdKinds = "customresourcedefinitions" sourcesLabelKey = "duck.knative.dev/source" sourcesLabelValue = "true" + sourceListGroup = "client.knative.dev" + sourceListVersion = "v1alpha1" + sourceListKind = "SourceList" ) // KnDynamicClient to client-go Dynamic client. All methods are relative to the @@ -111,9 +114,8 @@ func (c knDynamicClient) RawClient() dynamic.Interface { // only given types of source objects func (c *knDynamicClient) ListSources(types ...WithType) (*unstructured.UnstructuredList, error) { var ( - sourceList unstructured.UnstructuredList - options metav1.ListOptions - numberOfSourceTypesFound int + sourceList unstructured.UnstructuredList + options metav1.ListOptions ) sourceTypes, err := c.ListSourcesTypes() if err != nil { @@ -151,16 +153,11 @@ func (c *knDynamicClient) ListSources(types ...WithType) (*unstructured.Unstruct } if len(sList.Items) > 0 { - // keep a track if we found source objects of different types - numberOfSourceTypesFound++ sourceList.Items = append(sourceList.Items, sList.Items...) - sourceList.SetGroupVersionKind(sList.GetObjectKind().GroupVersionKind()) } } - // Clear the Group and Version for list if there are multiple types of source objects found - // Keep the source's GVK if there is only one type of source objects found or requested via --type filter - if numberOfSourceTypesFound > 1 { - sourceList.SetGroupVersionKind(schema.GroupVersionKind{Group: "", Version: "", Kind: "List"}) + if len(sourceList.Items) > 0 { + sourceList.SetGroupVersionKind(schema.GroupVersionKind{Group: sourceListGroup, Version: sourceListVersion, Kind: sourceListKind}) } return &sourceList, nil } @@ -172,9 +169,8 @@ func (c *knDynamicClient) ListSourcesUsingGVKs(gvks *[]schema.GroupVersionKind, } var ( - sourceList unstructured.UnstructuredList - options metav1.ListOptions - numberOfSourceTypesFound int + sourceList unstructured.UnstructuredList + options metav1.ListOptions ) namespace := c.Namespace() filters := WithTypes(types).List() @@ -193,16 +189,11 @@ func (c *knDynamicClient) ListSourcesUsingGVKs(gvks *[]schema.GroupVersionKind, } if len(sList.Items) > 0 { - // keep a track if we found source objects of different types - numberOfSourceTypesFound++ sourceList.Items = append(sourceList.Items, sList.Items...) - sourceList.SetGroupVersionKind(sList.GetObjectKind().GroupVersionKind()) } } - // Clear the Group and Version for list if there are multiple types of source objects found - // Keep the source's GVK if there is only one type of source objects found or requested via --type filter - if numberOfSourceTypesFound > 1 { - sourceList.SetGroupVersionKind(schema.GroupVersionKind{Group: "", Version: "", Kind: "List"}) + if len(sourceList.Items) > 0 { + sourceList.SetGroupVersionKind(schema.GroupVersionKind{Group: sourceListGroup, Version: sourceListVersion, Kind: sourceListKind}) } return &sourceList, nil } diff --git a/pkg/dynamic/client_test.go b/pkg/dynamic/client_test.go index aae3df4c00..69043d9976 100644 --- a/pkg/dynamic/client_test.go +++ b/pkg/dynamic/client_test.go @@ -122,6 +122,7 @@ func TestListSources(t *testing.T) { sources, err := client.ListSources(WithTypeFilter("pingsource"), WithTypeFilter("ApiServerSource")) assert.NilError(t, err) assert.Equal(t, len(sources.Items), 2) + assert.DeepEqual(t, sources.GroupVersionKind(), schema.GroupVersionKind{sourceListGroup, sourceListVersion, sourceListKind}) }) } @@ -149,12 +150,14 @@ func TestListSourcesUsingGVKs(t *testing.T) { assert.NilError(t, err) assert.Check(t, s != nil) assert.Equal(t, len(s.Items), 2) + assert.DeepEqual(t, s.GroupVersionKind(), schema.GroupVersionKind{sourceListGroup, sourceListVersion, sourceListKind}) // withType s, err = client.ListSourcesUsingGVKs(&gvks, WithTypeFilter("PingSource")) assert.NilError(t, err) assert.Check(t, s != nil) assert.Equal(t, len(s.Items), 1) + assert.DeepEqual(t, s.GroupVersionKind(), schema.GroupVersionKind{sourceListGroup, sourceListVersion, sourceListKind}) }) }