mirror of https://github.com/helm/helm
Merge pull request #4078 from adshmh/2742-feat-helm-notes-command
New helm notes command to display notes provided by a release's chartpull/4579/head
commit
7da7047cee
@ -0,0 +1,77 @@
|
|||||||
|
/*
|
||||||
|
Copyright The Helm Authors.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io"
|
||||||
|
|
||||||
|
"github.com/spf13/cobra"
|
||||||
|
|
||||||
|
"k8s.io/helm/pkg/helm"
|
||||||
|
)
|
||||||
|
|
||||||
|
var getNotesHelp = `
|
||||||
|
This command shows notes provided by the chart of a named release.
|
||||||
|
`
|
||||||
|
|
||||||
|
type getNotesCmd struct {
|
||||||
|
release string
|
||||||
|
out io.Writer
|
||||||
|
client helm.Interface
|
||||||
|
version int32
|
||||||
|
}
|
||||||
|
|
||||||
|
func newGetNotesCmd(client helm.Interface, out io.Writer) *cobra.Command {
|
||||||
|
get := &getNotesCmd{
|
||||||
|
out: out,
|
||||||
|
client: client,
|
||||||
|
}
|
||||||
|
|
||||||
|
cmd := &cobra.Command{
|
||||||
|
Use: "notes [flags] RELEASE_NAME",
|
||||||
|
Short: "displays the notes of the named release",
|
||||||
|
Long: getNotesHelp,
|
||||||
|
PreRunE: func(_ *cobra.Command, _ []string) error { return setupConnection() },
|
||||||
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
if len(args) == 0 {
|
||||||
|
return errReleaseRequired
|
||||||
|
}
|
||||||
|
get.release = args[0]
|
||||||
|
if get.client == nil {
|
||||||
|
get.client = newClient()
|
||||||
|
}
|
||||||
|
return get.run()
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
cmd.PersistentFlags().Int32Var(&get.version, "revision", 0, "get the notes of the named release with revision")
|
||||||
|
|
||||||
|
return cmd
|
||||||
|
}
|
||||||
|
|
||||||
|
func (n *getNotesCmd) run() error {
|
||||||
|
res, err := n.client.ReleaseStatus(n.release, helm.StatusReleaseVersion(n.version))
|
||||||
|
if err != nil {
|
||||||
|
return prettyError(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(res.Info.Status.Notes) > 0 {
|
||||||
|
fmt.Fprintf(n.out, "NOTES:\n%s\n", res.Info.Status.Notes)
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
@ -0,0 +1,52 @@
|
|||||||
|
/*
|
||||||
|
Copyright The Helm Authors.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"io"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/spf13/cobra"
|
||||||
|
|
||||||
|
"k8s.io/helm/pkg/helm"
|
||||||
|
"k8s.io/helm/pkg/proto/hapi/release"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestGetNotesCmd(t *testing.T) {
|
||||||
|
tests := []releaseCase{
|
||||||
|
{
|
||||||
|
name: "get notes of a deployed release",
|
||||||
|
args: []string{"flummoxed-chickadee"},
|
||||||
|
expected: "NOTES:\nrelease notes\n",
|
||||||
|
rels: []*release.Release{
|
||||||
|
releaseMockWithStatus(&release.Status{
|
||||||
|
Code: release.Status_DEPLOYED,
|
||||||
|
Notes: "release notes",
|
||||||
|
}),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "get notes requires release name arg",
|
||||||
|
err: true,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
runReleaseCases(t, tests, func(c *helm.FakeClient, out io.Writer) *cobra.Command {
|
||||||
|
return newGetNotesCmd(c, out)
|
||||||
|
})
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,44 @@
|
|||||||
|
## helm get notes
|
||||||
|
|
||||||
|
displays the notes of the named release
|
||||||
|
|
||||||
|
### Synopsis
|
||||||
|
|
||||||
|
|
||||||
|
This command shows notes provided by the chart of a named release.
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
helm get notes [flags] RELEASE_NAME
|
||||||
|
```
|
||||||
|
|
||||||
|
### Options
|
||||||
|
|
||||||
|
```
|
||||||
|
-h, --help help for notes
|
||||||
|
--revision int32 get the notes of the named release with revision
|
||||||
|
--tls enable TLS for request
|
||||||
|
--tls-ca-cert string path to TLS CA certificate file (default "$HELM_HOME/ca.pem")
|
||||||
|
--tls-cert string path to TLS certificate file (default "$HELM_HOME/cert.pem")
|
||||||
|
--tls-hostname string the server name used to verify the hostname on the returned certificates from the server
|
||||||
|
--tls-key string path to TLS key file (default "$HELM_HOME/key.pem")
|
||||||
|
--tls-verify enable TLS for request and verify remote
|
||||||
|
```
|
||||||
|
|
||||||
|
### Options inherited from parent commands
|
||||||
|
|
||||||
|
```
|
||||||
|
--debug enable verbose output
|
||||||
|
--home string location of your Helm config. Overrides $HELM_HOME (default "~/.helm")
|
||||||
|
--host string address of Tiller. Overrides $HELM_HOST
|
||||||
|
--kube-context string name of the kubeconfig context to use
|
||||||
|
--kubeconfig string absolute path to the kubeconfig file to use
|
||||||
|
--tiller-connection-timeout int the duration (in seconds) Helm will wait to establish a connection to tiller (default 300)
|
||||||
|
--tiller-namespace string namespace of Tiller (default "kube-system")
|
||||||
|
```
|
||||||
|
|
||||||
|
### SEE ALSO
|
||||||
|
|
||||||
|
* [helm get](helm_get.md) - download a named release
|
||||||
|
|
||||||
|
###### Auto generated by spf13/cobra on 1-Sep-2018
|
Loading…
Reference in new issue