import packageInfo from "../../package.json" import path from "path" import { bundledKubectl, Kubectl } from "../../src/main/kubectl"; import { isWindows } from "../common/vars"; jest.mock("../common/user-store"); describe("kubectlVersion", () => { it("returns bundled version if exactly same version used", async () => { const kubectl = new Kubectl(bundledKubectl.kubectlVersion) expect(kubectl.kubectlVersion).toBe(bundledKubectl.kubectlVersion) }) it("returns bundled version if same major.minor version is used", async () => { const { bundledKubectlVersion } = packageInfo.config; const kubectl = new Kubectl(bundledKubectlVersion); expect(kubectl.kubectlVersion).toBe(bundledKubectl.kubectlVersion) }) }) describe("getPath()", () => { it("returns path to downloaded kubectl binary", async () => { const { bundledKubectlVersion } = packageInfo.config; const kubectl = new Kubectl(bundledKubectlVersion); const kubectlPath = await kubectl.getPath() let binaryName = "kubectl" if (isWindows) { binaryName += ".exe" } const expectedPath = path.join(Kubectl.kubectlDir, Kubectl.bundledKubectlVersion, binaryName) expect(kubectlPath).toBe(expectedPath) }) it("returns plain binary name if bundled kubectl is non-functional", async () => { const { bundledKubectlVersion } = packageInfo.config; const kubectl = new Kubectl(bundledKubectlVersion); jest.spyOn(kubectl, "getBundledPath").mockReturnValue("/invalid/path/kubectl") const kubectlPath = await kubectl.getPath() let binaryName = "kubectl" if (isWindows) { binaryName += ".exe" } expect(kubectlPath).toBe(binaryName) }) })