Skip to content

Commit

Permalink
fix(serving): Remove hardcoded GVK and look it up from schema
Browse files Browse the repository at this point in the history
Fixes #133.
  • Loading branch information
rhuss committed May 20, 2019
1 parent 52b6b23 commit 0cbcdd9
Show file tree
Hide file tree
Showing 7 changed files with 88 additions and 25 deletions.
11 changes: 6 additions & 5 deletions pkg/kn/commands/revision_describe.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,11 @@ package commands

import (
"errors"
"github.com/knative/client/pkg/serving"
"github.com/knative/serving/pkg/apis/serving/v1alpha1"

"github.com/spf13/cobra"
v1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/runtime/schema"
"k8s.io/cli-runtime/pkg/genericclioptions"
)

Expand Down Expand Up @@ -51,10 +52,10 @@ func NewRevisionDescribeCommand(p *KnParams) *cobra.Command {
if err != nil {
return err
}
revision.GetObjectKind().SetGroupVersionKind(schema.GroupVersionKind{
Group: "knative.dev",
Version: "v1alpha1",
Kind: "Revision"})
if err := serving.UpdateGroupVersionKind(revision, v1alpha1.SchemeGroupVersion); err != nil {
return err
}

err = printer.PrintObj(revision, cmd.OutOrStdout())
if err != nil {
return err
Expand Down
12 changes: 6 additions & 6 deletions pkg/kn/commands/revision_get.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,10 @@ package commands

import (
"fmt"

"github.com/knative/client/pkg/serving"
"github.com/knative/serving/pkg/apis/serving/v1alpha1"
"github.com/spf13/cobra"
"k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/runtime/schema"
)

// NewRevisionGetCommand represents 'kn revision get' command
Expand All @@ -46,10 +46,10 @@ func NewRevisionGetCommand(p *KnParams) *cobra.Command {
fmt.Fprintf(cmd.OutOrStdout(), "No resources found.\n")
return nil
}
revision.GetObjectKind().SetGroupVersionKind(schema.GroupVersionKind{
Group: "knative.dev",
Version: "v1alpha1",
Kind: "revision"})
if err := serving.UpdateGroupVersionKind(revision, v1alpha1.SchemeGroupVersion); err != nil {
return err
}

printer, err := revisionGetFlags.ToPrinter()
if err != nil {
return err
Expand Down
11 changes: 6 additions & 5 deletions pkg/kn/commands/service_describe.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,11 @@ package commands

import (
"errors"
"github.com/knative/client/pkg/serving"
"github.com/knative/serving/pkg/apis/serving/v1alpha1"

"github.com/spf13/cobra"
v1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/runtime/schema"
"k8s.io/cli-runtime/pkg/genericclioptions"
)

Expand Down Expand Up @@ -51,10 +52,10 @@ func NewServiceDescribeCommand(p *KnParams) *cobra.Command {
if err != nil {
return err
}
describeService.GetObjectKind().SetGroupVersionKind(schema.GroupVersionKind{
Group: "knative.dev",
Version: "v1alpha1",
Kind: "Service"})
if err := serving.UpdateGroupVersionKind(describeService, v1alpha1.SchemeGroupVersion); err != nil {
return err
}

err = printer.PrintObj(describeService, cmd.OutOrStdout())
if err != nil {
return err
Expand Down
11 changes: 5 additions & 6 deletions pkg/kn/commands/service_get.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,10 @@ package commands

import (
"fmt"

"github.com/knative/client/pkg/serving"
"github.com/knative/serving/pkg/apis/serving/v1alpha1"
"github.com/spf13/cobra"
v1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/runtime/schema"
)

// NewServiceGetCommand represents 'kn service get' command
Expand All @@ -46,10 +46,9 @@ func NewServiceGetCommand(p *KnParams) *cobra.Command {
fmt.Fprintf(cmd.OutOrStdout(), "No resources found.\n")
return nil
}
service.GetObjectKind().SetGroupVersionKind(schema.GroupVersionKind{
Group: "knative.dev",
Version: "v1alpha1",
Kind: "Service"})
if err := serving.UpdateGroupVersionKind(service, v1alpha1.SchemeGroupVersion); err != nil {
return err
}

printer, err := serviceGetFlags.ToPrinter()
if err != nil {
Expand Down
31 changes: 31 additions & 0 deletions pkg/serving/schema_handling.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
package serving

import (
"errors"
"fmt"
"github.com/knative/serving/pkg/client/clientset/versioned/scheme"
"k8s.io/apimachinery/pkg/runtime"
"k8s.io/apimachinery/pkg/runtime/schema"
)

func UpdateGroupVersionKind(obj runtime.Object, gv schema.GroupVersion) error {
gvk, err := getGroupVersionKind(obj, gv)
if err != nil {
return err
}
obj.GetObjectKind().SetGroupVersionKind(*gvk)
return nil
}

func getGroupVersionKind(obj runtime.Object, gv schema.GroupVersion) (*schema.GroupVersionKind, error) {
gvks, _, err := scheme.Scheme.ObjectKinds(obj)
if err != nil {
return nil, err
}
for _, gvk := range gvks {
if gvk.GroupVersion() == gv {
return &gvk, nil
}
}
return nil, errors.New(fmt.Sprintf("no group version %s registered in %s", gv, scheme.Scheme.Name()))
}
31 changes: 31 additions & 0 deletions pkg/serving/schema_handling_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
package serving

import (
"github.com/knative/serving/pkg/apis/serving/v1alpha1"
"k8s.io/apimachinery/pkg/runtime/schema"
"testing"
)

func TestGVKUpdate(t *testing.T) {

service := v1alpha1.Service{}
err := UpdateGroupVersionKind(&service,v1alpha1.SchemeGroupVersion)
if err != nil {
t.Fatalf("cannot update GVK to a service %v",err)
}
if service.Kind != "Service" {
t.Fatalf("wrong kind '%s'", service.Kind)
}
if service.APIVersion != v1alpha1.SchemeGroupVersion.Group + "/" + v1alpha1.SchemeGroupVersion.Version {
t.Fatalf("wrong version '%s'", service.APIVersion)
}
}

func TestGVKUpdateNegative(t *testing.T) {

service := v1alpha1.Service{}
err := UpdateGroupVersionKind(&service,schema.GroupVersion{Group: "bla", Version: "blub"})
if err == nil {
t.Fatal("expect an error for an unregistered group version")
}
}
6 changes: 3 additions & 3 deletions vendor/modules.txt
Original file line number Diff line number Diff line change
Expand Up @@ -76,14 +76,14 @@ github.com/knative/pkg/configmap
github.com/knative/serving/pkg/apis/serving
github.com/knative/serving/pkg/apis/serving/v1alpha1
github.com/knative/serving/pkg/client/clientset/versioned/typed/serving/v1alpha1
github.com/knative/serving/pkg/client/clientset/versioned/scheme
github.com/knative/serving/pkg/apis/autoscaling
github.com/knative/serving/pkg/apis/networking
github.com/knative/serving/pkg/apis/networking/v1alpha1
github.com/knative/serving/pkg/apis/serving/v1beta1
github.com/knative/serving/pkg/client/clientset/versioned/scheme
github.com/knative/serving/pkg/client/clientset/versioned/typed/serving/v1alpha1/fake
github.com/knative/serving/pkg/apis/config
github.com/knative/serving/pkg/apis/autoscaling/v1alpha1
github.com/knative/serving/pkg/apis/config
# github.com/knative/test-infra v0.0.0-20190517181617-d1bb39bbca6e
github.com/knative/test-infra/scripts
# github.com/magiconair/properties v1.8.0
Expand Down Expand Up @@ -201,10 +201,10 @@ k8s.io/apimachinery/pkg/api/resource
k8s.io/apimachinery/pkg/apis/meta/v1
k8s.io/apimachinery/pkg/apis/meta/v1beta1
k8s.io/apimachinery/pkg/runtime
k8s.io/apimachinery/pkg/runtime/schema
k8s.io/apimachinery/pkg/util/duration
k8s.io/apimachinery/pkg/api/meta
k8s.io/apimachinery/pkg/util/runtime
k8s.io/apimachinery/pkg/runtime/schema
k8s.io/apimachinery/pkg/api/equality
k8s.io/apimachinery/pkg/api/validation
k8s.io/apimachinery/pkg/util/sets
Expand Down

0 comments on commit 0cbcdd9

Please sign in to comment.