From 5f2d193d8af840b3e03b15047007dcde4986c05e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Krzysztof=20D=C4=85browski?= Date: Sat, 2 Mar 2024 21:41:29 +0100 Subject: [PATCH] Fix panic when listing serverless instances --- internal/show/minimal/minimal.go | 12 +++++++++--- internal/show/verbose/verbose.go | 22 ++++++++++++++++++---- 2 files changed, 27 insertions(+), 7 deletions(-) diff --git a/internal/show/minimal/minimal.go b/internal/show/minimal/minimal.go index 1ec8a2a..95011eb 100644 --- a/internal/show/minimal/minimal.go +++ b/internal/show/minimal/minimal.go @@ -11,7 +11,6 @@ package minimal import ( "bytes" "fmt" - "strconv" "strings" "github.com/lynn9388/supsub" @@ -33,13 +32,20 @@ var ( zone = n.Zones[0] } az := zone[len(zone)-2:] - cpu := strconv.Itoa(n.Compute.CPU.Cores) + + cpu := "-" + mem := "-" + if n.Compute != nil { + cpu = fmt.Sprintf("%dx", n.Compute.CPU.Cores) + mem = n.Compute.Memory.Size.String() + } + role := "" if n.ReadOnly { role = "ro" } - text := fmt.Sprintf("%2s %-17s %-6s %-15s %2sx %7s %8s %-6s %2s %s\n", az, n.Engine.ID, n.Engine.Version, n.Type, cpu, n.Compute.Memory.Size, n.Storage.Size, n.Storage.Type, role, n.Name) + text := fmt.Sprintf("%2s %-17s %-6s %-15s %3s %7s %8s %-6s %2s %s\n", az, n.Engine.ID, n.Engine.Version, n.Type, cpu, mem, n.Storage.Size, n.Storage.Type, role, n.Name) return []byte(text), nil }, ) diff --git a/internal/show/verbose/verbose.go b/internal/show/verbose/verbose.go index 5b91fea..ce5bea2 100644 --- a/internal/show/verbose/verbose.go +++ b/internal/show/verbose/verbose.go @@ -34,6 +34,13 @@ var ( // Zones ¦ eu-central-1b showConfigNode = show.FromShow[types.Node]( func(node types.Node) ([]byte, error) { + cpu := "-" + mem := "-" + if node.Compute != nil { + cpu = node.Compute.CPU.String() + mem = node.Compute.Memory.String() + } + ro := "" if node.ReadOnly { ro = " (read-only)" @@ -43,8 +50,8 @@ var ( b.WriteString(fmt.Sprintf("\n%s%s\n", node.Name, ro)) b.WriteString(fmt.Sprintf("\t%9s ¦ %s\n", "Engine", node.Engine)) b.WriteString(fmt.Sprintf("\t%9s ¦ %s\n", "Instance", node.Type)) - b.WriteString(fmt.Sprintf("\t%9s ¦ %s\n", "CPU", node.Compute.CPU)) - b.WriteString(fmt.Sprintf("\t%9s ¦ %s\n", "Memory", node.Compute.Memory)) + b.WriteString(fmt.Sprintf("\t%9s ¦ %s\n", "CPU", cpu)) + b.WriteString(fmt.Sprintf("\t%9s ¦ %s\n", "Memory", mem)) b.WriteString(fmt.Sprintf("\t%9s ¦ %s\n", "Storage", node.Storage)) b.WriteString(fmt.Sprintf("\t%9s ¦ %s\n", "Zones", strings.Join(node.Zones, ", "))) return b.Bytes(), nil @@ -126,6 +133,13 @@ var ( func(node types.StatusNode) ([]byte, error) { status := show.StatusText(node.Status) + cpu := "-" + mem := "-" + if node.Node.Compute != nil { + cpu = node.Node.Compute.CPU.String() + mem = node.Node.Compute.Memory.String() + } + ro := "" if node.Node.ReadOnly { ro = " (read-only)" @@ -135,8 +149,8 @@ var ( b.WriteString(fmt.Sprintf("%s %s%s\n", status, node.Node.Name, ro)) b.WriteString(fmt.Sprintf("%14s ¦ %s\n", "Engine", node.Node.Engine)) b.WriteString(fmt.Sprintf("%14s ¦ %s\n", "Instance", node.Node.Type)) - b.WriteString(fmt.Sprintf("%14s ¦ %s\n", "CPU", node.Node.Compute.CPU)) - b.WriteString(fmt.Sprintf("%14s ¦ %s\n", "Memory", node.Node.Compute.Memory)) + b.WriteString(fmt.Sprintf("%14s ¦ %s\n", "CPU", cpu)) + b.WriteString(fmt.Sprintf("%14s ¦ %s\n", "Memory", mem)) b.WriteString(fmt.Sprintf("%14s ¦ %s\n", "Storage", node.Node.Storage)) b.WriteString(fmt.Sprintf("%14s ¦ %s\n\n", "Zones", strings.Join(node.Node.Zones, ", "))) return b.Bytes(), nil