Files
NativeScript/tests/app/ui/switch/switch-tests.ts
Alexander Vakrilov cc97a16800 feat: Scoped Packages (#7911)
* 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
2019-10-17 00:45:33 +03:00

165 lines
5.8 KiB
TypeScript

import * as TKUnit from "../../tk-unit";
import * as helper from "../../ui-helper";
import * as viewModule from "@nativescript/core/ui/core/view";
import * as bindable from "@nativescript/core/ui/core/bindable";
import * as observable from "@nativescript/core/data/observable";
import * as color from "@nativescript/core/color";
import * as platform from "@nativescript/core/platform";
// >> article-require-switch
import * as switchModule from "@nativescript/core/ui/switch";
// << article-require-switch
// ### Binding the Switch checked property and Button isEanbled property to a observable view-model property.
// >> article-binding-switch-property
function pageLoaded(args) {
var page = args.object;
var obj = new observable.Observable();
obj.set("someProperty", false);
page.bindingContext = obj;
}
exports.pageLoaded = pageLoaded;
// << article-binding-switch-property
export function test_recycling() {
helper.nativeView_recycling_test(() => new switchModule.Switch());
}
export function test_default_TNS_values() {
// >> article-create-switch
var mySwitch = new switchModule.Switch();
// << article-create-switch
TKUnit.assertEqual(mySwitch.checked, false, "Default switch.checked");
}
export function test_default_native_values() {
var mySwitch = new switchModule.Switch();
function testAction(views: Array<viewModule.View>) {
TKUnit.assertEqual(getNativeValue(mySwitch), false, "Default native switch.checked");
}
helper.buildUIAndRunTest(mySwitch, testAction);
}
// Uncomment this when find way to check android Drawable color set by setColorFilter() method.
if (platform.device.os === platform.platformNames.ios) {
exports.test_set_color = function () {
var mySwitch = new switchModule.Switch();
mySwitch.color = new color.Color("red");
function testAction(views: Array<viewModule.View>) {
TKUnit.assert(mySwitch.color.ios.isEqual(mySwitch.ios.thumbTintColor), "mySwitch.color");
}
helper.buildUIAndRunTest(mySwitch, testAction);
};
exports.test_set_backgroundColor = function () {
var mySwitch = new switchModule.Switch();
mySwitch.backgroundColor = new color.Color("red");
function testAction(views: Array<viewModule.View>) {
TKUnit.assert(CGColorEqualToColor((<color.Color>mySwitch.backgroundColor).ios.CGColor, mySwitch.ios.onTintColor.CGColor), "mySwitch.color");
}
helper.buildUIAndRunTest(mySwitch, testAction);
};
}
export function test_set_TNS_checked_updates_native_checked() {
var mySwitch = new switchModule.Switch();
function testAction(views: Array<viewModule.View>) {
// >> article-setting-checked-property
mySwitch.checked = true;
// << article-setting-checked-property
TKUnit.assertEqual(getNativeValue(mySwitch), true, "Native checked is different from TNS checked.");
}
helper.buildUIAndRunTest(mySwitch, testAction);
}
export function test_set_native_checked_updates_TNS_checked() {
var mySwitch = new switchModule.Switch();
function testAction(views: Array<viewModule.View>) {
setNativeValue(mySwitch, true);
TKUnit.assertEqual(mySwitch.checked, true, "Native checked is different from TNS checked.");
}
helper.buildUIAndRunTest(mySwitch, testAction);
}
export function test_set_native_checked_triggers_propertyChanged() {
var mySwitch = new switchModule.Switch();
function testAction(views: Array<viewModule.View>) {
var checkedChanged = false;
var allChanges = 0;
mySwitch.on("checkedChange", function (data: observable.EventData) {
allChanges++;
var propertyData = <observable.PropertyChangeData>data;
if (propertyData && propertyData.propertyName === "checked" && propertyData.value === true) {
checkedChanged = true;
}
});
setNativeValue(mySwitch, true);
mySwitch.off("checkedChange");
TKUnit.assert(checkedChanged, "Property changed for checked not called.");
TKUnit.assertEqual(allChanges, 1, "Property changed callbacks.");
}
helper.buildUIAndRunTest(mySwitch, testAction);
}
export function test_binding_value_to_model() {
var mySwitch = new switchModule.Switch();
function testAction(views: Array<viewModule.View>) {
// >> aricle-binding-checked-property
var model = new observable.Observable();
model.set("enabled", true);
var options: bindable.BindingOptions = {
sourceProperty: "enabled",
targetProperty: "checked"
};
mySwitch.bind(options, model);
// mySwitch.checked is now true
// >> (hide)
TKUnit.assertEqual(mySwitch.checked, true, "mySwitch.checked");
// << (hide)
model.set("enabled", false);
// mySwitch.checked is now false
// >> (hide)
TKUnit.assertEqual(mySwitch.checked, false, "mySwitch.checked");
// << (hide)
// << aricle-binding-checked-property
}
helper.buildUIAndRunTest(mySwitch, testAction);
}
function getNativeValue(mySwitch: switchModule.Switch): boolean {
if (platform.isAndroid) {
const nativeView: android.widget.Switch = mySwitch.nativeViewProtected;
return nativeView.isChecked();
} else if (mySwitch.ios) {
return mySwitch.ios.on;
}
}
function setNativeValue(mySwitch: switchModule.Switch, value: boolean) {
if (platform.isAndroid) {
const nativeView: android.widget.Switch = mySwitch.nativeViewProtected;
nativeView.setChecked(value);
}
else if (mySwitch.ios) {
mySwitch.ios.on = value;
// setting value trough code does not send notification, so simulate that manually.
mySwitch.ios.sendActionsForControlEvents(UIControlEvents.ValueChanged);
}
}