mirror of
https://github.com/Azure/cosmos-explorer.git
synced 2025-12-29 05:41:40 +00:00
* Index refresh component introduced - Made all notifications in Mongo Index editor have 12 font size - Added indexing policy refresh to sql indexing policy editor - Added "you have unsaved changes" message, replace old message for lazy indexing policy changes * formatting changes * addressed PR comments
150 lines
5.3 KiB
TypeScript
150 lines
5.3 KiB
TypeScript
import { collection, container } from "./TestUtils";
|
|
import {
|
|
getMaxRUs,
|
|
getMinRUs,
|
|
getMongoIndexType,
|
|
getMongoNotification,
|
|
getSanitizedInputValue,
|
|
hasDatabaseSharedThroughput,
|
|
isDirty,
|
|
isDirtyTypes,
|
|
MongoIndexTypes,
|
|
MongoNotificationType,
|
|
parseConflictResolutionMode,
|
|
parseConflictResolutionProcedure,
|
|
MongoWildcardPlaceHolder,
|
|
getMongoIndexTypeText,
|
|
SingleFieldText,
|
|
WildcardText,
|
|
isIndexTransforming
|
|
} from "./SettingsUtils";
|
|
import * as DataModels from "../../../Contracts/DataModels";
|
|
import * as ViewModels from "../../../Contracts/ViewModels";
|
|
import ko from "knockout";
|
|
|
|
describe("SettingsUtils", () => {
|
|
it("getMaxRUs", () => {
|
|
expect(collection.offer().content.collectionThroughputInfo.numPhysicalPartitions).toEqual(4);
|
|
expect(getMaxRUs(collection, container)).toEqual(40000);
|
|
});
|
|
|
|
it("getMinRUs", () => {
|
|
expect(collection.offer().content.collectionThroughputInfo.numPhysicalPartitions).toEqual(4);
|
|
expect(getMinRUs(collection, container)).toEqual(6000);
|
|
});
|
|
|
|
it("hasDatabaseSharedThroughput", () => {
|
|
expect(hasDatabaseSharedThroughput(collection)).toEqual(undefined);
|
|
|
|
const newCollection = { ...collection };
|
|
newCollection.getDatabase = () => {
|
|
return {
|
|
nodeKind: undefined,
|
|
rid: undefined,
|
|
container: undefined,
|
|
self: "",
|
|
id: ko.observable(""),
|
|
collections: ko.observableArray(undefined),
|
|
offer: ko.observable(undefined),
|
|
isDatabaseExpanded: ko.observable(false),
|
|
isDatabaseShared: ko.computed(() => true),
|
|
selectedSubnodeKind: ko.observable(undefined),
|
|
selectDatabase: undefined,
|
|
expandDatabase: undefined,
|
|
collapseDatabase: undefined,
|
|
loadCollections: undefined,
|
|
findCollectionWithId: undefined,
|
|
openAddCollection: undefined,
|
|
onDeleteDatabaseContextMenuClick: undefined,
|
|
readSettings: undefined,
|
|
onSettingsClick: undefined,
|
|
loadOffer: undefined
|
|
} as ViewModels.Database;
|
|
};
|
|
newCollection.offer(undefined);
|
|
expect(hasDatabaseSharedThroughput(newCollection)).toEqual(true);
|
|
});
|
|
|
|
it("parseConflictResolutionMode", () => {
|
|
expect(parseConflictResolutionMode("custom")).toEqual(DataModels.ConflictResolutionMode.Custom);
|
|
expect(parseConflictResolutionMode("lastwriterwins")).toEqual(DataModels.ConflictResolutionMode.LastWriterWins);
|
|
});
|
|
|
|
it("parseConflictResolutionProcedure", () => {
|
|
expect(parseConflictResolutionProcedure("/dbs/db/colls/coll/sprocs/conflictResSproc")).toEqual("conflictResSproc");
|
|
expect(parseConflictResolutionProcedure("conflictResSproc")).toEqual("conflictResSproc");
|
|
});
|
|
|
|
describe("isDirty", () => {
|
|
const indexingPolicy = {
|
|
automatic: true,
|
|
indexingMode: "consistent",
|
|
includedPaths: [],
|
|
excludedPaths: []
|
|
} as DataModels.IndexingPolicy;
|
|
|
|
const cases = [
|
|
["baseline", "current"],
|
|
[0, 1],
|
|
[true, false],
|
|
[undefined, indexingPolicy],
|
|
[indexingPolicy, { ...indexingPolicy, automatic: false }]
|
|
];
|
|
|
|
test.each(cases)("", (baseline: isDirtyTypes, current: isDirtyTypes) => {
|
|
expect(isDirty(baseline, baseline)).toEqual(false);
|
|
expect(isDirty(baseline, current)).toEqual(true);
|
|
});
|
|
});
|
|
|
|
it("getSanitizedInputValue", () => {
|
|
const max = 100;
|
|
expect(getSanitizedInputValue("", max)).toEqual(0);
|
|
expect(getSanitizedInputValue("999", max)).toEqual(100);
|
|
expect(getSanitizedInputValue("10", max)).toEqual(10);
|
|
});
|
|
|
|
it("getMongoIndexType", () => {
|
|
expect(getMongoIndexType(["Single"])).toEqual(MongoIndexTypes.Single);
|
|
expect(getMongoIndexType(["Wildcard.$**"])).toEqual(MongoIndexTypes.Wildcard);
|
|
expect(getMongoIndexType(["Key1", "Key2"])).toEqual(undefined);
|
|
});
|
|
|
|
it("getMongoIndexTypeText", () => {
|
|
expect(getMongoIndexTypeText(MongoIndexTypes.Single)).toEqual(SingleFieldText);
|
|
expect(getMongoIndexTypeText(MongoIndexTypes.Wildcard)).toEqual(WildcardText);
|
|
});
|
|
|
|
it("getMongoNotification", () => {
|
|
const singleIndexDescription = "sampleKey";
|
|
const wildcardIndexDescription = "sampleKey.$**";
|
|
|
|
let notification = getMongoNotification(singleIndexDescription, undefined);
|
|
expect(notification.message).toEqual("Please select a type for each index.");
|
|
expect(notification.type).toEqual(MongoNotificationType.Warning);
|
|
|
|
notification = getMongoNotification(singleIndexDescription, MongoIndexTypes.Single);
|
|
expect(notification).toEqual(undefined);
|
|
|
|
notification = getMongoNotification(wildcardIndexDescription, MongoIndexTypes.Wildcard);
|
|
expect(notification).toEqual(undefined);
|
|
|
|
notification = getMongoNotification("", MongoIndexTypes.Single);
|
|
expect(notification.message).toEqual("Please enter a field name.");
|
|
expect(notification.type).toEqual(MongoNotificationType.Error);
|
|
|
|
notification = getMongoNotification(singleIndexDescription, MongoIndexTypes.Wildcard);
|
|
expect(notification.message).toEqual(
|
|
"Wildcard path is not present in the field name. Use a pattern like " + MongoWildcardPlaceHolder
|
|
);
|
|
expect(notification.type).toEqual(MongoNotificationType.Error);
|
|
});
|
|
});
|
|
|
|
it("isIndexingTransforming", () => {
|
|
expect(isIndexTransforming(undefined)).toBeFalsy();
|
|
expect(isIndexTransforming(0)).toBeTruthy();
|
|
expect(isIndexTransforming(90)).toBeTruthy();
|
|
expect(isIndexTransforming(100)).toBeFalsy();
|
|
});
|