2021-04-20 04:08:25 +01:00
|
|
|
import { jest } from "@jest/globals";
|
|
|
|
import "expect-playwright";
|
2024-05-29 17:56:27 +01:00
|
|
|
import {
|
|
|
|
AccountType,
|
|
|
|
generateDatabaseNameWithTimestamp,
|
|
|
|
generateUniqueName,
|
|
|
|
getPanelSelector,
|
|
|
|
getTestExplorerUrl,
|
|
|
|
getTreeMenuItemSelector,
|
|
|
|
getTreeNodeSelector,
|
|
|
|
openContextMenu,
|
|
|
|
} from "../utils/shared";
|
2021-07-22 00:22:31 +01:00
|
|
|
import { waitForExplorer } from "../utils/waitForExplorer";
|
2021-04-20 04:08:25 +01:00
|
|
|
jest.setTimeout(240000);
|
|
|
|
|
2021-04-21 18:45:34 +01:00
|
|
|
test("Mongo CRUD", async () => {
|
|
|
|
const databaseId = generateDatabaseNameWithTimestamp();
|
2021-04-20 04:08:25 +01:00
|
|
|
const containerId = generateUniqueName("container");
|
2024-04-09 18:55:08 +01:00
|
|
|
|
2021-07-22 00:22:31 +01:00
|
|
|
page.setDefaultTimeout(50000);
|
2021-04-20 04:08:25 +01:00
|
|
|
|
2024-05-29 17:56:27 +01:00
|
|
|
const url = await getTestExplorerUrl(AccountType.Mongo);
|
|
|
|
await page.goto(url);
|
2021-07-22 00:22:31 +01:00
|
|
|
const explorer = await waitForExplorer();
|
2020-11-02 19:33:14 +00:00
|
|
|
|
2021-04-20 04:08:25 +01:00
|
|
|
// Create new database and collection
|
|
|
|
await explorer.click('[data-test="New Collection"]');
|
2024-05-29 17:56:27 +01:00
|
|
|
|
|
|
|
await explorer.waitForSelector(getPanelSelector("New Collection"));
|
2023-09-27 16:17:40 +01:00
|
|
|
await explorer.fill('[aria-label="New database id, Type a new database id"]', databaseId);
|
|
|
|
await explorer.fill('[aria-label="Collection id, Example Collection1"]', containerId);
|
2021-08-16 17:35:21 +01:00
|
|
|
await explorer.fill('[aria-label="Shard key"]', "pk");
|
2021-04-30 18:23:34 +01:00
|
|
|
await explorer.click("#sidePanelOkButton");
|
2024-05-29 17:56:27 +01:00
|
|
|
await explorer.waitForSelector(getPanelSelector("New Collection"), { state: "detached" });
|
|
|
|
|
|
|
|
await explorer.click(getTreeNodeSelector(`DATA/${databaseId}`));
|
|
|
|
await explorer.click(getTreeNodeSelector(`DATA/${databaseId}/${containerId}`));
|
|
|
|
|
2021-04-20 04:08:25 +01:00
|
|
|
// Create indexing policy
|
2024-05-29 17:56:27 +01:00
|
|
|
await explorer.click(getTreeNodeSelector(`DATA/${databaseId}/${containerId}/Settings`));
|
2021-04-20 04:08:25 +01:00
|
|
|
await explorer.click('button[role="tab"]:has-text("Indexing Policy")');
|
|
|
|
await explorer.click('[aria-label="Index Field Name 0"]');
|
|
|
|
await explorer.fill('[aria-label="Index Field Name 0"]', "foo");
|
|
|
|
await explorer.click("text=Select an index type");
|
|
|
|
await explorer.click('button[role="option"]:has-text("Single Field")');
|
|
|
|
await explorer.click('[data-test="Save"]');
|
2024-05-29 17:56:27 +01:00
|
|
|
|
2021-04-20 04:08:25 +01:00
|
|
|
// Remove indexing policy
|
|
|
|
await explorer.click('[aria-label="Delete index Button"]');
|
|
|
|
await explorer.click('[data-test="Save"]');
|
2024-05-29 17:56:27 +01:00
|
|
|
|
2021-04-20 04:08:25 +01:00
|
|
|
// Delete database and collection
|
2024-05-29 17:56:27 +01:00
|
|
|
await openContextMenu(explorer, `DATA/${databaseId}/${containerId}`);
|
|
|
|
await explorer.click(getTreeMenuItemSelector(`DATA/${databaseId}/${containerId}`, "Delete Collection"));
|
|
|
|
|
|
|
|
await explorer.waitForSelector(getPanelSelector("Delete Collection"));
|
2021-04-20 04:08:25 +01:00
|
|
|
await explorer.fill('text=* Confirm by typing the collection id >> input[type="text"]', containerId);
|
2021-05-19 03:57:31 +01:00
|
|
|
await explorer.click('[aria-label="OK"]');
|
2024-05-29 17:56:27 +01:00
|
|
|
await explorer.waitForSelector(getPanelSelector("Delete Collection"), { state: "detached" });
|
|
|
|
|
|
|
|
await openContextMenu(explorer, `DATA/${databaseId}`);
|
|
|
|
await explorer.click(getTreeMenuItemSelector(`DATA/${databaseId}`, "Delete Database"));
|
|
|
|
|
|
|
|
await explorer.waitForSelector(getPanelSelector("Delete Database"));
|
2021-04-20 04:08:25 +01:00
|
|
|
await explorer.click('text=* Confirm by typing the database id >> input[type="text"]');
|
|
|
|
await explorer.fill('text=* Confirm by typing the database id >> input[type="text"]', databaseId);
|
|
|
|
await explorer.click("#sidePanelOkButton");
|
2024-05-29 17:56:27 +01:00
|
|
|
await explorer.waitForSelector(getPanelSelector("Delete Database"), { state: "detached" });
|
|
|
|
|
2021-04-20 04:08:25 +01:00
|
|
|
await expect(explorer).not.toHaveText(".dataResourceTree", databaseId);
|
|
|
|
await expect(explorer).not.toHaveText(".dataResourceTree", containerId);
|
|
|
|
});
|