WIP: app errors

This commit is contained in:
decentral1se 2021-12-24 01:40:39 +01:00
parent e839f100df
commit 58a24a50e1
Signed by: decentral1se
GPG Key ID: 03789458B3D0C410
1 changed files with 39 additions and 16 deletions

View File

@ -1,12 +1,14 @@
package app package app
import ( import (
"fmt" "strconv"
"strings" "strings"
abraFormatter "coopcloud.tech/abra/cli/formatter"
"coopcloud.tech/abra/cli/internal" "coopcloud.tech/abra/cli/internal"
"coopcloud.tech/abra/pkg/autocomplete" "coopcloud.tech/abra/pkg/autocomplete"
"coopcloud.tech/abra/pkg/client" "coopcloud.tech/abra/pkg/client"
stack "coopcloud.tech/abra/pkg/upstream/stack"
"github.com/docker/docker/api/types" "github.com/docker/docker/api/types"
"github.com/docker/docker/api/types/filters" "github.com/docker/docker/api/types/filters"
"github.com/sirupsen/logrus" "github.com/sirupsen/logrus"
@ -34,6 +36,15 @@ by "abra app logs <app>".
logrus.Fatal(err) logrus.Fatal(err)
} }
isDeployed, _, err := stack.IsDeployed(c.Context, cl, app.StackName())
if err != nil {
logrus.Fatal(err)
}
if !isDeployed {
logrus.Fatalf("%s is not deployed?", app.Name)
}
filters := filters.NewArgs() filters := filters.NewArgs()
filters.Add("name", app.StackName()) filters.Add("name", app.StackName())
@ -42,38 +53,50 @@ by "abra app logs <app>".
logrus.Fatal(err) logrus.Fatal(err)
} }
// tableCol := []string{"status", "error", "healthcheck", "healthcheck logs"} tableCol := []string{"app name", "status", "error", "out of memory", "restart count", "healthcheck"}
// table := abraFormatter.CreateTable(tableCol) table := abraFormatter.CreateTable(tableCol)
for _, container := range containers { for _, container := range containers {
fmt.Println("service: ", strings.Join(container.Names, "")) serviceName := getServiceName(container.Names)
containerState, err := cl.ContainerInspect(c.Context, container.ID) containerState, err := cl.ContainerInspect(c.Context, container.ID)
if err != nil { if err != nil {
logrus.Fatal(err) logrus.Fatal(err)
} }
fmt.Println("restarted no. times: ", containerState.RestartCount) errMsg := "N/A"
fmt.Println("status: ", containerState.State.Status) hcStat := "N/A"
fmt.Println("oom killed: ", containerState.State.OOMKilled) var hcLogs []string
fmt.Println("error: ", containerState.State.Error)
if containerState.State.Health != nil { if containerState.State.Health != nil {
fmt.Println("healthcheck status: ", containerState.State.Health.Status) hcStat = containerState.State.Health.Status
fmt.Println("failed no. times: ", containerState.State.Health.FailingStreak)
for _, log := range containerState.State.Health.Log { for _, log := range containerState.State.Health.Log {
fmt.Println("output: ", log.Output) hcLogs = append(hcLogs, log.Output)
} }
} }
fmt.Println("---") if containerState.State.Error != "" {
errMsg = containerState.State.Error
// table.Append([]string{containerState.State.Status, containerState.State.Error, healthCheckState, healthCheckLogs}) }
table.Append([]string{
serviceName,
containerState.State.Status,
errMsg,
strconv.FormatBool(containerState.State.OOMKilled),
strconv.Itoa(containerState.RestartCount),
hcStat,
strings.Join(hcLogs, "\n"),
})
} }
// table.Render() table.Render()
return nil return nil
}, },
} }
func getServiceName(names []string) string {
containerName := strings.Join(names, " ")
trimmed := strings.TrimPrefix(containerName, "/")
return strings.Split(trimmed, ".")[0]
}