mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
261 lines
6.2 KiB
TypeScript
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],
|
|
]);
|
|
});
|
|
});
|