mirror of https://github.com/portainer/portainer
feat: improve diagnostics stability - release 2.27 (#398)
parent
2c1156da75
commit
d1f48ce043
|
@ -1,6 +1,7 @@
|
||||||
package endpoints
|
package endpoints
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/hashicorp/go-version"
|
||||||
portainer "github.com/portainer/portainer/api"
|
portainer "github.com/portainer/portainer/api"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -15,6 +16,11 @@ func IsEdgeEndpoint(endpoint *portainer.Endpoint) bool {
|
||||||
return endpoint.Type == portainer.EdgeAgentOnDockerEnvironment || endpoint.Type == portainer.EdgeAgentOnKubernetesEnvironment
|
return endpoint.Type == portainer.EdgeAgentOnDockerEnvironment || endpoint.Type == portainer.EdgeAgentOnKubernetesEnvironment
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// IsStandardEdgeEndpoint returns true if this is a standard Edge endpoint and not in async mode on either Docker or Kubernetes
|
||||||
|
func IsStandardEdgeEndpoint(endpoint *portainer.Endpoint) bool {
|
||||||
|
return (endpoint.Type == portainer.EdgeAgentOnDockerEnvironment || endpoint.Type == portainer.EdgeAgentOnKubernetesEnvironment) && !endpoint.Edge.AsyncMode
|
||||||
|
}
|
||||||
|
|
||||||
// IsAssociatedEdgeEndpoint returns true if the environment is an Edge environment
|
// IsAssociatedEdgeEndpoint returns true if the environment is an Edge environment
|
||||||
// and has a set EdgeID and UserTrusted is true.
|
// and has a set EdgeID and UserTrusted is true.
|
||||||
func IsAssociatedEdgeEndpoint(endpoint *portainer.Endpoint) bool {
|
func IsAssociatedEdgeEndpoint(endpoint *portainer.Endpoint) bool {
|
||||||
|
@ -26,3 +32,11 @@ func IsAssociatedEdgeEndpoint(endpoint *portainer.Endpoint) bool {
|
||||||
func HasDirectConnectivity(endpoint *portainer.Endpoint) bool {
|
func HasDirectConnectivity(endpoint *portainer.Endpoint) bool {
|
||||||
return !IsEdgeEndpoint(endpoint) || (IsAssociatedEdgeEndpoint(endpoint) && !endpoint.Edge.AsyncMode)
|
return !IsEdgeEndpoint(endpoint) || (IsAssociatedEdgeEndpoint(endpoint) && !endpoint.Edge.AsyncMode)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// IsNewerThan225 returns true if the agent version is newer than 2.25.0
|
||||||
|
// this is used to check if the agent is compatible with the new diagnostics feature
|
||||||
|
func IsNewerThan225(agentVersion string) bool {
|
||||||
|
v1, _ := version.NewVersion(agentVersion)
|
||||||
|
v2, _ := version.NewVersion("2.25.0")
|
||||||
|
return v1.GreaterThanOrEqual(v2)
|
||||||
|
}
|
||||||
|
|
|
@ -202,3 +202,61 @@ func TestHasDirectConnectivity(t *testing.T) {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestIsStandardEdgeEndpoint(t *testing.T) {
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
endpoint *portainer.Endpoint
|
||||||
|
expected bool
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
name: "StandardEdgeEndpoint",
|
||||||
|
endpoint: &portainer.Endpoint{
|
||||||
|
Type: portainer.EdgeAgentOnDockerEnvironment,
|
||||||
|
Edge: portainer.EnvironmentEdgeSettings{AsyncMode: false},
|
||||||
|
},
|
||||||
|
expected: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "AsyncEdgeEndpoint",
|
||||||
|
endpoint: &portainer.Endpoint{
|
||||||
|
Type: portainer.EdgeAgentOnDockerEnvironment,
|
||||||
|
Edge: portainer.EnvironmentEdgeSettings{AsyncMode: true},
|
||||||
|
},
|
||||||
|
expected: false,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, tt := range tests {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
result := IsStandardEdgeEndpoint(tt.endpoint)
|
||||||
|
assert.Equal(t, tt.expected, result)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestIsNewerThan225(t *testing.T) {
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
version string
|
||||||
|
expected bool
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
name: "NewerThan225",
|
||||||
|
version: "2.25.1",
|
||||||
|
expected: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "OlderThan225",
|
||||||
|
version: "2.24.0",
|
||||||
|
expected: false,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, tt := range tests {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
result := IsNewerThan225(tt.version)
|
||||||
|
assert.Equal(t, tt.expected, result)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -1 +0,0 @@
|
||||||
package snapshot
|
|
|
@ -1 +1,44 @@
|
||||||
package snapshot
|
package snapshot
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
portainer "github.com/portainer/portainer/api"
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
||||||
|
kfake "k8s.io/client-go/kubernetes/fake"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestCreateKubernetesSnapshot(t *testing.T) {
|
||||||
|
cli := kfake.NewSimpleClientset()
|
||||||
|
kubernetesSnapshot := &portainer.KubernetesSnapshot{}
|
||||||
|
|
||||||
|
serverInfo, err := cli.Discovery().ServerVersion()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("error getting the kubernetesserver version: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
kubernetesSnapshot.KubernetesVersion = serverInfo.GitVersion
|
||||||
|
require.Equal(t, kubernetesSnapshot.KubernetesVersion, serverInfo.GitVersion)
|
||||||
|
|
||||||
|
nodeList, err := cli.CoreV1().Nodes().List(context.TODO(), metav1.ListOptions{})
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("error listing kubernetes nodes: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
var totalCPUs, totalMemory int64
|
||||||
|
for _, node := range nodeList.Items {
|
||||||
|
totalCPUs += node.Status.Capacity.Cpu().Value()
|
||||||
|
totalMemory += node.Status.Capacity.Memory().Value()
|
||||||
|
}
|
||||||
|
|
||||||
|
kubernetesSnapshot.TotalCPU = totalCPUs
|
||||||
|
kubernetesSnapshot.TotalMemory = totalMemory
|
||||||
|
kubernetesSnapshot.NodeCount = len(nodeList.Items)
|
||||||
|
require.Equal(t, kubernetesSnapshot.TotalCPU, totalCPUs)
|
||||||
|
require.Equal(t, kubernetesSnapshot.TotalMemory, totalMemory)
|
||||||
|
require.Equal(t, kubernetesSnapshot.NodeCount, len(nodeList.Items))
|
||||||
|
|
||||||
|
t.Logf("Kubernetes snapshot: %+v", kubernetesSnapshot)
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue