mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
* Adding General Entities and General Category Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Usign material icons for general entities Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Setting background for hotbar icon explicitly Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Adding Catalog initially to first hotbar Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Tuning hotbar store tests Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Changing type from GeneralEntity to General Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Search for catalog hotbar item in tests Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Removing Catalog link from bottom bar Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Waiting for hotbar catalog entity Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Opening cluster list by data-testId Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Replacing types on interfaces Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Fixing integration tests Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Adding general entities throught initializers Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Removing icon refs from CatalogEntitySpec Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com>
75 lines
2.9 KiB
TypeScript
75 lines
2.9 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.
|
|
*/
|
|
import { spawnSync } from "child_process";
|
|
import type { Application } from "spectron";
|
|
|
|
export function minikubeReady(testNamespace: string): boolean {
|
|
// determine if minikube is running
|
|
{
|
|
const { status } = spawnSync("minikube status", { shell: true });
|
|
|
|
if (status !== 0) {
|
|
console.warn("minikube not running");
|
|
|
|
return false;
|
|
}
|
|
}
|
|
|
|
// Remove TEST_NAMESPACE if it already exists
|
|
{
|
|
const { status } = spawnSync(`minikube kubectl -- get namespace ${testNamespace}`, { shell: true });
|
|
|
|
if (status === 0) {
|
|
console.warn(`Removing existing ${testNamespace} namespace`);
|
|
|
|
const { status, stdout, stderr } = spawnSync(
|
|
`minikube kubectl -- delete namespace ${testNamespace}`,
|
|
{ shell: true },
|
|
);
|
|
|
|
if (status !== 0) {
|
|
console.warn(`Error removing ${testNamespace} namespace: ${stderr.toString()}`);
|
|
|
|
return false;
|
|
}
|
|
|
|
console.log(stdout.toString());
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
export async function waitForMinikubeDashboard(app: Application) {
|
|
await app.client.waitUntilTextExists("div.TableCell", "minikube");
|
|
await app.client.waitForExist(".Input.SearchInput input");
|
|
await app.client.setValue(".Input.SearchInput input", "minikube");
|
|
await app.client.waitUntilTextExists("div.TableCell", "minikube");
|
|
await app.client.click("div.TableRow");
|
|
await app.client.waitUntilTextExists("div.drawer-title-text", "KubernetesCluster: minikube");
|
|
await app.client.waitForExist("div.EntityIcon div.HotbarIcon div div.MuiAvatar-root");
|
|
await app.client.click("div.EntityIcon div.HotbarIcon div div.MuiAvatar-root");
|
|
await app.client.waitUntilTextExists("pre.kube-auth-out", "Authentication proxy started");
|
|
await app.client.waitForExist(`iframe[name="minikube"]`);
|
|
await app.client.frame("minikube");
|
|
await app.client.waitUntilTextExists("span.link-text", "Cluster");
|
|
}
|