mirror of
https://github.com/gitpod-io/gitpod.git
synced 2025-12-08 17:36:30 +00:00
Deleting a workspace cluster by name only makes sense in the context of a particular workspace cluster.
161 lines
5.0 KiB
TypeScript
161 lines
5.0 KiB
TypeScript
/**
|
|
* Copyright (c) 2022 Gitpod GmbH. All rights reserved.
|
|
* Licensed under the GNU Affero General Public License (AGPL).
|
|
* See License-AGPL.txt in the project root for license information.
|
|
*/
|
|
|
|
import * as chai from "chai";
|
|
import { suite, test, timeout } from "mocha-typescript";
|
|
import { testContainer } from "./test-container";
|
|
import { TypeORM } from "./typeorm/typeorm";
|
|
import { WorkspaceCluster, WorkspaceClusterDB } from "@gitpod/gitpod-protocol/lib/workspace-cluster";
|
|
import { DBWorkspaceCluster } from "./typeorm/entity/db-workspace-cluster";
|
|
const expect = chai.expect;
|
|
|
|
@suite
|
|
@timeout(5000)
|
|
export class WorkspaceClusterDBSpec {
|
|
typeORM = testContainer.get<TypeORM>(TypeORM);
|
|
db = testContainer.get<WorkspaceClusterDB>(WorkspaceClusterDB);
|
|
|
|
async before() {
|
|
await this.clear();
|
|
}
|
|
|
|
async after() {
|
|
await this.clear();
|
|
}
|
|
|
|
protected async clear() {
|
|
const connection = await this.typeORM.getConnection();
|
|
const manager = connection.manager;
|
|
await manager.clear(DBWorkspaceCluster);
|
|
}
|
|
|
|
@test public async findByName() {
|
|
const wsc1: DBWorkspaceCluster = {
|
|
name: "eu71",
|
|
applicationCluster: "eu02",
|
|
url: "some-url",
|
|
state: "available",
|
|
score: 100,
|
|
maxScore: 100,
|
|
govern: true,
|
|
};
|
|
const wsc2: DBWorkspaceCluster = {
|
|
name: "us71",
|
|
applicationCluster: "eu02",
|
|
url: "some-url",
|
|
state: "cordoned",
|
|
score: 0,
|
|
maxScore: 0,
|
|
govern: false,
|
|
};
|
|
|
|
await this.db.save(wsc1);
|
|
await this.db.save(wsc2);
|
|
|
|
// Can find the eu71 cluster as seen by the eu02 application cluster.
|
|
const result = await this.db.findByName("eu71", "eu02");
|
|
expect(result).not.to.be.undefined;
|
|
expect((result as WorkspaceCluster).name).to.equal("eu71");
|
|
|
|
// Can't find the eu71 cluster as seen by the us02 application cluster.
|
|
// (no record in the db for that (ws-cluster, app-cluster) combination).
|
|
const result2 = await this.db.findByName("eu71", "us02");
|
|
expect(result2).to.be.undefined;
|
|
|
|
// Can find the us71 cluster as seen by the eu02 application cluster.
|
|
const result3 = await this.db.findByName("us71", "eu02");
|
|
expect(result3).not.to.be.undefined;
|
|
expect((result3 as WorkspaceCluster).name).to.equal("us71");
|
|
}
|
|
|
|
@test public async deleteByName() {
|
|
const wsc1: DBWorkspaceCluster = {
|
|
name: "eu71",
|
|
applicationCluster: "eu02",
|
|
url: "some-url",
|
|
state: "available",
|
|
score: 100,
|
|
maxScore: 100,
|
|
govern: true,
|
|
};
|
|
const wsc2: DBWorkspaceCluster = {
|
|
name: "us71",
|
|
applicationCluster: "eu02",
|
|
url: "some-url",
|
|
state: "cordoned",
|
|
score: 0,
|
|
maxScore: 0,
|
|
govern: false,
|
|
};
|
|
|
|
await this.db.save(wsc1);
|
|
await this.db.save(wsc2);
|
|
|
|
// Can delete the eu71 cluster as seen by the eu02 application cluster.
|
|
await this.db.deleteByName("eu71", "eu02");
|
|
expect(await this.db.findByName("eu71", "eu02")).to.be.undefined;
|
|
expect(await this.db.findByName("us71", "eu02")).not.to.be.undefined;
|
|
}
|
|
|
|
@test public async testFindFilteredByName() {
|
|
const wsc1: DBWorkspaceCluster = {
|
|
name: "eu71",
|
|
applicationCluster: "eu02",
|
|
url: "some-url",
|
|
state: "available",
|
|
score: 100,
|
|
maxScore: 100,
|
|
govern: true,
|
|
};
|
|
const wsc2: DBWorkspaceCluster = {
|
|
name: "us71",
|
|
applicationCluster: "eu02",
|
|
url: "some-url",
|
|
state: "cordoned",
|
|
score: 0,
|
|
maxScore: 0,
|
|
govern: false,
|
|
};
|
|
|
|
await this.db.save(wsc1);
|
|
await this.db.save(wsc2);
|
|
|
|
const wscs = await this.db.findFiltered({ name: "eu71", applicationCluster: "eu02" });
|
|
expect(wscs.length).to.equal(1);
|
|
expect(wscs[0].name).to.equal("eu71");
|
|
}
|
|
|
|
@test public async testFindFilteredByApplicationCluster() {
|
|
const wsc1: DBWorkspaceCluster = {
|
|
name: "eu71",
|
|
applicationCluster: "eu02",
|
|
url: "some-url",
|
|
state: "available",
|
|
score: 100,
|
|
maxScore: 100,
|
|
govern: true,
|
|
};
|
|
const wsc2: DBWorkspaceCluster = {
|
|
name: "us71",
|
|
applicationCluster: "us02",
|
|
url: "some-url",
|
|
state: "available",
|
|
score: 100,
|
|
maxScore: 100,
|
|
govern: true,
|
|
};
|
|
|
|
await this.db.save(wsc1);
|
|
await this.db.save(wsc2);
|
|
|
|
const wscs = await this.db.findFiltered({ applicationCluster: "eu02" });
|
|
expect(wscs.length).to.equal(1);
|
|
expect(wscs[0].name).to.equal("eu71");
|
|
}
|
|
}
|
|
|
|
module.exports = WorkspaceClusterDBSpec;
|