k9s/internal/resource/no_test.go

148 lines
3.3 KiB
Go

package resource_test
import (
"testing"
"github.com/derailed/k9s/internal/k8s"
"github.com/derailed/k9s/internal/resource"
m "github.com/petergtz/pegomock"
"github.com/stretchr/testify/assert"
v1 "k8s.io/api/core/v1"
res "k8s.io/apimachinery/pkg/api/resource"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
mv1beta1 "k8s.io/metrics/pkg/apis/metrics/v1beta1"
v1beta1 "k8s.io/metrics/pkg/apis/metrics/v1beta1"
)
func TestNodeListAccess(t *testing.T) {
ns := "blee"
l := resource.NewNodeList(resource.AllNamespaces)
l.SetNamespace(ns)
assert.Equal(t, resource.NotNamespaced, l.GetNamespace())
assert.Equal(t, "no", l.GetName())
for _, a := range []int{resource.ViewAccess} {
assert.True(t, l.Access(a))
}
}
func TestNodeFields(t *testing.T) {
r := newNode().Fields("blee")
assert.Equal(t, "fred", r[0])
}
func TestNodeMarshal(t *testing.T) {
setup(t)
mx := NewMockMetricsServer()
// m.When(mx.NodesMetrics([]v1.Node{*k8sNode()})).
// ThenReturn(map[string]k8s.RawMetric{"fred": {}}, nil)
ca := NewMockCaller()
m.When(ca.Get("blee", "fred")).ThenReturn(k8sNode(), nil)
cm := resource.NewNodeWithArgs(ca, mx)
ma, err := cm.Marshal("blee/fred")
ca.VerifyWasCalledOnce().Get("blee", "fred")
assert.Nil(t, err)
assert.Equal(t, noYaml(), ma)
}
func TestNodeListData(t *testing.T) {
setup(t)
mockServer := NewMockMetricsServer()
m.When(mockServer.HasMetrics()).ThenReturn(true)
m.When(mockServer.FetchNodesMetrics()).
ThenReturn([]mv1beta1.NodeMetrics{makeMxNode("fred", "100m", "100Mi")}, nil)
ca := NewMockCaller()
m.When(ca.List("-")).ThenReturn(k8s.Collection{*k8sNode()}, nil)
l := resource.NewNodeListWithArgs("", resource.NewNodeWithArgs(ca, mockServer))
// Make sure we can get deltas!
for i := 0; i < 2; i++ {
err := l.Reconcile()
assert.Nil(t, err)
}
ca.VerifyWasCalled(m.Times(2)).List("-")
td := l.Data()
assert.Equal(t, 1, len(td.Rows))
assert.Equal(t, resource.NotNamespaced, l.GetNamespace())
row, ok := td.Rows["fred"]
assert.True(t, ok)
assert.Equal(t, 12, len(row.Deltas))
for _, d := range row.Deltas {
assert.Equal(t, "", d)
}
assert.Equal(t, resource.Row{"fred"}, row.Fields[:1])
}
// Helpers...
func k8sNode() *v1.Node {
return &v1.Node{
ObjectMeta: metav1.ObjectMeta{
Name: "fred",
CreationTimestamp: metav1.Time{Time: testTime()},
},
Spec: v1.NodeSpec{},
Status: v1.NodeStatus{
Addresses: []v1.NodeAddress{
{Address: "1.1.1.1"},
},
},
}
}
func makeMxNode(name, cpu, mem string) mv1beta1.NodeMetrics {
return v1beta1.NodeMetrics{
ObjectMeta: metav1.ObjectMeta{
Name: name,
},
Usage: makeRes(cpu, mem),
}
}
func makeRes(c, m string) v1.ResourceList {
cpu, _ := res.ParseQuantity(c)
mem, _ := res.ParseQuantity(m)
return v1.ResourceList{
v1.ResourceCPU: cpu,
v1.ResourceMemory: mem,
}
}
func newNode() resource.Columnar {
return resource.NewNode().NewInstance(k8sNode())
}
func noYaml() string {
return `apiVersion: v1
kind: Node
metadata:
creationTimestamp: "2018-12-14T17:36:43Z"
name: fred
spec: {}
status:
addresses:
- address: 1.1.1.1
type: ""
daemonEndpoints:
kubeletEndpoint:
Port: 0
nodeInfo:
architecture: ""
bootID: ""
containerRuntimeVersion: ""
kernelVersion: ""
kubeProxyVersion: ""
kubeletVersion: ""
machineID: ""
operatingSystem: ""
osImage: ""
systemUUID: ""
`
}