219 lines
5.5 KiB
Go
219 lines
5.5 KiB
Go
package resource_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/k8sland/k9s/resource"
|
|
"github.com/k8sland/k9s/resource/k8s"
|
|
m "github.com/petergtz/pegomock"
|
|
"github.com/stretchr/testify/assert"
|
|
batchv1beta1 "k8s.io/api/batch/v1beta1"
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
|
)
|
|
|
|
func TestCronJobListAccess(t *testing.T) {
|
|
ns := "blee"
|
|
l := resource.NewCronJobList(resource.AllNamespaces)
|
|
l.SetNamespace(ns)
|
|
|
|
assert.Equal(t, "blee", l.GetNamespace())
|
|
assert.Equal(t, "job", l.GetName())
|
|
for _, a := range []int{resource.GetAccess, resource.ListAccess, resource.DeleteAccess, resource.ViewAccess, resource.EditAccess} {
|
|
assert.True(t, l.Access(a))
|
|
}
|
|
}
|
|
|
|
func TestCronJobHeader(t *testing.T) {
|
|
assert.Equal(t, resource.Row{"NAME", "SCHEDULE", "SUSPEND", "ACTIVE", "LAST_SCHEDULE", "AGE"}, newCronJob().Header("default"))
|
|
}
|
|
|
|
func TestCronJobFields(t *testing.T) {
|
|
r := newCronJob().Fields("blee")
|
|
assert.Equal(t, "fred", r[0])
|
|
}
|
|
|
|
func TestCronJobMarshal(t *testing.T) {
|
|
setup(t)
|
|
|
|
ca := NewMockCaller()
|
|
m.When(ca.Get("blee", "fred")).ThenReturn(k8sCronJob(), nil)
|
|
|
|
cm := resource.NewCronJobWithArgs(ca)
|
|
ma, err := cm.Marshal("blee/fred")
|
|
ca.VerifyWasCalledOnce().Get("blee", "fred")
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, cronjobYaml(), ma)
|
|
}
|
|
|
|
func TestCronJobListData(t *testing.T) {
|
|
setup(t)
|
|
|
|
ca := NewMockCaller()
|
|
m.When(ca.List(resource.NotNamespaced)).ThenReturn(k8s.Collection{*k8sCronJob()}, nil)
|
|
|
|
l := resource.NewCronJobListWithArgs("-", resource.NewCronJobWithArgs(ca))
|
|
// 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(resource.NotNamespaced)
|
|
td := l.Data()
|
|
assert.Equal(t, 1, len(td.Rows))
|
|
assert.Equal(t, resource.NotNamespaced, l.GetNamespace())
|
|
assert.False(t, l.HasXRay())
|
|
row := td.Rows["blee/fred"]
|
|
assert.Equal(t, 6, len(row.Deltas))
|
|
for _, d := range row.Deltas {
|
|
assert.Equal(t, "", d)
|
|
}
|
|
assert.Equal(t, resource.Row{"fred"}, row.Fields[:1])
|
|
}
|
|
|
|
func TestCronJobListDescribe(t *testing.T) {
|
|
setup(t)
|
|
|
|
ca := NewMockCaller()
|
|
m.When(ca.Get("blee", "fred")).ThenReturn(k8sCronJob(), nil)
|
|
l := resource.NewCronJobListWithArgs("blee", resource.NewCronJobWithArgs(ca))
|
|
props, err := l.Describe("blee/fred")
|
|
|
|
ca.VerifyWasCalledOnce().Get("blee", "fred")
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, 0, len(props))
|
|
}
|
|
|
|
// Helpers...
|
|
|
|
func k8sCronJob() *batchv1beta1.CronJob {
|
|
var b bool
|
|
return &batchv1beta1.CronJob{
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
Namespace: "blee",
|
|
Name: "fred",
|
|
CreationTimestamp: metav1.Time{Time: testTime()},
|
|
},
|
|
Spec: batchv1beta1.CronJobSpec{
|
|
Schedule: "*/1 * * * *",
|
|
Suspend: &b,
|
|
},
|
|
Status: batchv1beta1.CronJobStatus{
|
|
LastScheduleTime: &metav1.Time{Time: testTime()},
|
|
},
|
|
}
|
|
}
|
|
|
|
func newCronJob() resource.Columnar {
|
|
return resource.NewCronJob().NewInstance(k8sCronJob())
|
|
}
|
|
|
|
func cronjobYaml() string {
|
|
return `typemeta:
|
|
kind: CronJob
|
|
apiversion: extensions/batchv1beta1
|
|
objectmeta:
|
|
name: fred
|
|
generatename: ""
|
|
namespace: blee
|
|
selflink: ""
|
|
uid: ""
|
|
resourceversion: ""
|
|
generation: 0
|
|
creationtimestamp: "2018-12-14T10:36:43.326972-07:00"
|
|
deletiontimestamp: null
|
|
deletiongraceperiodseconds: null
|
|
labels: {}
|
|
annotations: {}
|
|
ownerreferences: []
|
|
initializers: null
|
|
finalizers: []
|
|
clustername: ""
|
|
spec:
|
|
schedule: '*/1 * * * *'
|
|
startingdeadlineseconds: null
|
|
concurrencypolicy: ""
|
|
suspend: false
|
|
jobtemplate:
|
|
objectmeta:
|
|
name: ""
|
|
generatename: ""
|
|
namespace: ""
|
|
selflink: ""
|
|
uid: ""
|
|
resourceversion: ""
|
|
generation: 0
|
|
creationtimestamp: "0001-01-01T00:00:00Z"
|
|
deletiontimestamp: null
|
|
deletiongraceperiodseconds: null
|
|
labels: {}
|
|
annotations: {}
|
|
ownerreferences: []
|
|
initializers: null
|
|
finalizers: []
|
|
clustername: ""
|
|
spec:
|
|
parallelism: null
|
|
completions: null
|
|
activedeadlineseconds: null
|
|
backofflimit: null
|
|
selector: null
|
|
manualselector: null
|
|
template:
|
|
objectmeta:
|
|
name: ""
|
|
generatename: ""
|
|
namespace: ""
|
|
selflink: ""
|
|
uid: ""
|
|
resourceversion: ""
|
|
generation: 0
|
|
creationtimestamp: "0001-01-01T00:00:00Z"
|
|
deletiontimestamp: null
|
|
deletiongraceperiodseconds: null
|
|
labels: {}
|
|
annotations: {}
|
|
ownerreferences: []
|
|
initializers: null
|
|
finalizers: []
|
|
clustername: ""
|
|
spec:
|
|
volumes: []
|
|
initcontainers: []
|
|
containers: []
|
|
restartpolicy: ""
|
|
terminationgraceperiodseconds: null
|
|
activedeadlineseconds: null
|
|
dnspolicy: ""
|
|
nodeselector: {}
|
|
serviceaccountname: ""
|
|
deprecatedserviceaccount: ""
|
|
automountserviceaccounttoken: null
|
|
nodename: ""
|
|
hostnetwork: false
|
|
hostpid: false
|
|
hostipc: false
|
|
shareprocessnamespace: null
|
|
securitycontext: null
|
|
imagepullsecrets: []
|
|
hostname: ""
|
|
subdomain: ""
|
|
affinity: null
|
|
schedulername: ""
|
|
tolerations: []
|
|
hostaliases: []
|
|
priorityclassname: ""
|
|
priority: null
|
|
dnsconfig: null
|
|
readinessgates: []
|
|
runtimeclassname: null
|
|
enableservicelinks: null
|
|
ttlsecondsafterfinished: null
|
|
successfuljobshistorylimit: null
|
|
failedjobshistorylimit: null
|
|
status:
|
|
active: []
|
|
lastscheduletime: "2018-12-14T10:36:43.326972-07:00"
|
|
`
|
|
}
|