mirror of https://github.com/knative/client.git
Fix exit code on service delete and revision delete (#971)
* Fix exit code 0 upon service delete * Mentioned bug fix in CHANGELOG.adoc * Add error check test for service not found * Fix for kn revision delete failure exit code and add test cases * Testing changes in test cases for failure in intergration tests * Fix test case error causing integration test failure
This commit is contained in:
parent
7f2de9eb9d
commit
980a6a9469
|
|
@ -34,6 +34,10 @@
|
||||||
| Fix Missing NAMESPACE column header for 'kn source list -A'
|
| Fix Missing NAMESPACE column header for 'kn source list -A'
|
||||||
| https://github.com/knative/client/pull/951[#951]
|
| https://github.com/knative/client/pull/951[#951]
|
||||||
|
|
||||||
|
| 🐛
|
||||||
|
| Fix exit code for `kn service delete` and `kn revision delete` failures
|
||||||
|
| https://github.com/knative/client/pull/971[#971]
|
||||||
|
|
||||||
|===
|
|===
|
||||||
|
|
||||||
## v0.16.0 (2020-07-14)
|
## v0.16.0 (2020-07-14)
|
||||||
|
|
|
||||||
|
|
@ -60,11 +60,11 @@ func RevisionMultipleDelete(r *KnRunResultCollector, existRevision1, existRevisi
|
||||||
assert.Check(r.T(), strings.Contains(out.Stdout, existRevision2), "Required revision2 does not exist")
|
assert.Check(r.T(), strings.Contains(out.Stdout, existRevision2), "Required revision2 does not exist")
|
||||||
|
|
||||||
out = r.KnTest().Kn().Run("revision", "delete", existRevision1, existRevision2, nonexistRevision)
|
out = r.KnTest().Kn().Run("revision", "delete", existRevision1, existRevision2, nonexistRevision)
|
||||||
r.AssertNoError(out)
|
r.AssertError(out)
|
||||||
|
|
||||||
assert.Check(r.T(), util.ContainsAll(out.Stdout, "Revision", existRevision1, "deleted", "namespace", r.KnTest().Kn().Namespace()), "Failed to get 'deleted' first revision message")
|
assert.Check(r.T(), util.ContainsAll(out.Stdout, "Revision", existRevision1, "deleted", "namespace", r.KnTest().Kn().Namespace()), "Failed to get 'deleted' first revision message")
|
||||||
assert.Check(r.T(), util.ContainsAll(out.Stdout, "Revision", existRevision2, "deleted", "namespace", r.KnTest().Kn().Namespace()), "Failed to get 'deleted' second revision message")
|
assert.Check(r.T(), util.ContainsAll(out.Stdout, "Revision", existRevision2, "deleted", "namespace", r.KnTest().Kn().Namespace()), "Failed to get 'deleted' second revision message")
|
||||||
assert.Check(r.T(), util.ContainsAll(out.Stdout, "revisions.serving.knative.dev", nonexistRevision, "not found"), "Failed to get 'not found' error")
|
assert.Check(r.T(), util.ContainsAll(out.Stderr, "revisions.serving.knative.dev", nonexistRevision, "not found"), "Failed to get 'not found' error")
|
||||||
}
|
}
|
||||||
|
|
||||||
// RevisionDescribeWithPrintFlags verifies describing given revision using print flag '--output=name'
|
// RevisionDescribeWithPrintFlags verifies describing given revision using print flag '--output=name'
|
||||||
|
|
|
||||||
|
|
@ -17,6 +17,7 @@ package revision
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
|
|
@ -47,6 +48,7 @@ func NewRevisionDeleteCommand(p *commands.KnParams) *cobra.Command {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
errs := []string{}
|
||||||
for _, name := range args {
|
for _, name := range args {
|
||||||
timeout := time.Duration(0)
|
timeout := time.Duration(0)
|
||||||
if waitFlags.Wait {
|
if waitFlags.Wait {
|
||||||
|
|
@ -54,11 +56,14 @@ func NewRevisionDeleteCommand(p *commands.KnParams) *cobra.Command {
|
||||||
}
|
}
|
||||||
err = client.DeleteRevision(name, timeout)
|
err = client.DeleteRevision(name, timeout)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Fprintf(cmd.OutOrStdout(), "%s.\n", err)
|
errs = append(errs, err.Error())
|
||||||
} else {
|
} else {
|
||||||
fmt.Fprintf(cmd.OutOrStdout(), "Revision '%s' deleted in namespace '%s'.\n", name, namespace)
|
fmt.Fprintf(cmd.OutOrStdout(), "Revision '%s' deleted in namespace '%s'.\n", name, namespace)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if len(errs) > 0 {
|
||||||
|
return errors.New("Error: " + strings.Join(errs, "\nError: "))
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -25,7 +25,9 @@ import (
|
||||||
clienttesting "k8s.io/client-go/testing"
|
clienttesting "k8s.io/client-go/testing"
|
||||||
|
|
||||||
"knative.dev/client/pkg/kn/commands"
|
"knative.dev/client/pkg/kn/commands"
|
||||||
|
clientservingv1 "knative.dev/client/pkg/serving/v1"
|
||||||
"knative.dev/client/pkg/util"
|
"knative.dev/client/pkg/util"
|
||||||
|
"knative.dev/client/pkg/util/mock"
|
||||||
"knative.dev/client/pkg/wait"
|
"knative.dev/client/pkg/wait"
|
||||||
servingv1 "knative.dev/serving/pkg/apis/serving/v1"
|
servingv1 "knative.dev/serving/pkg/apis/serving/v1"
|
||||||
)
|
)
|
||||||
|
|
@ -102,3 +104,23 @@ func getRevisionDeleteEvents(name string) []watch.Event {
|
||||||
{watch.Deleted, &servingv1.Revision{ObjectMeta: metav1.ObjectMeta{Name: name}}},
|
{watch.Deleted, &servingv1.Revision{ObjectMeta: metav1.ObjectMeta{Name: name}}},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestRevisionDeleteCheckErrorForNotFoundRevisionsMock(t *testing.T) {
|
||||||
|
// New mock client
|
||||||
|
client := clientservingv1.NewMockKnServiceClient(t)
|
||||||
|
|
||||||
|
// Recording:
|
||||||
|
r := client.Recorder()
|
||||||
|
|
||||||
|
r.DeleteRevision("foo", mock.Any(), nil)
|
||||||
|
r.DeleteRevision("bar", mock.Any(), errors.New("revisions.serving.knative.dev \"bar\" not found."))
|
||||||
|
r.DeleteRevision("baz", mock.Any(), errors.New("revisions.serving.knative.dev \"baz\" not found."))
|
||||||
|
|
||||||
|
output, err := executeRevisionCommand(client, "delete", "foo", "bar", "baz")
|
||||||
|
if err == nil {
|
||||||
|
t.Fatal("Expected revision not found error, returned nil")
|
||||||
|
}
|
||||||
|
assert.Assert(t, util.ContainsAll(output, "'foo' deleted", "\"bar\" not found", "\"baz\" not found"))
|
||||||
|
|
||||||
|
r.Validate()
|
||||||
|
}
|
||||||
|
|
|
||||||
|
|
@ -15,15 +15,24 @@
|
||||||
package revision
|
package revision
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bytes"
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"github.com/spf13/cobra"
|
||||||
"gotest.tools/assert"
|
"gotest.tools/assert"
|
||||||
|
"k8s.io/client-go/tools/clientcmd"
|
||||||
|
knflags "knative.dev/client/pkg/kn/flags"
|
||||||
servingv1 "knative.dev/serving/pkg/apis/serving/v1"
|
servingv1 "knative.dev/serving/pkg/apis/serving/v1"
|
||||||
|
|
||||||
|
"knative.dev/client/pkg/kn/commands"
|
||||||
|
clientservingv1 "knative.dev/client/pkg/serving/v1"
|
||||||
"knative.dev/client/pkg/util"
|
"knative.dev/client/pkg/util"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// Helper methods
|
||||||
|
var blankConfig clientcmd.ClientConfig
|
||||||
|
|
||||||
func TestExtractTrafficAndTag(t *testing.T) {
|
func TestExtractTrafficAndTag(t *testing.T) {
|
||||||
|
|
||||||
service := &servingv1.Service{
|
service := &servingv1.Service{
|
||||||
|
|
@ -52,3 +61,23 @@ func createTarget(rev string, percent int64, tag string) servingv1.TrafficTarget
|
||||||
Percent: &percent,
|
Percent: &percent,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func executeRevisionCommand(client clientservingv1.KnServingClient, args ...string) (string, error) {
|
||||||
|
knParams := &commands.KnParams{}
|
||||||
|
knParams.ClientConfig = blankConfig
|
||||||
|
|
||||||
|
output := new(bytes.Buffer)
|
||||||
|
knParams.Output = output
|
||||||
|
knParams.NewServingClient = func(namespace string) (clientservingv1.KnServingClient, error) {
|
||||||
|
return client, nil
|
||||||
|
}
|
||||||
|
cmd := NewRevisionCommand(knParams)
|
||||||
|
cmd.SetArgs(args)
|
||||||
|
cmd.SetOutput(output)
|
||||||
|
|
||||||
|
cmd.PersistentPreRunE = func(cmd *cobra.Command, args []string) error {
|
||||||
|
return knflags.ReconcileBoolFlags(cmd.Flags())
|
||||||
|
}
|
||||||
|
err := cmd.Execute()
|
||||||
|
return output.String(), err
|
||||||
|
}
|
||||||
|
|
|
||||||
|
|
@ -17,6 +17,7 @@ package service
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
|
|
@ -77,6 +78,7 @@ func NewServiceDeleteCommand(p *commands.KnParams) *cobra.Command {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
errs := []string{}
|
||||||
for _, name := range args {
|
for _, name := range args {
|
||||||
timeout := time.Duration(0)
|
timeout := time.Duration(0)
|
||||||
if waitFlags.Wait {
|
if waitFlags.Wait {
|
||||||
|
|
@ -84,11 +86,14 @@ func NewServiceDeleteCommand(p *commands.KnParams) *cobra.Command {
|
||||||
}
|
}
|
||||||
err = client.DeleteService(name, timeout)
|
err = client.DeleteService(name, timeout)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Fprintf(cmd.OutOrStdout(), "%s.\n", err)
|
errs = append(errs, err.Error())
|
||||||
} else {
|
} else {
|
||||||
fmt.Fprintf(cmd.OutOrStdout(), "Service '%s' successfully deleted in namespace '%s'.\n", name, namespace)
|
fmt.Fprintf(cmd.OutOrStdout(), "Service '%s' successfully deleted in namespace '%s'.\n", name, namespace)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if len(errs) > 0 {
|
||||||
|
return errors.New("Error: " + strings.Join(errs, "\nError: "))
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -15,6 +15,7 @@
|
||||||
package service
|
package service
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"gotest.tools/assert"
|
"gotest.tools/assert"
|
||||||
|
|
@ -141,3 +142,23 @@ func TestServiceDeleteNoSvcNameMock(t *testing.T) {
|
||||||
r.Validate()
|
r.Validate()
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestServiceDeleteCheckErrorForNotFoundServicesMock(t *testing.T) {
|
||||||
|
// New mock client
|
||||||
|
client := clientservingv1.NewMockKnServiceClient(t)
|
||||||
|
|
||||||
|
// Recording:
|
||||||
|
r := client.Recorder()
|
||||||
|
|
||||||
|
r.DeleteService("foo", mock.Any(), nil)
|
||||||
|
r.DeleteService("bar", mock.Any(), errors.New("services.serving.knative.dev \"bar\" not found."))
|
||||||
|
r.DeleteService("baz", mock.Any(), errors.New("services.serving.knative.dev \"baz\" not found."))
|
||||||
|
|
||||||
|
output, err := executeServiceCommand(client, "delete", "foo", "bar", "baz")
|
||||||
|
if err == nil {
|
||||||
|
t.Fatal("Expected service not found error, returned nil")
|
||||||
|
}
|
||||||
|
assert.Assert(t, util.ContainsAll(output, "'foo' successfully deleted", "\"bar\" not found", "\"baz\" not found"))
|
||||||
|
|
||||||
|
r.Validate()
|
||||||
|
}
|
||||||
|
|
|
||||||
|
|
@ -125,8 +125,8 @@ func serviceDeleteNonexistent(r *test.KnRunResultCollector, serviceName string)
|
||||||
assert.Check(r.T(), !strings.Contains(out.Stdout, serviceName), "The service exists")
|
assert.Check(r.T(), !strings.Contains(out.Stdout, serviceName), "The service exists")
|
||||||
|
|
||||||
out = r.KnTest().Kn().Run("service", "delete", serviceName)
|
out = r.KnTest().Kn().Run("service", "delete", serviceName)
|
||||||
r.AssertNoError(out)
|
r.AssertError(out)
|
||||||
assert.Check(r.T(), util.ContainsAll(out.Stdout, "hello", "not found"), "Failed to get 'not found' error")
|
assert.Check(r.T(), util.ContainsAll(out.Stderr, "hello", "not found"), "Failed to get 'not found' error")
|
||||||
}
|
}
|
||||||
|
|
||||||
func serviceMultipleDelete(r *test.KnRunResultCollector, existService, nonexistService string) {
|
func serviceMultipleDelete(r *test.KnRunResultCollector, existService, nonexistService string) {
|
||||||
|
|
@ -136,12 +136,12 @@ func serviceMultipleDelete(r *test.KnRunResultCollector, existService, nonexistS
|
||||||
assert.Check(r.T(), !strings.Contains(out.Stdout, nonexistService), "The service", nonexistService, " exists (but is supposed to be not)")
|
assert.Check(r.T(), !strings.Contains(out.Stdout, nonexistService), "The service", nonexistService, " exists (but is supposed to be not)")
|
||||||
|
|
||||||
out = r.KnTest().Kn().Run("service", "delete", existService, nonexistService)
|
out = r.KnTest().Kn().Run("service", "delete", existService, nonexistService)
|
||||||
r.AssertNoError(out)
|
r.AssertError(out)
|
||||||
|
|
||||||
expectedSuccess := fmt.Sprintf(`Service '%s' successfully deleted in namespace '%s'.`, existService, r.KnTest().Kn().Namespace())
|
expectedSuccess := fmt.Sprintf(`Service '%s' successfully deleted in namespace '%s'.`, existService, r.KnTest().Kn().Namespace())
|
||||||
expectedErr := fmt.Sprintf(`services.serving.knative.dev "%s" not found`, nonexistService)
|
expectedErr := fmt.Sprintf(`services.serving.knative.dev "%s" not found`, nonexistService)
|
||||||
assert.Check(r.T(), strings.Contains(out.Stdout, expectedSuccess), "Failed to get 'successfully deleted' message")
|
assert.Check(r.T(), strings.Contains(out.Stdout, expectedSuccess), "Failed to get 'successfully deleted' message")
|
||||||
assert.Check(r.T(), strings.Contains(out.Stdout, expectedErr), "Failed to get 'not found' error")
|
assert.Check(r.T(), strings.Contains(out.Stderr, expectedErr), "Failed to get 'not found' error")
|
||||||
}
|
}
|
||||||
|
|
||||||
func serviceUntagTagThatDoesNotExist(r *test.KnRunResultCollector, serviceName string) {
|
func serviceUntagTagThatDoesNotExist(r *test.KnRunResultCollector, serviceName string) {
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue