UNPKG

@genialis/resolwe

Version:
111 lines (109 loc) 15.2 kB
"use strict"; var __extends = (this && this.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; return extendStatics(d, b); }; return function (d, b) { extendStatics(d, b); function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; Object.defineProperty(exports, "__esModule", { value: true }); var _ = require("lodash"); var base_1 = require("./base"); var component_1 = require("../../tests/component"); component_1.describeComponent('base component', [], function (tester) { var DummyComponent = /** @class */ (function (_super) { __extends(DummyComponent, _super); // @ngInject DummyComponent.$inject = ["$scope"]; function DummyComponent($scope) { var _this = _super.call(this, $scope) || this; _this.array = []; _this.strObservable = _this.createWatchObservable(function () { return _this.str; }); _this.arrayObservable = _this.createWatchObservable(function () { return _this.array; }, true); return _this; } DummyComponent = __decorate([ base_1.component({ module: tester.module, directive: 'gen-watch-observable', }) ], DummyComponent); return DummyComponent; }(base_1.ComponentBase)); it('should reactively update on shallow component changes', function () { var dummyComponent = tester.createComponent(DummyComponent.asView().template); // Test this.str var strSpy = jasmine.createSpy('strSpy'); dummyComponent.ctrl.strObservable .distinctUntilChanged() .subscribe(function (value) { return strSpy(_.cloneDeep(value)); }); dummyComponent.ctrl.str = 'some value'; tester.digest(); expect(strSpy.calls.count()).toBe(2); expect(strSpy.calls.first().args[0]).toBeUndefined(); expect(strSpy.calls.mostRecent().args[0]).toBe('some value'); }); it('should reactively update on deep component changes', function () { var dummyComponent = tester.createComponent(DummyComponent.asView().template); // Test this.array var arraySpy = jasmine.createSpy('arraySpy'); dummyComponent.ctrl.arrayObservable .filter(function (value) { return !_.isEmpty(value); }) .subscribe(function (value) { return arraySpy(_.cloneDeep(value)); }); dummyComponent.ctrl.array.push('some value'); tester.digest(); dummyComponent.ctrl.array.push('some other value'); tester.digest(); expect(arraySpy.calls.all()[0].args[0]).toEqual(['some value']); expect(arraySpy.calls.all()[1].args[0]).toEqual(['some value', 'some other value']); }); it('should support watch', function () { var dummyComponent = tester.createComponent(DummyComponent.asView().template); // No watch should be created if computation is immediately unsubscribed. var expression = 0; var executed = 0; var watchComputation = dummyComponent.ctrl.watch(function () { return expression; }, function (computation) { executed++; expect(computation.isDone()).toBeFalsy(); computation.unsubscribe(); }); expect(watchComputation.isDone()).toBeTruthy(); expression = 1; tester.digest(); expect(executed).toBe(1); // Check that watching works correctly. expression = 0; executed = 0; watchComputation = dummyComponent.ctrl.watch(function () { return expression; }, function (computation) { executed++; if (executed > 2) computation.unsubscribe(); }); expect(watchComputation.isDone()).toBeFalsy(); expression = 1; tester.digest(); // Just to check that watch is only evaluated when the expression changes. tester.digest(); expect(executed).toBe(2); expression = 2; tester.digest(); expect(executed).toBe(3); // Check that unsubscribe actually stops the watch. expression = 3; tester.digest(); expect(executed).toBe(3); }); }); //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/core/components/base.spec.ts"],"names":[],"mappings":"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","file":"core/components/base.spec.js","sourcesContent":["import * as _ from 'lodash';\nimport * as Rx from 'rx';\nimport * as angular from 'angular';\n\nimport {ComponentBase, component} from './base';\nimport {describeComponent} from '../../tests/component';\n\ndescribeComponent('base component', [], (tester) => {\n    @component({\n        module: tester.module,\n        directive: 'gen-watch-observable',\n    })\n    class DummyComponent extends ComponentBase {\n        public str: string;\n        public strObservable: Rx.Observable<string>;\n\n        public array: string[] = [];\n        public arrayObservable: Rx.Observable<string[]>;\n\n        // @ngInject\n        constructor($scope: angular.IScope) {\n            super($scope);\n\n            this.strObservable = this.createWatchObservable(() => this.str);\n            this.arrayObservable = this.createWatchObservable(() => this.array, true);\n        }\n    }\n\n    it('should reactively update on shallow component changes', () => {\n        const dummyComponent = tester.createComponent<DummyComponent>(\n            DummyComponent.asView().template\n        );\n\n        // Test this.str\n        const strSpy = jasmine.createSpy('strSpy');\n        dummyComponent.ctrl.strObservable\n            .distinctUntilChanged()\n            .subscribe((value) => strSpy(_.cloneDeep(value)));\n\n        dummyComponent.ctrl.str = 'some value';\n        tester.digest();\n\n        expect(strSpy.calls.count()).toBe(2);\n        expect(strSpy.calls.first().args[0]).toBeUndefined();\n        expect(strSpy.calls.mostRecent().args[0]).toBe('some value');\n    });\n\n    it('should reactively update on deep component changes', () => {\n        const dummyComponent = tester.createComponent<DummyComponent>(\n            DummyComponent.asView().template\n        );\n\n        // Test this.array\n        const arraySpy = jasmine.createSpy('arraySpy');\n        dummyComponent.ctrl.arrayObservable\n            .filter((value) => !_.isEmpty(value))\n            .subscribe((value) => arraySpy(_.cloneDeep(value)));\n\n        dummyComponent.ctrl.array.push('some value');\n        tester.digest();\n        dummyComponent.ctrl.array.push('some other value');\n        tester.digest();\n\n        expect(arraySpy.calls.all()[0].args[0]).toEqual(['some value']);\n        expect(arraySpy.calls.all()[1].args[0]).toEqual(['some value', 'some other value']);\n    });\n\n    it('should support watch', () => {\n        const dummyComponent = tester.createComponent<DummyComponent>(\n            DummyComponent.asView().template\n        );\n\n        // No watch should be created if computation is immediately unsubscribed.\n        let expression = 0;\n        let executed = 0;\n        let watchComputation = dummyComponent.ctrl.watch(() => expression, (computation) => {\n            executed++;\n            expect(computation.isDone()).toBeFalsy();\n            computation.unsubscribe();\n        });\n        expect(watchComputation.isDone()).toBeTruthy();\n\n        expression = 1;\n        tester.digest();\n        expect(executed).toBe(1);\n\n        // Check that watching works correctly.\n        expression = 0;\n        executed = 0;\n        watchComputation = dummyComponent.ctrl.watch(() => expression, (computation) => {\n            executed++;\n            if (executed > 2) computation.unsubscribe();\n        });\n        expect(watchComputation.isDone()).toBeFalsy();\n\n        expression = 1;\n        tester.digest();\n        // Just to check that watch is only evaluated when the expression changes.\n        tester.digest();\n        expect(executed).toBe(2);\n\n        expression = 2;\n        tester.digest();\n        expect(executed).toBe(3);\n\n        // Check that unsubscribe actually stops the watch.\n        expression = 3;\n        tester.digest();\n        expect(executed).toBe(3);\n    });\n});\n\n\n"]}