1
0
mirror of https://github.com/lensapp/lens.git synced 2025-05-20 05:10:56 +00:00
lens/src/renderer/components/__tests__/job.store.test.ts
Sebastian Malton 3dbe01e830 Fix non-ApplicationBuilder tests by adding overrides
Signed-off-by: Sebastian Malton <sebastian@malton.name>
2022-12-19 08:17:26 -05:00

261 lines
6.2 KiB
TypeScript

/**
* 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],
]);
});
});