Merge pull request #4675 from superbrothers/fix-minikube-service

Fix `minikube service` to show error message if service has no node ports
pull/4732/head
Medya Ghazizadeh 2019-07-08 21:22:58 -07:00 committed by GitHub
commit c8b0b41a6b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 31 additions and 7 deletions

View File

@ -20,7 +20,6 @@ import (
"os"
"strings"
"github.com/olekukonko/tablewriter"
"github.com/spf13/cobra"
core "k8s.io/api/core/v1"
"k8s.io/minikube/pkg/minikube/console"
@ -59,12 +58,7 @@ var serviceListCmd = &cobra.Command{
}
table := tablewriter.NewWriter(os.Stdout)
table.SetHeader([]string{"Namespace", "Name", "URL"})
table.SetBorders(tablewriter.Border{Left: true, Top: true, Right: true, Bottom: true})
table.SetCenterSeparator("|")
table.AppendBulk(data) // Add Bulk Data
table.Render()
service.PrintServiceList(os.Stdout, data)
},
}

View File

@ -19,13 +19,16 @@ package service
import (
"bytes"
"fmt"
"io"
"net/url"
"os"
"strings"
"text/template"
"time"
"github.com/docker/machine/libmachine"
"github.com/golang/glog"
"github.com/olekukonko/tablewriter"
"github.com/pkg/browser"
"github.com/pkg/errors"
"github.com/spf13/viper"
@ -242,6 +245,17 @@ func OptionallyHTTPSFormattedURLString(bareURLString string, https bool) (string
return httpsFormattedString, isHTTPSchemedURL
}
// PrintServiceList prints a list of services as a table which has
// "Namespace", "Name" and "URL" columns to a writer
func PrintServiceList(writer io.Writer, data [][]string) {
table := tablewriter.NewWriter(writer)
table.SetHeader([]string{"Namespace", "Name", "URL"})
table.SetBorders(tablewriter.Border{Left: true, Top: true, Right: true, Bottom: true})
table.SetCenterSeparator("|")
table.AppendBulk(data)
table.Render()
}
// WaitAndMaybeOpenService waits for a service, and opens it when running
func WaitAndMaybeOpenService(api libmachine.API, namespace string, service string, urlTemplate *template.Template, urlMode bool, https bool,
wait int, interval int) error {
@ -258,6 +272,22 @@ func WaitAndMaybeOpenService(api libmachine.API, namespace string, service strin
if err != nil {
return errors.Wrap(err, "Check that minikube is running and that you have specified the correct namespace")
}
if !urlMode {
var data [][]string
if len(urls) == 0 {
data = append(data, []string{namespace, service, "No node port"})
} else {
data = append(data, []string{namespace, service, strings.Join(urls, "\n")})
}
PrintServiceList(os.Stdout, data)
}
if len(urls) == 0 {
console.OutStyle(console.Sad, "service %s/%s has no node port", namespace, service)
return nil
}
for _, bareURLString := range urls {
urlString, isHTTPSchemedURL := OptionallyHTTPSFormattedURLString(bareURLString, https)