UNPKG

videogular2

Version:

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

96 lines 16.9 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); var core_1 = require("@angular/core"); var vg_fullscreen_api_1 = require("./vg-fullscreen-api"); var vg_utils_1 = require("./vg-utils"); describe('Videogular Player', function () { var medias; var elem; var fsAPI; beforeEach(function () { medias = new core_1.QueryList(); elem = document.createElement('video'); fsAPI = new vg_fullscreen_api_1.VgFullscreenAPI(); fsAPI.isAvailable = true; fsAPI.nativeFullscreen = true; fsAPI.init(elem, medias); }); it('Should create polyfills on init', function () { expect(fsAPI.polyfill.enabled).toBe('fullscreenEnabled'); expect(fsAPI.polyfill.element).toBe('fullscreenElement'); expect(fsAPI.polyfill.request).toBe('requestFullscreen'); expect(fsAPI.polyfill.exit).toBe('exitFullscreen'); expect(fsAPI.polyfill.onchange).toBe('fullscreenchange'); expect(fsAPI.polyfill.onerror).toBe('fullscreenerror'); }); it('Should request an element to enter in fullscreen mode (desktop)', function () { spyOn(fsAPI, 'enterElementInFullScreen').and.callFake(function () { }); fsAPI.request(null); expect(fsAPI.isFullscreen).toBeTruthy(); expect(fsAPI.enterElementInFullScreen).toHaveBeenCalledWith(elem); }); it('Should request an element to enter in fullscreen mode (mobile)', function () { spyOn(vg_utils_1.VgUtils, 'isMobileDevice').and.callFake(function () { return true; }); spyOn(fsAPI, 'enterElementInFullScreen').and.callFake(function () { }); fsAPI.request(null); expect(fsAPI.isFullscreen).toBeTruthy(); expect(vg_utils_1.VgUtils.isMobileDevice).toHaveBeenCalled(); expect(fsAPI.enterElementInFullScreen).toHaveBeenCalledWith(elem); }); it('Should request an element to enter in fullscreen mode (mobile with param elem)', function () { spyOn(vg_utils_1.VgUtils, 'isMobileDevice').and.callFake(function () { return true; }); spyOn(fsAPI, 'enterElementInFullScreen').and.callFake(function () { }); fsAPI.request(elem); expect(fsAPI.isFullscreen).toBeTruthy(); expect(vg_utils_1.VgUtils.isMobileDevice).toHaveBeenCalled(); expect(fsAPI.enterElementInFullScreen).toHaveBeenCalledWith(elem); }); it('Should not request an element to enter in fullscreen mode', function () { spyOn(fsAPI, 'enterElementInFullScreen').and.callFake(function () { }); fsAPI.nativeFullscreen = false; fsAPI.request(elem); expect(fsAPI.enterElementInFullScreen).not.toHaveBeenCalled(); }); it('Should enter in fullscreen mode', function () { spyOn(elem, 'requestFullscreen').and.callThrough(); fsAPI.enterElementInFullScreen(elem); expect(elem.requestFullscreen).toHaveBeenCalled(); }); it('Should request an element to exit from fullscreen mode (native)', function () { fsAPI.polyfill.exit = 'mockedExitFunction'; document.mockedExitFunction = function () { }; spyOn(document, 'mockedExitFunction').and.callThrough(); fsAPI.exit(); expect(fsAPI.isFullscreen).toBeFalsy(); expect(document.mockedExitFunction).toHaveBeenCalled(); }); it('Should request an element to exit from fullscreen mode (emulated)', function () { fsAPI.polyfill.exit = 'mockedExitFunction'; document.mockedExitFunction = function () { }; spyOn(document, 'mockedExitFunction').and.callThrough(); fsAPI.nativeFullscreen = false; fsAPI.exit(); expect(fsAPI.isFullscreen).toBeFalsy(); expect(document.mockedExitFunction).not.toHaveBeenCalled(); }); it('Should enter videogular element to fullscreen mode', function () { fsAPI.videogularElement = { id: 'vgElem' }; spyOn(fsAPI, 'request').and.callFake(function () { }); fsAPI.toggleFullscreen(); expect(fsAPI.request).toHaveBeenCalledWith(null); }); it('Should enter other element to fullscreen mode', function () { var element = { id: 'main' }; fsAPI.videogularElement = { id: 'vgElem' }; spyOn(fsAPI, 'request').and.callFake(function () { }); fsAPI.toggleFullscreen(element); expect(fsAPI.request).toHaveBeenCalledWith(element); }); it('Should exit from fullscreen mode', function () { fsAPI.isFullscreen = true; spyOn(fsAPI, 'exit').and.callFake(function () { }); fsAPI.toggleFullscreen(); expect(fsAPI.exit).toHaveBeenCalled(); }); }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vg-fullscreen-api.spec.js","sourceRoot":"","sources":["../../../../src/core/services/vg-fullscreen-api.spec.ts"],"names":[],"mappings":";;AAAA,sCAAwC;AACxC,yDAAoD;AACpD,uCAAmC;AAEnC,QAAQ,CAAC,mBAAmB,EAAE;IAC1B,IAAI,MAAqB,CAAC;IAC1B,IAAI,IAAgB,CAAC;IACrB,IAAI,KAAsB,CAAC;IAE3B,UAAU,CAAC;QACP,MAAM,GAAG,IAAI,gBAAS,EAAE,CAAC;QACzB,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QAEvC,KAAK,GAAG,IAAI,mCAAe,EAAE,CAAC;QAC9B,KAAK,CAAC,WAAW,GAAG,IAAI,CAAC;QACzB,KAAK,CAAC,gBAAgB,GAAG,IAAI,CAAC;QAC9B,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;IAC7B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iCAAiC,EAAE;QAClC,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QACzD,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QACzD,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QACzD,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QACnD,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QACzD,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAC3D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iEAAiE,EAAE;QAClE,KAAK,CAAC,KAAK,EAAE,0BAA0B,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,cAAO,CAAC,CAAC,CAAC;QAEhE,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAEpB,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,UAAU,EAAE,CAAC;QACxC,MAAM,CAAC,KAAK,CAAC,wBAAwB,CAAC,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;IACtE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gEAAgE,EAAE;QACjE,KAAK,CAAC,kBAAO,EAAE,gBAAgB,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,cAAO,OAAO,IAAI,CAAC,CAAA,CAAC,CAAC,CAAC;QACpE,KAAK,CAAC,KAAK,EAAE,0BAA0B,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,cAAO,CAAC,CAAC,CAAC;QAEhE,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAEpB,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,UAAU,EAAE,CAAC;QACxC,MAAM,CAAC,kBAAO,CAAC,cAAc,CAAC,CAAC,gBAAgB,EAAE,CAAC;QAClD,MAAM,CAAC,KAAK,CAAC,wBAAwB,CAAC,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;IACtE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gFAAgF,EAAE;QACjF,KAAK,CAAC,kBAAO,EAAE,gBAAgB,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,cAAO,OAAO,IAAI,CAAC,CAAA,CAAC,CAAC,CAAC;QACpE,KAAK,CAAC,KAAK,EAAE,0BAA0B,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,cAAO,CAAC,CAAC,CAAC;QAEhE,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAEpB,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,UAAU,EAAE,CAAC;QACxC,MAAM,CAAC,kBAAO,CAAC,cAAc,CAAC,CAAC,gBAAgB,EAAE,CAAC;QAClD,MAAM,CAAC,KAAK,CAAC,wBAAwB,CAAC,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;IACtE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2DAA2D,EAAE;QAC5D,KAAK,CAAC,KAAK,EAAE,0BAA0B,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,cAAO,CAAC,CAAC,CAAC;QAEhE,KAAK,CAAC,gBAAgB,GAAG,KAAK,CAAC;QAC/B,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAEpB,MAAM,CAAC,KAAK,CAAC,wBAAwB,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;IAClE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iCAAiC,EAAE;QAClC,KAAK,CAAM,IAAI,EAAE,mBAAmB,CAAC,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;QAExD,KAAK,CAAC,wBAAwB,CAAC,IAAI,CAAC,CAAC;QAErC,MAAM,CAAO,IAAK,CAAC,iBAAiB,CAAC,CAAC,gBAAgB,EAAE,CAAC;IAC7D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iEAAiE,EAAE;QAClE,KAAK,CAAC,QAAQ,CAAC,IAAI,GAAG,oBAAoB,CAAC;QAErC,QAAS,CAAC,kBAAkB,GAAG,cAAO,CAAC,CAAC;QAE9C,KAAK,CAAC,QAAQ,EAAE,oBAA2B,CAAC,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;QAE/D,KAAK,CAAC,IAAI,EAAE,CAAC;QAEb,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,SAAS,EAAE,CAAC;QACvC,MAAM,CAAO,QAAS,CAAC,kBAAkB,CAAC,CAAC,gBAAgB,EAAE,CAAC;IAClE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mEAAmE,EAAE;QACpE,KAAK,CAAC,QAAQ,CAAC,IAAI,GAAG,oBAAoB,CAAC;QAErC,QAAS,CAAC,kBAAkB,GAAG,cAAO,CAAC,CAAC;QAE9C,KAAK,CAAC,QAAQ,EAAE,oBAA2B,CAAC,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;QAE/D,KAAK,CAAC,gBAAgB,GAAG,KAAK,CAAC;QAC/B,KAAK,CAAC,IAAI,EAAE,CAAC;QAEb,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,SAAS,EAAE,CAAC;QACvC,MAAM,CAAO,QAAS,CAAC,kBAAkB,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;IACtE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oDAAoD,EAAE;QACrD,KAAK,CAAC,iBAAiB,GAAgB,EAAC,EAAE,EAAE,QAAQ,EAAC,CAAC;QAEtD,KAAK,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,cAAO,CAAC,CAAC,CAAC;QAE/C,KAAK,CAAC,gBAAgB,EAAE,CAAC;QAEzB,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+CAA+C,EAAE;QAChD,IAAI,OAAO,GAAG,EAAC,EAAE,EAAE,MAAM,EAAC,CAAC;QAE3B,KAAK,CAAC,iBAAiB,GAAgB,EAAC,EAAE,EAAE,QAAQ,EAAC,CAAC;QAEtD,KAAK,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,cAAO,CAAC,CAAC,CAAC;QAE/C,KAAK,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;QAEhC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE;QACnC,KAAK,CAAC,YAAY,GAAG,IAAI,CAAC;QAE1B,KAAK,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,cAAO,CAAC,CAAC,CAAC;QAE5C,KAAK,CAAC,gBAAgB,EAAE,CAAC;QAEzB,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,gBAAgB,EAAE,CAAC;IAC1C,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC","sourcesContent":["import {QueryList} from \"@angular/core\";\nimport {VgFullscreenAPI} from \"./vg-fullscreen-api\";\nimport {VgUtils} from \"./vg-utils\";\n\ndescribe('Videogular Player', () => {\n    let medias:QueryList<any>;\n    let elem:HTMLElement;\n    let fsAPI: VgFullscreenAPI;\n\n    beforeEach(() => {\n        medias = new QueryList();\n        elem = document.createElement('video');\n\n        fsAPI = new VgFullscreenAPI();\n        fsAPI.isAvailable = true;\n        fsAPI.nativeFullscreen = true;\n        fsAPI.init(elem, medias);\n    });\n\n    it('Should create polyfills on init', () => {\n        expect(fsAPI.polyfill.enabled).toBe('fullscreenEnabled');\n        expect(fsAPI.polyfill.element).toBe('fullscreenElement');\n        expect(fsAPI.polyfill.request).toBe('requestFullscreen');\n        expect(fsAPI.polyfill.exit).toBe('exitFullscreen');\n        expect(fsAPI.polyfill.onchange).toBe('fullscreenchange');\n        expect(fsAPI.polyfill.onerror).toBe('fullscreenerror');\n    });\n\n    it('Should request an element to enter in fullscreen mode (desktop)', () => {\n        spyOn(fsAPI, 'enterElementInFullScreen').and.callFake(() => {});\n\n        fsAPI.request(null);\n\n        expect(fsAPI.isFullscreen).toBeTruthy();\n        expect(fsAPI.enterElementInFullScreen).toHaveBeenCalledWith(elem);\n    });\n\n    it('Should request an element to enter in fullscreen mode (mobile)', () => {\n        spyOn(VgUtils, 'isMobileDevice').and.callFake(() => {return true;});\n        spyOn(fsAPI, 'enterElementInFullScreen').and.callFake(() => {});\n\n        fsAPI.request(null);\n\n        expect(fsAPI.isFullscreen).toBeTruthy();\n        expect(VgUtils.isMobileDevice).toHaveBeenCalled();\n        expect(fsAPI.enterElementInFullScreen).toHaveBeenCalledWith(elem);\n    });\n\n    it('Should request an element to enter in fullscreen mode (mobile with param elem)', () => {\n        spyOn(VgUtils, 'isMobileDevice').and.callFake(() => {return true;});\n        spyOn(fsAPI, 'enterElementInFullScreen').and.callFake(() => {});\n\n        fsAPI.request(elem);\n\n        expect(fsAPI.isFullscreen).toBeTruthy();\n        expect(VgUtils.isMobileDevice).toHaveBeenCalled();\n        expect(fsAPI.enterElementInFullScreen).toHaveBeenCalledWith(elem);\n    });\n\n    it('Should not request an element to enter in fullscreen mode', () => {\n        spyOn(fsAPI, 'enterElementInFullScreen').and.callFake(() => {});\n\n        fsAPI.nativeFullscreen = false;\n        fsAPI.request(elem);\n\n        expect(fsAPI.enterElementInFullScreen).not.toHaveBeenCalled();\n    });\n\n    it('Should enter in fullscreen mode', () => {\n        spyOn(<any>elem, 'requestFullscreen').and.callThrough();\n\n        fsAPI.enterElementInFullScreen(elem);\n\n        expect((<any>elem).requestFullscreen).toHaveBeenCalled();\n    });\n\n    it('Should request an element to exit from fullscreen mode (native)', () => {\n        fsAPI.polyfill.exit = 'mockedExitFunction';\n\n        (<any>document).mockedExitFunction = () => {};\n\n        spyOn(document, 'mockedExitFunction' as any).and.callThrough();\n\n        fsAPI.exit();\n\n        expect(fsAPI.isFullscreen).toBeFalsy();\n        expect((<any>document).mockedExitFunction).toHaveBeenCalled();\n    });\n\n    it('Should request an element to exit from fullscreen mode (emulated)', () => {\n        fsAPI.polyfill.exit = 'mockedExitFunction';\n\n        (<any>document).mockedExitFunction = () => {};\n\n        spyOn(document, 'mockedExitFunction' as any).and.callThrough();\n\n        fsAPI.nativeFullscreen = false;\n        fsAPI.exit();\n\n        expect(fsAPI.isFullscreen).toBeFalsy();\n        expect((<any>document).mockedExitFunction).not.toHaveBeenCalled();\n    });\n\n    it('Should enter videogular element to fullscreen mode', () => {\n        fsAPI.videogularElement = <HTMLElement>{id: 'vgElem'};\n\n        spyOn(fsAPI, 'request').and.callFake(() => {});\n\n        fsAPI.toggleFullscreen();\n\n        expect(fsAPI.request).toHaveBeenCalledWith(null);\n    });\n\n    it('Should enter other element to fullscreen mode', () => {\n        let element = {id: 'main'};\n\n        fsAPI.videogularElement = <HTMLElement>{id: 'vgElem'};\n\n        spyOn(fsAPI, 'request').and.callFake(() => {});\n\n        fsAPI.toggleFullscreen(element);\n\n        expect(fsAPI.request).toHaveBeenCalledWith(element);\n    });\n\n    it('Should exit from fullscreen mode', () => {\n        fsAPI.isFullscreen = true;\n\n        spyOn(fsAPI, 'exit').and.callFake(() => {});\n\n        fsAPI.toggleFullscreen();\n\n        expect(fsAPI.exit).toHaveBeenCalled();\n    });\n});\n"]}