mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
* Using RemovableItem for items in Kubernetes page Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Helm Charts empty state Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Empty state for kubeconfig sync list Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Remove unused styles Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Fixing tests Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com>
88 lines
3.8 KiB
TypeScript
88 lines
3.8 KiB
TypeScript
/**
|
|
* Copyright (c) 2021 OpenLens Authors
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
|
* this software and associated documentation files (the "Software"), to deal in
|
|
* the Software without restriction, including without limitation the rights to
|
|
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
|
* the Software, and to permit persons to whom the Software is furnished to do so,
|
|
* subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in all
|
|
* copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
|
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
|
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
|
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
*/
|
|
|
|
/*
|
|
Cluster tests are run if there is a pre-existing minikube cluster. Before running cluster tests the TEST_NAMESPACE
|
|
namespace is removed, if it exists, from the minikube cluster. Resources are created as part of the cluster tests in the
|
|
TEST_NAMESPACE namespace. This is done to minimize destructive impact of the cluster tests on an existing minikube
|
|
cluster and vice versa.
|
|
*/
|
|
import type { Application } from "spectron";
|
|
import * as utils from "../helpers/utils";
|
|
import { listHelmRepositories } from "../helpers/utils";
|
|
import { fail } from "assert";
|
|
|
|
jest.setTimeout(2 * 60 * 1000); // 2 minutes so that we can get better errors from spectron
|
|
|
|
// FIXME (!): improve / simplify all css-selectors + use [data-test-id="some-id"] (already used in some tests below)
|
|
describe("Lens integration tests", () => {
|
|
let app: Application;
|
|
|
|
describe("app start", () => {
|
|
utils.beforeAllWrapped(async () => {
|
|
app = await utils.setup();
|
|
});
|
|
|
|
utils.afterAllWrapped(() => utils.tearDown(app));
|
|
|
|
it('shows "add cluster"', async () => {
|
|
await app.electron.ipcRenderer.send("test-menu-item-click", "File", "Add Cluster");
|
|
await app.client.waitUntilTextExists("h2", "Add Clusters from Kubeconfig");
|
|
});
|
|
|
|
describe("preferences page", () => {
|
|
it('shows "preferences"', async () => {
|
|
const appName: string = process.platform === "darwin" ? "OpenLens" : "File";
|
|
|
|
await app.electron.ipcRenderer.send("test-menu-item-click", appName, "Preferences");
|
|
await app.client.waitUntilTextExists("[data-testid=application-header]", "Application");
|
|
});
|
|
|
|
it.each([
|
|
["application", "Application"],
|
|
["proxy", "Proxy"],
|
|
["kubernetes", "Kubernetes"],
|
|
])("Can click the %s tab and see the %s header", async (tab, header) => {
|
|
await app.client.click(`[data-testid=${tab}-tab]`);
|
|
await app.client.waitUntilTextExists(`[data-testid=${tab}-header]`, header);
|
|
});
|
|
|
|
it("ensures helm repos", async () => {
|
|
const repos = await listHelmRepositories();
|
|
|
|
if (repos.length === 0) {
|
|
fail("Lens failed to add any repositories");
|
|
}
|
|
|
|
await app.client.click("[data-testid=kubernetes-tab]");
|
|
await app.client.waitUntilTextExists("[data-testid=repository-name]", repos[0].name); // wait for the helm-cli to fetch the repo(s)
|
|
await app.client.click("#HelmRepoSelect"); // click the repo select to activate the drop-down
|
|
await app.client.waitUntilTextExists("div.Select__option", ""); // wait for at least one option to appear (any text)
|
|
});
|
|
});
|
|
|
|
it.skip('quits Lens"', async () => {
|
|
await app.client.keys(["Meta", "Q"]);
|
|
await app.client.keys("Meta");
|
|
});
|
|
});
|
|
});
|