/** * Copyright (c) OpenLens Authors. All rights reserved. * Licensed under MIT License. See LICENSE in root directory for more information. */ import { observable } from "mobx"; import type { JobStore } from "../+workloads-jobs/store"; import jobStoreInjectable from "../+workloads-jobs/store.injectable"; import podStoreInjectable from "../+workloads-pods/store.injectable"; import { Job, Pod } from "../../../common/k8s-api/endpoints"; import storesAndApisCanBeCreatedInjectable from "../../stores-apis-can-be-created.injectable"; import { getDiForUnitTesting } from "../../getDiForUnitTesting"; import directoryForUserDataInjectable from "../../../common/app-paths/directory-for-user-data/directory-for-user-data.injectable"; import directoryForKubeConfigsInjectable from "../../../common/app-paths/directory-for-kube-configs/directory-for-kube-configs.injectable"; import hostedClusterInjectable from "../../cluster-frame-context/hosted-cluster.injectable"; import createClusterInjectable from "../../cluster/create-cluster.injectable"; const runningJob = new Job({ apiVersion: "foo", kind: "Job", metadata: { name: "runningJob", resourceVersion: "runningJob", uid: "runningJob", namespace: "default", selfLink: "/apis/batch/v1/jobs/default/runningJob", }, }); const failedJob = new Job({ apiVersion: "foo", kind: "Job", metadata: { name: "failedJob", resourceVersion: "failedJob", uid: "failedJob", namespace: "default", selfLink: "/apis/batch/v1/jobs/default/failedJob", }, }); const pendingJob = new Job({ apiVersion: "foo", kind: "Job", metadata: { name: "pendingJob", resourceVersion: "pendingJob", uid: "pendingJob", namespace: "default", selfLink: "/apis/batch/v1/jobs/default/pendingJob", }, }); const succeededJob = new Job({ apiVersion: "foo", kind: "Job", metadata: { name: "succeededJob", resourceVersion: "succeededJob", uid: "succeededJob", namespace: "default", selfLink: "/apis/batch/v1/jobs/default/succeededJob", }, }); const runningPod = new Pod({ apiVersion: "foo", kind: "Pod", metadata: { name: "foobar", resourceVersion: "foobar", uid: "foobar", ownerReferences: [{ uid: "runningJob", apiVersion: "v1", kind: "Pod", name: "running", }], namespace: "default", selfLink: "/api/v1/pods/default/foobar", }, status: { phase: "Running", conditions: [ { type: "Initialized", status: "True", lastProbeTime: 1, lastTransitionTime: "1", }, { type: "Ready", status: "True", lastProbeTime: 1, lastTransitionTime: "1", }, ], hostIP: "10.0.0.1", podIP: "10.0.0.1", startTime: "now", containerStatuses: [], initContainerStatuses: [], }, }); const pendingPod = new Pod({ apiVersion: "foo", kind: "Pod", metadata: { name: "foobar-pending", resourceVersion: "foobar", uid: "foobar-pending", ownerReferences: [{ uid: "pendingJob", apiVersion: "v1", kind: "Pod", name: "pending", }], namespace: "default", selfLink: "/api/v1/pods/default/foobar-pending", }, }); const failedPod = new Pod({ apiVersion: "foo", kind: "Pod", metadata: { name: "foobar-failed", resourceVersion: "foobar", uid: "foobar-failed", ownerReferences: [{ uid: "failedJob", apiVersion: "v1", kind: "Pod", name: "failed", }], namespace: "default", selfLink: "/api/v1/pods/default/foobar-failed", }, status: { phase: "Failed", conditions: [], hostIP: "10.0.0.1", podIP: "10.0.0.1", startTime: "now", }, }); const succeededPod = new Pod({ apiVersion: "foo", kind: "Pod", metadata: { name: "foobar-succeeded", resourceVersion: "foobar", uid: "foobar-succeeded", ownerReferences: [{ uid: "succeededJob", apiVersion: "v1", kind: "Pod", name: "succeeded", }], namespace: "default", selfLink: "/api/v1/pods/default/foobar-succeeded", }, status: { phase: "Succeeded", conditions: [], hostIP: "10.0.0.1", podIP: "10.0.0.1", startTime: "now", }, }); describe("Job Store tests", () => { let jobStore: JobStore; beforeEach(() => { const di = getDiForUnitTesting({ doGeneralOverrides: true }); di.override(directoryForUserDataInjectable, () => "/some-user-store-path"); di.override(directoryForKubeConfigsInjectable, () => "/some-kube-configs"); di.override(storesAndApisCanBeCreatedInjectable, () => true); const createCluster = di.inject(createClusterInjectable); di.override(hostedClusterInjectable, () => createCluster({ contextName: "some-context-name", id: "some-cluster-id", kubeConfigPath: "/some-path-to-a-kubeconfig", }, { clusterServerUrl: "https://localhost:8080", })); jobStore = di.inject(jobStoreInjectable); const podStore = di.inject(podStoreInjectable); // Add pods to pod store podStore.items = observable.array([ runningPod, failedPod, pendingPod, succeededPod, ]); }); it("gets Job statuses in proper sorting order", () => { const statuses = Object.entries(jobStore.getStatuses([ failedJob, succeededJob, runningJob, pendingJob, ])); expect(statuses).toEqual([ ["succeeded", 1], ["running", 1], ["failed", 1], ["pending", 1], ]); }); it("returns 0 for other statuses", () => { let statuses = Object.entries(jobStore.getStatuses([succeededJob])); expect(statuses).toEqual([ ["succeeded", 1], ["running", 0], ["failed", 0], ["pending", 0], ]); statuses = Object.entries(jobStore.getStatuses([runningJob])); expect(statuses).toEqual([ ["succeeded", 0], ["running", 1], ["failed", 0], ["pending", 0], ]); statuses = Object.entries(jobStore.getStatuses([failedJob])); expect(statuses).toEqual([ ["succeeded", 0], ["running", 0], ["failed", 1], ["pending", 0], ]); statuses = Object.entries(jobStore.getStatuses([pendingJob])); expect(statuses).toEqual([ ["succeeded", 0], ["running", 0], ["failed", 0], ["pending", 1], ]); }); });