mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-08-15 19:26:42 +08:00

* chore: move tns-core-modules to nativescript-core * chore: preparing compat generate script * chore: add missing definitions * chore: no need for http-request to be private * chore: packages chore * test: generate tests for tns-core-modules * chore: add anroid module for consistency * chore: add .npmignore * chore: added privateModulesWhitelist * chore(webpack): added bundle-entry-points * chore: scripts * chore: tests changed to use @ns/core * test: add scoped-packages test project * test: fix types * test: update test project * chore: build scripts * chore: update build script * chore: npm scripts cleanup * chore: make the compat pgk work with old wp config * test: generate diff friendly tests * chore: create barrel exports * chore: move files after rebase * chore: typedoc config * chore: compat mode * chore: review of barrels * chore: remove tns-core-modules import after rebase * chore: dev workflow setup * chore: update developer-workflow * docs: experiment with API extractor * chore: api-extractor and barrel exports * chore: api-extractor configs * chore: generate d.ts rollup with api-extractor * refactor: move methods inside Frame * chore: fic tests to use Frame static methods * refactor: create Builder class * refactor: use Builder class in tests * refactor: include Style in ui barrel * chore: separate compat build script * chore: fix tslint errors * chore: update NATIVESCRIPT_CORE_ARGS * chore: fix compat pack * chore: fix ui-test-app build with linked modules * chore: Application, ApplicationSettings, Connectivity and Http * chore: export Trace, Profiling and Utils * refactor: Static create methods for ImageSource * chore: fix deprecated usages of ImageSource * chore: move Span and FormattedString to ui * chore: add events-args and ImageSource to index files * chore: check for CLI >= 6.2 when building for IOS * chore: update travis build * chore: copy Pod file to compat package * chore: update error msg ui-tests-app * refactor: Apply suggestions from code review Co-Authored-By: Martin Yankov <m.i.yankov@gmail.com> * chore: typings and refs * chore: add missing d.ts files for public API * chore: adress code review FB * chore: update api-report * chore: dev-workflow for other apps * chore: api update * chore: update api-report
279 lines
11 KiB
TypeScript
279 lines
11 KiB
TypeScript
import * as TKUnit from "../../tk-unit";
|
|
import * as segmentedBarTestsNative from "./segmented-bar-tests-native";
|
|
import { buildUIAndRunTest } from "../../ui-helper";
|
|
import { View } from "@nativescript/core/ui/core/view";
|
|
import { BindingOptions } from "@nativescript/core/ui/core/bindable";
|
|
import { Observable } from "@nativescript/core/data/observable";
|
|
import { Color } from "@nativescript/core/color";
|
|
import * as helper from "../../ui-helper";
|
|
|
|
// >> article-require-segmentedbar-module
|
|
import * as segmentedBarModule from "@nativescript/core/ui/segmented-bar";
|
|
// << article-require-segmentedbar-module
|
|
|
|
function _createSegmentedBar(): segmentedBarModule.SegmentedBar {
|
|
// >> article-create-segmentedbar
|
|
var segmentedBar = new segmentedBarModule.SegmentedBar();
|
|
// << article-create-segmentedbar
|
|
segmentedBar.id = "SegmentedBar";
|
|
|
|
return segmentedBar;
|
|
}
|
|
|
|
export function test_recycling() {
|
|
const setters = new Map<string, Array<any>>();
|
|
setters.set("items", _createItems(3));
|
|
helper.nativeView_recycling_test(() => new segmentedBarModule.SegmentedBar(), null, null, setters);
|
|
}
|
|
|
|
function _createItems(count: number): Array<segmentedBarModule.SegmentedBarItem> {
|
|
var items = new Array<segmentedBarModule.SegmentedBarItem>();
|
|
for (var i = 0; i < count; i++) {
|
|
let bar = new segmentedBarModule.SegmentedBarItem();
|
|
bar.title = i + "";
|
|
items.push(bar);
|
|
}
|
|
|
|
return items;
|
|
}
|
|
|
|
export var testWhenSegmentedBarIsCreatedItemsAreUndefined = function () {
|
|
buildUIAndRunTest(_createSegmentedBar(), function (views: Array<View>) {
|
|
var segmentedBar = <segmentedBarModule.SegmentedBar>views[0];
|
|
var expectedValue = undefined;
|
|
var actualValue = segmentedBar.items;
|
|
TKUnit.assert(actualValue === expectedValue, "Actual: " + actualValue + "; Expected: " + expectedValue);
|
|
});
|
|
};
|
|
|
|
export var testWhenSegmentedBarIsCreatedSelectedIndexIsUndefined = function () {
|
|
buildUIAndRunTest(_createSegmentedBar(), function (views: Array<View>) {
|
|
var segmentedBar = <segmentedBarModule.SegmentedBar>views[0];
|
|
var expectedValue = -1;
|
|
var actualValue = segmentedBar.selectedIndex;
|
|
TKUnit.assert(actualValue === expectedValue, "Actual: " + actualValue + "; Expected: " + expectedValue);
|
|
});
|
|
};
|
|
|
|
export var testWhenSettingItemsToNonEmptyArrayTheSameAmountOfNativeItemsIsCreated = function () {
|
|
buildUIAndRunTest(_createSegmentedBar(), function (views: Array<View>) {
|
|
var segmentedBar = <segmentedBarModule.SegmentedBar>views[0];
|
|
segmentedBar.items = _createItems(10);
|
|
var expectedValue = segmentedBar.items.length;
|
|
var actualValue = segmentedBarTestsNative.getNativeItemsCount(segmentedBar);
|
|
TKUnit.assert(actualValue === expectedValue, "Actual: " + actualValue + "; Expected: " + expectedValue);
|
|
});
|
|
};
|
|
|
|
export var testWhenItemsAreBoundTheTextColorIsPreserved = function () {
|
|
var segmentedBar = _createSegmentedBar();
|
|
segmentedBar.color = new Color("red");
|
|
|
|
buildUIAndRunTest(segmentedBar, function (views: Array<View>) {
|
|
segmentedBar.color = new Color("red");
|
|
|
|
var model = new Observable();
|
|
let firstSegmentedBarItem = new segmentedBarModule.SegmentedBarItem();
|
|
firstSegmentedBarItem.title = "One";
|
|
let secondSegmentedBarItem = new segmentedBarModule.SegmentedBarItem();
|
|
secondSegmentedBarItem.title = "Two";
|
|
let thirdSegmentedBarItem = new segmentedBarModule.SegmentedBarItem();
|
|
thirdSegmentedBarItem.title = "Three";
|
|
model.set("items", [firstSegmentedBarItem, secondSegmentedBarItem, thirdSegmentedBarItem]);
|
|
var options: BindingOptions = {
|
|
sourceProperty: "items",
|
|
targetProperty: "items"
|
|
};
|
|
|
|
segmentedBar.bind(options, model);
|
|
|
|
TKUnit.assert(segmentedBarTestsNative.checkNativeItemsTextColor(segmentedBar), "Items text color not preserved" + "; Expected: " + segmentedBar.color);
|
|
});
|
|
};
|
|
|
|
export var testWhenSettingItemsToEmptyArrayZeroNativeItemsAreCreated = function () {
|
|
buildUIAndRunTest(_createSegmentedBar(), function (views: Array<View>) {
|
|
var segmentedBar = <segmentedBarModule.SegmentedBar>views[0];
|
|
segmentedBar.items = [];
|
|
var expectedValue = segmentedBar.items.length;
|
|
var actualValue = segmentedBarTestsNative.getNativeItemsCount(segmentedBar);
|
|
TKUnit.assert(actualValue === expectedValue, "Actual: " + actualValue + "; Expected: " + expectedValue);
|
|
});
|
|
};
|
|
|
|
export var testSelectedIndexBecomesZeroWhenItemsBoundToNonEmptyArray = function () {
|
|
buildUIAndRunTest(_createSegmentedBar(), function (views: Array<View>) {
|
|
var segmentedBar = <segmentedBarModule.SegmentedBar>views[0];
|
|
// >> article-creating-segmentedbar-items
|
|
var items = [];
|
|
var item1 = new segmentedBarModule.SegmentedBarItem();
|
|
item1.title = "Item1";
|
|
items.push(item1);
|
|
var item2 = new segmentedBarModule.SegmentedBarItem();
|
|
item2.title = "Item2";
|
|
items.push(item2);
|
|
var item3 = new segmentedBarModule.SegmentedBarItem();
|
|
item3.title = "Item3";
|
|
items.push(item3);
|
|
segmentedBar.items = items;
|
|
// << article-creating-segmentedbar-items
|
|
var expectedValue = 0;
|
|
var actualValue = segmentedBar.selectedIndex;
|
|
TKUnit.assert(actualValue === expectedValue, "Actual: " + actualValue + "; Expected: " + expectedValue);
|
|
});
|
|
};
|
|
|
|
export var testSelectedIndexBecomesUndefinedWhenItemsBoundToEmptyArray = function () {
|
|
buildUIAndRunTest(_createSegmentedBar(), function (views: Array<View>) {
|
|
var segmentedBar = <segmentedBarModule.SegmentedBar>views[0];
|
|
segmentedBar.items = _createItems(10);
|
|
// >> artcile-selecting-item
|
|
segmentedBar.selectedIndex = 9;
|
|
// << artcile-selecting-item
|
|
segmentedBar.items = [];
|
|
var expectedValue = -1;
|
|
var actualValue = segmentedBar.selectedIndex;
|
|
TKUnit.assert(actualValue === expectedValue, "Actual: " + actualValue + "; Expected: " + expectedValue);
|
|
});
|
|
};
|
|
|
|
export var testSelectedIndexBecomesUndefinedWhenItemsBoundToUndefined = function () {
|
|
buildUIAndRunTest(_createSegmentedBar(), function (views: Array<View>) {
|
|
var segmentedBar = <segmentedBarModule.SegmentedBar>views[0];
|
|
segmentedBar.items = _createItems(10);
|
|
segmentedBar.selectedIndex = 9;
|
|
segmentedBar.items = undefined;
|
|
var expectedValue = -1;
|
|
var actualValue = segmentedBar.selectedIndex;
|
|
TKUnit.assert(actualValue === expectedValue, "Actual: " + actualValue + "; Expected: " + expectedValue);
|
|
});
|
|
};
|
|
|
|
export var testSelectedIndexBecomesUndefinedWhenItemsBoundToNull = function () {
|
|
buildUIAndRunTest(_createSegmentedBar(), function (views: Array<View>) {
|
|
var segmentedBar = <segmentedBarModule.SegmentedBar>views[0];
|
|
segmentedBar.items = _createItems(10);
|
|
segmentedBar.selectedIndex = 9;
|
|
segmentedBar.items = null;
|
|
var expectedValue = -1;
|
|
var actualValue = segmentedBar.selectedIndex;
|
|
TKUnit.assert(actualValue === expectedValue, "Actual: " + actualValue + "; Expected: " + expectedValue);
|
|
});
|
|
};
|
|
|
|
export var testItemsIsResolvedCorrectlyIfSetBeforeViewIsLoaded = function () {
|
|
var segmentedBar = _createSegmentedBar();
|
|
var expectedValue = 10;
|
|
segmentedBar.items = _createItems(expectedValue);
|
|
segmentedBar.selectedIndex = 9;
|
|
buildUIAndRunTest(segmentedBar, function (views: Array<View>) {
|
|
var segmentedBar = <segmentedBarModule.SegmentedBar>views[0];
|
|
var actualValue = segmentedBar.items.length;
|
|
TKUnit.assert(actualValue === expectedValue, "Actual: " + actualValue + "; Expected: " + expectedValue);
|
|
});
|
|
};
|
|
|
|
export var testSelectedIndexIsResolvedCorrectlyIfSetBeforeViewIsLoaded = function () {
|
|
var segmentedBar = _createSegmentedBar();
|
|
segmentedBar.items = _createItems(10);
|
|
var expectedValue = 9;
|
|
segmentedBar.selectedIndex = expectedValue;
|
|
buildUIAndRunTest(segmentedBar, function (views: Array<View>) {
|
|
var segmentedBar = <segmentedBarModule.SegmentedBar>views[0];
|
|
var actualValue = segmentedBar.selectedIndex;
|
|
TKUnit.assert(actualValue === expectedValue, "Actual: " + actualValue + "; Expected: " + expectedValue);
|
|
});
|
|
};
|
|
|
|
export var testSelectedIndexChangedIsReisedCorrectlyIfSelectedIndexIsSet = function () {
|
|
var oldIndex;
|
|
var newIndex;
|
|
var segmentedBar = _createSegmentedBar();
|
|
|
|
segmentedBar.on(segmentedBarModule.SegmentedBar.selectedIndexChangedEvent, (args: segmentedBarModule.SelectedIndexChangedEventData) => {
|
|
oldIndex = args.oldIndex;
|
|
newIndex = args.newIndex;
|
|
});
|
|
|
|
segmentedBar.items = _createItems(10);
|
|
|
|
buildUIAndRunTest(segmentedBar, function (views: Array<View>) {
|
|
var segmentedBar = <segmentedBarModule.SegmentedBar>views[0];
|
|
|
|
segmentedBar.selectedIndex = 6;
|
|
TKUnit.assertEqual(oldIndex, 0);
|
|
TKUnit.assertEqual(newIndex, 6);
|
|
|
|
segmentedBar.selectedIndex = 3;
|
|
TKUnit.assertEqual(oldIndex, 6);
|
|
TKUnit.assertEqual(newIndex, 3);
|
|
|
|
segmentedBar.selectedIndex = 9;
|
|
TKUnit.assertEqual(oldIndex, 3);
|
|
TKUnit.assertEqual(newIndex, 9);
|
|
});
|
|
};
|
|
|
|
export var testSelectedIndexChangedIsReisedCorrectlyIfSelectedIndexIsSetNative = function () {
|
|
var oldIndex;
|
|
var newIndex;
|
|
var segmentedBar = _createSegmentedBar();
|
|
|
|
segmentedBar.on(segmentedBarModule.SegmentedBar.selectedIndexChangedEvent, (args: segmentedBarModule.SelectedIndexChangedEventData) => {
|
|
oldIndex = args.oldIndex;
|
|
newIndex = args.newIndex;
|
|
});
|
|
|
|
segmentedBar.items = _createItems(10);
|
|
|
|
buildUIAndRunTest(segmentedBar, function (views: Array<View>) {
|
|
var segmentedBar = <segmentedBarModule.SegmentedBar>views[0];
|
|
|
|
segmentedBarTestsNative.setNativeSelectedIndex(segmentedBar, 6);
|
|
TKUnit.assertEqual(oldIndex, 0);
|
|
TKUnit.assertEqual(newIndex, 6);
|
|
|
|
segmentedBarTestsNative.setNativeSelectedIndex(segmentedBar, 3);
|
|
TKUnit.assertEqual(oldIndex, 6);
|
|
TKUnit.assertEqual(newIndex, 3);
|
|
|
|
segmentedBarTestsNative.setNativeSelectedIndex(segmentedBar, 9);
|
|
TKUnit.assertEqual(oldIndex, 3);
|
|
TKUnit.assertEqual(newIndex, 9);
|
|
});
|
|
};
|
|
|
|
export var testSelectedIndexChangedIsRaisedCorrectlyIfItemsNotBound = function () {
|
|
const segmentedBar = _createSegmentedBar();
|
|
let newSelectedIndex = 0;
|
|
segmentedBar.on(segmentedBarModule.SegmentedBar.selectedIndexChangedEvent, () => {
|
|
newSelectedIndex = segmentedBar.selectedIndex;
|
|
});
|
|
|
|
const item0 = new segmentedBarModule.SegmentedBarItem();
|
|
item0.title = "item 0";
|
|
segmentedBar._addChildFromBuilder("SegmentedBarItem", item0);
|
|
|
|
const item1 = new segmentedBarModule.SegmentedBarItem();
|
|
item1.title = "item 1";
|
|
segmentedBar._addChildFromBuilder("SegmentedBarItem", item1);
|
|
|
|
buildUIAndRunTest(segmentedBar, function (views: Array<View>) {
|
|
TKUnit.assertEqual(segmentedBar.items.length, 2);
|
|
|
|
segmentedBarTestsNative.setNativeSelectedIndex(segmentedBar, 1);
|
|
TKUnit.assertEqual(newSelectedIndex, 1);
|
|
});
|
|
};
|
|
|
|
export function test_SettingNumberAsTitleFromXML_DoesNotThrow() {
|
|
let segmentedBar = new segmentedBarModule.SegmentedBar();
|
|
let item = new segmentedBarModule.SegmentedBarItem();
|
|
(<any>item).title = 1;
|
|
segmentedBar.items = [item];
|
|
|
|
buildUIAndRunTest(segmentedBar, function (views: Array<View>) {
|
|
TKUnit.assertEqual(item.title, "1");
|
|
});
|
|
}
|