mirror of
https://github.com/Azure/cosmos-explorer.git
synced 2025-02-19 10:46:56 +00:00
140 lines
4.4 KiB
TypeScript
140 lines
4.4 KiB
TypeScript
import * as ko from "knockout";
|
|
import * as ViewModels from "../../Contracts/ViewModels";
|
|
import { useTabs } from "../../hooks/useTabs";
|
|
import { updateUserContext } from "../../UserContext";
|
|
import { container } from "../Controls/Settings/TestUtils";
|
|
import DocumentId from "../Tree/DocumentId";
|
|
import DocumentsTab from "./DocumentsTab";
|
|
import { NewQueryTab } from "./QueryTab/QueryTab";
|
|
|
|
describe("useTabs tests", () => {
|
|
let database: ViewModels.Database;
|
|
let collection: ViewModels.Collection;
|
|
let queryTab: NewQueryTab;
|
|
let documentsTab: DocumentsTab;
|
|
|
|
beforeEach(() => {
|
|
updateUserContext({
|
|
databaseAccount: {
|
|
id: "test",
|
|
name: "test",
|
|
location: "",
|
|
type: "",
|
|
kind: "",
|
|
properties: undefined,
|
|
},
|
|
});
|
|
|
|
database = {
|
|
id: ko.observable<string>("test"),
|
|
isDatabaseShared: () => false,
|
|
} as ViewModels.Database;
|
|
database.isDatabaseExpanded = ko.observable<boolean>(true);
|
|
database.selectedSubnodeKind = ko.observable<ViewModels.CollectionTabKind>();
|
|
|
|
collection = {
|
|
databaseId: "test",
|
|
id: ko.observable<string>("test"),
|
|
} as ViewModels.Collection;
|
|
collection.getDatabase = (): ViewModels.Database => database;
|
|
collection.isCollectionExpanded = ko.observable<boolean>(true);
|
|
collection.selectedSubnodeKind = ko.observable<ViewModels.CollectionTabKind>();
|
|
|
|
queryTab = new NewQueryTab(
|
|
{
|
|
tabKind: ViewModels.CollectionTabKind.Query,
|
|
collection,
|
|
database,
|
|
title: "",
|
|
tabPath: "",
|
|
queryText: "",
|
|
partitionKey: collection.partitionKey,
|
|
onLoadStartKey: 1,
|
|
},
|
|
{
|
|
container: container,
|
|
}
|
|
);
|
|
|
|
documentsTab = new DocumentsTab({
|
|
partitionKey: undefined,
|
|
documentIds: ko.observableArray<DocumentId>(),
|
|
tabKind: ViewModels.CollectionTabKind.Documents,
|
|
collection,
|
|
title: "",
|
|
tabPath: "",
|
|
});
|
|
|
|
// make sure tabs have different tabId
|
|
queryTab.tabId = "1";
|
|
documentsTab.tabId = "2";
|
|
});
|
|
|
|
beforeEach(() => useTabs.setState({ openedTabs: [], activeTab: undefined }));
|
|
|
|
it("open new tabs", () => {
|
|
const { activateNewTab } = useTabs.getState();
|
|
activateNewTab(queryTab);
|
|
let tabsState = useTabs.getState();
|
|
expect(tabsState.openedTabs.length).toBe(1);
|
|
expect(tabsState.openedTabs[0]).toEqual(queryTab);
|
|
expect(tabsState.activeTab).toEqual(queryTab);
|
|
expect(queryTab.isActive()).toBe(true);
|
|
|
|
activateNewTab(documentsTab);
|
|
tabsState = useTabs.getState();
|
|
expect(tabsState.openedTabs.length).toBe(2);
|
|
expect(tabsState.openedTabs[1]).toEqual(documentsTab);
|
|
expect(tabsState.activeTab).toEqual(documentsTab);
|
|
expect(queryTab.isActive()).toBe(false);
|
|
expect(documentsTab.isActive()).toBe(true);
|
|
});
|
|
|
|
it("open existing tabs", () => {
|
|
const { activateNewTab, activateTab } = useTabs.getState();
|
|
activateNewTab(queryTab);
|
|
activateNewTab(documentsTab);
|
|
activateTab(queryTab);
|
|
|
|
const { openedTabs, activeTab } = useTabs.getState();
|
|
expect(openedTabs.length).toBe(2);
|
|
expect(activeTab).toEqual(queryTab);
|
|
expect(queryTab.isActive()).toBe(true);
|
|
expect(documentsTab.isActive()).toBe(false);
|
|
});
|
|
|
|
it("get tabs", () => {
|
|
const { activateNewTab, getTabs } = useTabs.getState();
|
|
activateNewTab(queryTab);
|
|
activateNewTab(documentsTab);
|
|
|
|
const queryTabs = getTabs(ViewModels.CollectionTabKind.Query);
|
|
expect(queryTabs.length).toBe(1);
|
|
expect(queryTabs[0]).toEqual(queryTab);
|
|
|
|
const documentsTabs = getTabs(ViewModels.CollectionTabKind.Documents, (tab) => tab.tabId === documentsTab.tabId);
|
|
expect(documentsTabs.length).toBe(1);
|
|
expect(documentsTabs[0]).toEqual(documentsTab);
|
|
});
|
|
|
|
it("close tabs", () => {
|
|
const { activateNewTab, closeTab, closeTabsByComparator } = useTabs.getState();
|
|
activateNewTab(queryTab);
|
|
activateNewTab(documentsTab);
|
|
closeTab(documentsTab);
|
|
|
|
let tabsState = useTabs.getState();
|
|
expect(tabsState.openedTabs.length).toBe(1);
|
|
expect(tabsState.openedTabs[0]).toEqual(queryTab);
|
|
expect(tabsState.activeTab).toEqual(queryTab);
|
|
expect(queryTab.isActive()).toBe(true);
|
|
expect(documentsTab.isActive()).toBe(false);
|
|
|
|
closeTabsByComparator((tab) => tab.tabId === queryTab.tabId);
|
|
tabsState = useTabs.getState();
|
|
expect(tabsState.openedTabs.length).toBe(0);
|
|
expect(tabsState.activeTab).toEqual(undefined);
|
|
expect(queryTab.isActive()).toBe(false);
|
|
});
|
|
});
|