k9s/internal/resource/cronjob_test.go

133 lines
3.6 KiB
Go

package resource_test
// BOZO!!
// import (
// "testing"
// "github.com/derailed/k9s/internal/k8s"
// "github.com/derailed/k9s/internal/resource"
// 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 NewCronJobListWithArgs(ns string, r *resource.CronJob) resource.List {
// return resource.NewList(ns, "cj", r, resource.AllVerbsAccess|resource.DescribeAccess)
// }
// func NewCronJobWithArgs(conn k8s.Connection, res resource.Cruder) *resource.CronJob {
// r := &resource.CronJob{Base: resource.NewBase(conn, res)}
// r.Factory = r
// return r
// }
// func TestCronJobListAccess(t *testing.T) {
// mc := NewMockConnection()
// mr := NewMockCruder()
// ns := "blee"
// r := NewCronJobWithArgs(mc, mr)
// l := NewCronJobListWithArgs(resource.AllNamespaces, r)
// l.SetNamespace(ns)
// assert.Equal(t, ns, l.GetNamespace())
// assert.Equal(t, "cj", l.GetName())
// for _, a := range []int{resource.GetAccess, resource.ListAccess, resource.DeleteAccess, resource.ViewAccess, resource.EditAccess} {
// assert.True(t, l.Access(a))
// }
// }
// func TestCronJobFields(t *testing.T) {
// r := newCronJob().Fields("blee")
// assert.Equal(t, "fred", r[0])
// }
// func TestCronJobMarshal(t *testing.T) {
// mc := NewMockConnection()
// mr := NewMockCruder()
// m.When(mr.Get("blee", "fred")).ThenReturn(k8sCronJob(), nil)
// cm := NewCronJobWithArgs(mc, mr)
// ma, err := cm.Marshal("blee/fred")
// mr.VerifyWasCalledOnce().Get("blee", "fred")
// assert.Nil(t, err)
// assert.Equal(t, cronjobYaml(), ma)
// }
// // BOZO!!
// // func TestCronJobListData(t *testing.T) {
// // mc := NewMockConnection()
// // mr := NewMockCruder()
// // m.When(mr.List(resource.NotNamespaced, metav1.ListOptions{})).ThenReturn(k8s.Collection{*k8sCronJob()}, nil)
// // l := NewCronJobListWithArgs("-", NewCronJobWithArgs(mc, mr))
// // // Make sure we can get deltas!
// // for i := 0; i < 2; i++ {
// // err := l.Reconcile(nil, "", "")
// // assert.Nil(t, err)
// // }
// // mr.VerifyWasCalled(m.Times(2)).List(resource.NotNamespaced, metav1.ListOptions{})
// // td := l.Data()
// // assert.Equal(t, 1, len(td.Rows))
// // assert.Equal(t, resource.NotNamespaced, l.GetNamespace())
// // 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])
// // }
// // 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 {
// mc := NewMockConnection()
// c, _ := resource.NewCronJob(mc).New(k8sCronJob())
// return c
// }
// func cronjobYaml() string {
// return `apiVersion: extensions/batchv1beta1
// kind: CronJob
// metadata:
// creationTimestamp: "2018-12-14T17:36:43Z"
// name: fred
// namespace: blee
// spec:
// jobTemplate:
// metadata:
// creationTimestamp: null
// spec:
// template:
// metadata:
// creationTimestamp: null
// spec:
// containers: null
// schedule: '*/1 * * * *'
// suspend: false
// status:
// lastScheduleTime: "2018-12-14T17:36:43Z"
// `
// }