mirror of
https://github.com/Azure/cosmos-explorer.git
synced 2026-01-01 23:32:02 +00:00
126 lines
4.1 KiB
TypeScript
126 lines
4.1 KiB
TypeScript
import { expect, test } from "@playwright/test";
|
|
|
|
import { DataExplorer, TEST_AUTOSCALE_THROUGHPUT_RU, TestAccount, generateUniqueName } from "../fx";
|
|
import { MONGO_CONFIG, deleteDatabase, openAndFillCreateContainerPanel } from "../helpers/containerCreationHelpers";
|
|
|
|
test("Mongo: New database non-shared throughput", async ({ page }) => {
|
|
const databaseId = generateUniqueName("db");
|
|
const collectionId = generateUniqueName("collection");
|
|
|
|
const explorer = await DataExplorer.open(page, TestAccount.Mongo);
|
|
|
|
await openAndFillCreateContainerPanel(explorer, MONGO_CONFIG, {
|
|
databaseId,
|
|
containerId: collectionId,
|
|
partitionKey: "pk",
|
|
isAutoscale: true,
|
|
throughputValue: TEST_AUTOSCALE_THROUGHPUT_RU,
|
|
});
|
|
|
|
const databaseNode = await explorer.waitForNode(databaseId);
|
|
const collectionNode = await explorer.waitForContainerNode(databaseId, collectionId);
|
|
|
|
await expect(collectionNode.element).toBeAttached();
|
|
|
|
// Cleanup
|
|
await deleteDatabase(explorer, databaseId);
|
|
await expect(databaseNode.element).not.toBeAttached();
|
|
});
|
|
|
|
test("Mongo: New database shared throughput", async ({ page }) => {
|
|
const databaseId = generateUniqueName("db");
|
|
const collectionId = generateUniqueName("collection");
|
|
|
|
const explorer = await DataExplorer.open(page, TestAccount.Mongo);
|
|
|
|
await openAndFillCreateContainerPanel(explorer, MONGO_CONFIG, {
|
|
databaseId,
|
|
containerId: collectionId,
|
|
partitionKey: "pk",
|
|
useSharedThroughput: true,
|
|
});
|
|
|
|
const databaseNode = await explorer.waitForNode(databaseId);
|
|
const collectionNode = await explorer.waitForContainerNode(databaseId, collectionId);
|
|
|
|
await expect(collectionNode.element).toBeAttached();
|
|
|
|
// Cleanup
|
|
await deleteDatabase(explorer, databaseId);
|
|
await expect(databaseNode.element).not.toBeAttached();
|
|
});
|
|
|
|
test("Mongo: Unique keys", async ({ page }) => {
|
|
const databaseId = generateUniqueName("db");
|
|
const collectionId = generateUniqueName("collection");
|
|
|
|
const explorer = await DataExplorer.open(page, TestAccount.Mongo);
|
|
|
|
await openAndFillCreateContainerPanel(explorer, MONGO_CONFIG, {
|
|
databaseId,
|
|
containerId: collectionId,
|
|
partitionKey: "pk",
|
|
isAutoscale: true,
|
|
throughputValue: TEST_AUTOSCALE_THROUGHPUT_RU,
|
|
uniqueKey: "email",
|
|
});
|
|
|
|
const databaseNode = await explorer.waitForNode(databaseId);
|
|
const collectionNode = await explorer.waitForContainerNode(databaseId, collectionId);
|
|
|
|
await expect(collectionNode.element).toBeAttached();
|
|
|
|
// Cleanup
|
|
await deleteDatabase(explorer, databaseId);
|
|
await expect(databaseNode.element).not.toBeAttached();
|
|
});
|
|
|
|
test("Mongo: Autoscale throughput", async ({ page }) => {
|
|
const databaseId = generateUniqueName("db");
|
|
const collectionId = generateUniqueName("collection");
|
|
|
|
const explorer = await DataExplorer.open(page, TestAccount.Mongo);
|
|
|
|
await openAndFillCreateContainerPanel(explorer, MONGO_CONFIG, {
|
|
databaseId,
|
|
containerId: collectionId,
|
|
partitionKey: "pk",
|
|
isAutoscale: true,
|
|
throughputValue: TEST_AUTOSCALE_THROUGHPUT_RU,
|
|
});
|
|
|
|
const databaseNode = await explorer.waitForNode(databaseId);
|
|
const collectionNode = await explorer.waitForContainerNode(databaseId, collectionId);
|
|
|
|
await expect(collectionNode.element).toBeAttached();
|
|
|
|
// Cleanup
|
|
await deleteDatabase(explorer, databaseId);
|
|
await expect(databaseNode.element).not.toBeAttached();
|
|
});
|
|
|
|
test("Mongo: Manual throughput", async ({ page }) => {
|
|
const databaseId = generateUniqueName("db");
|
|
const collectionId = generateUniqueName("collection");
|
|
const manualThroughput = 400;
|
|
|
|
const explorer = await DataExplorer.open(page, TestAccount.Mongo);
|
|
|
|
await openAndFillCreateContainerPanel(explorer, MONGO_CONFIG, {
|
|
databaseId,
|
|
containerId: collectionId,
|
|
partitionKey: "pk",
|
|
isAutoscale: false,
|
|
throughputValue: manualThroughput,
|
|
});
|
|
|
|
const databaseNode = await explorer.waitForNode(databaseId);
|
|
const collectionNode = await explorer.waitForContainerNode(databaseId, collectionId);
|
|
|
|
await expect(collectionNode.element).toBeAttached();
|
|
|
|
// Cleanup
|
|
await deleteDatabase(explorer, databaseId);
|
|
await expect(databaseNode.element).not.toBeAttached();
|
|
});
|