UNPKG

videogular2

Version:

Videogular is a video application framework for desktop and mobile powered by Angular 2.0

100 lines 15 kB
"use strict"; var vg_controls_1 = require("./vg-controls"); var vg_controls_hidden_1 = require('./../core/services/vg-controls-hidden'); var vg_api_1 = require("../core/services/vg-api"); var Observable_1 = require("rxjs/Observable"); require('rxjs/add/observable/fromEvent'); var vg_states_1 = require('../core/states/vg-states'); describe('Controls Bar', function () { var controls; var ref; var api; var hidden; beforeEach(function () { jasmine.clock().uninstall(); jasmine.clock().install(); api = new vg_api_1.VgAPI(); hidden = new vg_controls_hidden_1.VgControlsHidden(); ref = { nativeElement: { getAttribute: function (name) { return name; } } }; controls = new vg_controls_1.VgControls(api, ref, hidden); }); afterEach(function () { jasmine.clock().uninstall(); }); it('Should have been defined', function () { expect(controls).toBeTruthy(); }); it('Should listen for mouseenter and mouseleave events', function () { spyOn(Observable_1.Observable, 'fromEvent').and.callThrough(); var vgElem = document.createElement('vg-player'); api.registerElement(vgElem); controls.ngOnInit(); expect(Observable_1.Observable.fromEvent).toHaveBeenCalledWith(api.videogularElement, 'mousemove'); expect(Observable_1.Observable.fromEvent).toHaveBeenCalledWith(api.videogularElement, 'touchstart'); }); it('Should hide controls after view init', function () { spyOn(controls, 'hide').and.callFake(function () { }); controls.vgAutohide = true; controls.ngAfterViewInit(); expect(controls.hide).toHaveBeenCalled(); }); it('Should show controls after view init', function () { spyOn(controls, 'show').and.callFake(function () { }); controls.vgAutohide = false; controls.ngAfterViewInit(); expect(controls.show).toHaveBeenCalled(); }); it('Should show controls', function () { spyOn(window, 'clearTimeout').and.callFake(function () { }); spyOn(hidden, 'state').and.callFake(function () { }); controls.show(); expect(window.clearTimeout).toHaveBeenCalled(); expect(controls.hideControls).toBe(false); expect(hidden.state).toHaveBeenCalledWith(false); }); it('Should hide controls when is playing', function () { spyOn(hidden, 'state').and.callFake(function () { }); controls.vgAutohide = true; api.medias = [{ state: vg_states_1.VgStates.VG_PLAYING }]; controls.hide(); jasmine.clock().tick(3100); expect(controls.hideControls).toBe(true); expect(hidden.state).toHaveBeenCalledWith(true); }); it('Should not hide controls if player is paused', function () { controls.hideControls = false; controls.vgAutohide = false; controls.vgAutohide = true; api.medias = [{ state: vg_states_1.VgStates.VG_PAUSED }]; controls.hide(); jasmine.clock().tick(3100); expect(controls.hideControls).toBe(false); }); it('Should not hide controls if autohide is false', function () { controls.hideControls = false; controls.vgAutohide = false; controls.hide(); jasmine.clock().tick(3100); expect(controls.hideControls).toBe(false); }); it('Should start hiding controls if media is playing', function () { spyOn(controls, 'hide').and.callFake(function () { }); controls.vgAutohide = true; controls.onPlay(); expect(controls.hide).toHaveBeenCalled(); }); it('Should show controls if media is paused', function () { spyOn(hidden, 'state').and.callFake(function () { }); controls.vgAutohide = true; controls.onPause(); expect(controls.hideControls).toBe(false); expect(hidden.state).toHaveBeenCalledWith(false); }); }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vg-controls.spec.js","sourceRoot":"","sources":["vg-controls.spec.ts"],"names":[],"mappings":";AAAA,4BAAyB,eAAe,CAAC,CAAA;AACzC,mCAA+B,uCAAuC,CAAC,CAAA;AAEvE,uBAAoB,yBAAyB,CAAC,CAAA;AAC9C,2BAAyB,iBAAiB,CAAC,CAAA;AAE3C,QAAO,+BAA+B,CAAC,CAAA;AACvC,0BAAyB,0BAA0B,CAAC,CAAA;AAEpD,QAAQ,CAAC,cAAc,EAAE;IACrB,IAAI,QAAmB,CAAC;IACxB,IAAI,GAAc,CAAC;IACnB,IAAI,GAAS,CAAC;IACd,IAAI,MAAwB,CAAC;IAE7B,UAAU,CAAC;QACP,OAAO,CAAC,KAAK,EAAE,CAAC,SAAS,EAAE,CAAC;QAC5B,OAAO,CAAC,KAAK,EAAE,CAAC,OAAO,EAAE,CAAC;QAE1B,GAAG,GAAG,IAAI,cAAK,EAAE,CAAC;QAClB,MAAM,GAAG,IAAI,qCAAgB,EAAE,CAAC;QAEhC,GAAG,GAAG;YACF,aAAa,EAAE;gBACX,YAAY,EAAE,UAAC,IAAI;oBACf,MAAM,CAAC,IAAI,CAAC;gBAChB,CAAC;aACJ;SACJ,CAAC;QAEF,QAAQ,GAAG,IAAI,wBAAU,CAAC,GAAG,EAAE,GAAG,EAAE,MAAM,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC;QACN,OAAO,CAAC,KAAK,EAAE,CAAC,SAAS,EAAE,CAAC;IAChC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0BAA0B,EAAE;QAC3B,MAAM,CAAC,QAAQ,CAAC,CAAC,UAAU,EAAE,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oDAAoD,EAAE;QACrD,KAAK,CAAC,uBAAU,EAAE,WAAW,CAAC,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;QAEjD,IAAI,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;QAEjD,GAAG,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;QAE5B,QAAQ,CAAC,QAAQ,EAAE,CAAC;QAEpB,MAAM,CAAC,uBAAU,CAAC,SAAS,CAAC,CAAC,oBAAoB,CAAC,GAAG,CAAC,iBAAiB,EAAE,WAAW,CAAC,CAAC;QACtF,MAAM,CAAC,uBAAU,CAAC,SAAS,CAAC,CAAC,oBAAoB,CAAC,GAAG,CAAC,iBAAiB,EAAE,YAAY,CAAC,CAAC;IAC3F,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sCAAsC,EAAE;QACvC,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,cAAO,CAAC,CAAC,CAAC;QAE/C,QAAQ,CAAC,UAAU,GAAG,IAAI,CAAC;QAE3B,QAAQ,CAAC,eAAe,EAAE,CAAC;QAE3B,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,gBAAgB,EAAE,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sCAAsC,EAAE;QACvC,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,cAAO,CAAC,CAAC,CAAC;QAE/C,QAAQ,CAAC,UAAU,GAAG,KAAK,CAAC;QAE5B,QAAQ,CAAC,eAAe,EAAE,CAAC;QAE3B,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,gBAAgB,EAAE,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sBAAsB,EAAE;QACvB,KAAK,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,cAAO,CAAC,CAAC,CAAC;QACrD,KAAK,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,cAAO,CAAC,CAAC,CAAC;QAE9C,QAAQ,CAAC,IAAI,EAAE,CAAC;QAEhB,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,gBAAgB,EAAE,CAAC;QAC/C,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1C,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sCAAsC,EAAE;QACvC,KAAK,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,cAAO,CAAC,CAAC,CAAC;QAE9C,QAAQ,CAAC,UAAU,GAAG,IAAI,CAAC;QAC3B,GAAG,CAAC,MAAM,GAAG,CAAC,EAAC,KAAK,EAAE,oBAAQ,CAAC,UAAU,EAAC,CAAC,CAAC;QAE5C,QAAQ,CAAC,IAAI,EAAE,CAAC;QAEhB,OAAO,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3B,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8CAA8C,EAAE;QAC/C,QAAQ,CAAC,YAAY,GAAG,KAAK,CAAC;QAC9B,QAAQ,CAAC,UAAU,GAAG,KAAK,CAAC;QAE5B,QAAQ,CAAC,UAAU,GAAG,IAAI,CAAC;QAC3B,GAAG,CAAC,MAAM,GAAG,CAAC,EAAC,KAAK,EAAE,oBAAQ,CAAC,SAAS,EAAC,CAAC,CAAC;QAE3C,QAAQ,CAAC,IAAI,EAAE,CAAC;QAEhB,OAAO,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3B,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+CAA+C,EAAE;QAChD,QAAQ,CAAC,YAAY,GAAG,KAAK,CAAC;QAC9B,QAAQ,CAAC,UAAU,GAAG,KAAK,CAAC;QAE5B,QAAQ,CAAC,IAAI,EAAE,CAAC;QAEhB,OAAO,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3B,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE;QACnD,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,cAAO,CAAC,CAAC,CAAC;QAE/C,QAAQ,CAAC,UAAU,GAAG,IAAI,CAAC;QAE3B,QAAQ,CAAC,MAAM,EAAE,CAAC;QAElB,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,gBAAgB,EAAE,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE;QAC1C,KAAK,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,cAAO,CAAC,CAAC,CAAC;QAE9C,QAAQ,CAAC,UAAU,GAAG,IAAI,CAAC;QAE3B,QAAQ,CAAC,OAAO,EAAE,CAAC;QAEnB,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1C,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC","sourcesContent":["import {VgControls} from \"./vg-controls\";\nimport {VgControlsHidden} from './../core/services/vg-controls-hidden';\nimport {ElementRef} from \"@angular/core\";\nimport {VgAPI} from \"../core/services/vg-api\";\nimport {Observable} from \"rxjs/Observable\";\n\nimport 'rxjs/add/observable/fromEvent';\nimport { VgStates } from '../core/states/vg-states';\n\ndescribe('Controls Bar', () => {\n    let controls:VgControls;\n    let ref:ElementRef;\n    let api:VgAPI;\n    let hidden: VgControlsHidden;\n\n    beforeEach(() => {\n        jasmine.clock().uninstall();\n        jasmine.clock().install();\n\n        api = new VgAPI();\n        hidden = new VgControlsHidden();\n\n        ref = {\n            nativeElement: {\n                getAttribute: (name) => {\n                    return name;\n                }\n            }\n        };\n\n        controls = new VgControls(api, ref, hidden);\n    });\n\n    afterEach(() => {\n        jasmine.clock().uninstall();\n    });\n\n    it('Should have been defined', () => {\n        expect(controls).toBeTruthy();\n    });\n\n    it('Should listen for mouseenter and mouseleave events', () => {\n        spyOn(Observable, 'fromEvent').and.callThrough();\n\n        let vgElem = document.createElement('vg-player');\n\n        api.registerElement(vgElem);\n\n        controls.ngOnInit();\n\n        expect(Observable.fromEvent).toHaveBeenCalledWith(api.videogularElement, 'mousemove');\n        expect(Observable.fromEvent).toHaveBeenCalledWith(api.videogularElement, 'touchstart');\n    });\n\n    it('Should hide controls after view init', () => {\n        spyOn(controls, 'hide').and.callFake(() => {});\n\n        controls.vgAutohide = true;\n\n        controls.ngAfterViewInit();\n\n        expect(controls.hide).toHaveBeenCalled();\n    });\n\n    it('Should show controls after view init', () => {\n        spyOn(controls, 'show').and.callFake(() => {});\n\n        controls.vgAutohide = false;\n\n        controls.ngAfterViewInit();\n\n        expect(controls.show).toHaveBeenCalled();\n    });\n\n    it('Should show controls', () => {\n        spyOn(window, 'clearTimeout').and.callFake(() => {});\n        spyOn(hidden, 'state').and.callFake(() => {});\n\n        controls.show();\n\n        expect(window.clearTimeout).toHaveBeenCalled();\n        expect(controls.hideControls).toBe(false);\n        expect(hidden.state).toHaveBeenCalledWith(false);\n    });\n\n    it('Should hide controls when is playing', () => {\n        spyOn(hidden, 'state').and.callFake(() => {});\n\n        controls.vgAutohide = true;\n        api.medias = [{state: VgStates.VG_PLAYING}];\n\n        controls.hide();\n\n        jasmine.clock().tick(3100);\n        expect(controls.hideControls).toBe(true);\n        expect(hidden.state).toHaveBeenCalledWith(true);\n    });\n\n    it('Should not hide controls if player is paused', () => {\n        controls.hideControls = false;\n        controls.vgAutohide = false;\n\n        controls.vgAutohide = true;\n        api.medias = [{state: VgStates.VG_PAUSED}];\n\n        controls.hide();\n\n        jasmine.clock().tick(3100);\n        expect(controls.hideControls).toBe(false);\n    });\n\n    it('Should not hide controls if autohide is false', () => {\n        controls.hideControls = false;\n        controls.vgAutohide = false;\n\n        controls.hide();\n\n        jasmine.clock().tick(3100);\n        expect(controls.hideControls).toBe(false);\n    });\n\n    it('Should start hiding controls if media is playing', () => {\n        spyOn(controls, 'hide').and.callFake(() => {});\n\n        controls.vgAutohide = true;\n\n        controls.onPlay();\n\n        expect(controls.hide).toHaveBeenCalled();\n    });\n\n    it('Should show controls if media is paused', () => {\n        spyOn(hidden, 'state').and.callFake(() => {});\n\n        controls.vgAutohide = true;\n\n        controls.onPause();\n\n        expect(controls.hideControls).toBe(false);\n        expect(hidden.state).toHaveBeenCalledWith(false);\n    });\n});\n\ninterface DecoratorInvocation {\n  type: Function;\n  args?: any[];\n}\n"]}