| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148 |
- package kubemodel
- import (
- "testing"
- "time"
- "github.com/stretchr/testify/require"
- )
- func TestValidateJob(t *testing.T) {
- start := time.Now().UTC().Truncate(time.Hour)
- end := start.Add(time.Hour)
- window := Window{Start: start, End: end}
- tests := []struct {
- name string
- job *Job
- wantErr string
- }{
- {
- name: "empty UID",
- job: &Job{Name: "my-job", NamespaceUID: "ns-uid", Start: start, End: end},
- wantErr: "UID is missing for Job with name 'my-job'",
- },
- {
- name: "empty Name",
- job: &Job{UID: "job-uid", NamespaceUID: "ns-uid", Start: start, End: end},
- wantErr: "Name is missing for Job 'job-uid'",
- },
- {
- name: "empty NamespaceUID",
- job: &Job{UID: "job-uid", Name: "my-job", Start: start, End: end},
- wantErr: "NamespaceUID is missing for Job 'job-uid'",
- },
- {
- name: "outside window",
- job: &Job{UID: "job-uid", Name: "my-job", NamespaceUID: "ns-uid", Start: start.Add(-time.Hour), End: end},
- wantErr: checkWindow(window, start.Add(-time.Hour), end).Error(),
- },
- {
- name: "valid",
- job: &Job{UID: "job-uid", Name: "my-job", NamespaceUID: "ns-uid", Start: start, End: end},
- },
- }
- for _, tt := range tests {
- t.Run(tt.name, func(t *testing.T) {
- err := tt.job.ValidateJob(window)
- if tt.wantErr != "" {
- require.EqualError(t, err, tt.wantErr)
- } else {
- require.NoError(t, err)
- }
- })
- }
- }
- func TestRegisterJob(t *testing.T) {
- start := time.Now().UTC().Truncate(time.Hour)
- end := start.Add(time.Hour)
- newJob := func(uid, name string) *Job {
- return &Job{UID: uid, Name: name, NamespaceUID: "ns-uid", Start: start, End: end}
- }
- withCluster := func(kms *KubeModelSet) {
- kms.RegisterCluster(&Cluster{UID: "cluster-uid", Start: start, End: end})
- }
- tests := []struct {
- name string
- setup func(*KubeModelSet)
- job *Job
- wantErr string
- want *KubeModelSet
- }{
- {
- name: "validation failure",
- job: &Job{UID: "", Name: "my-job", NamespaceUID: "ns-uid", Start: start, End: end},
- wantErr: "RegisterJob: invalid job: UID is missing for Job with name 'my-job'",
- want: func() *KubeModelSet {
- kms := NewKubeModelSet(start, end)
- kms.Metadata.Diagnostics = []Diagnostic{
- {Level: DiagnosticLevelError, Message: "RegisterJob: invalid job: UID is missing for Job with name 'my-job'"},
- }
- return kms
- }(),
- },
- {
- name: "warns when cluster is nil",
- job: newJob("job-uid", "my-job"),
- want: func() *KubeModelSet {
- kms := NewKubeModelSet(start, end)
- kms.Jobs["job-uid"] = newJob("job-uid", "my-job")
- kms.Metadata.ObjectCount = 1
- kms.Metadata.Diagnostics = []Diagnostic{
- {Level: DiagnosticLevelWarning, Message: "RegisterJob: Cluster is nil"},
- }
- return kms
- }(),
- },
- {
- name: "registers job with cluster",
- setup: withCluster,
- job: newJob("job-uid", "my-job"),
- want: func() *KubeModelSet {
- kms := NewKubeModelSet(start, end)
- withCluster(kms)
- kms.Jobs["job-uid"] = newJob("job-uid", "my-job")
- kms.Metadata.ObjectCount = 1
- return kms
- }(),
- },
- {
- name: "duplicate registration is a no-op",
- setup: func(kms *KubeModelSet) {
- withCluster(kms)
- kms.RegisterJob(newJob("job-uid", "original"))
- },
- job: newJob("job-uid", "duplicate"),
- want: func() *KubeModelSet {
- kms := NewKubeModelSet(start, end)
- withCluster(kms)
- kms.Jobs["job-uid"] = newJob("job-uid", "original")
- kms.Metadata.ObjectCount = 1
- return kms
- }(),
- },
- }
- for _, tt := range tests {
- t.Run(tt.name, func(t *testing.T) {
- kms := NewKubeModelSet(start, end)
- if tt.setup != nil {
- tt.setup(kms)
- }
- err := kms.RegisterJob(tt.job)
- if tt.wantErr != "" {
- require.EqualError(t, err, tt.wantErr)
- } else {
- require.NoError(t, err)
- }
- KubeModelSetEquals(t, tt.want, kms)
- })
- }
- }
|