videogular2
Version:
Videogular is a video application framework for desktop and mobile powered by Angular 2.0
95 lines • 17.1 kB
JavaScript
;
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('webkitFullscreenEnabled');
expect(fsAPI.polyfill.element).toBe('webkitFullscreenElement');
expect(fsAPI.polyfill.request).toBe('webkitRequestFullscreen');
expect(fsAPI.polyfill.exit).toBe('webkitExitFullscreen');
expect(fsAPI.polyfill.onchange).toBe('webkitfullscreenchange');
expect(fsAPI.polyfill.onerror).toBe('webkitfullscreenerror');
});
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, 'webkitRequestFullscreen').and.callThrough();
fsAPI.enterElementInFullScreen(elem);
expect(elem.webkitRequestFullscreen).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":["vg-fullscreen-api.spec.ts"],"names":[],"mappings":"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","sourcesContent":["import {QueryList} from \"@angular/core\";\nimport {VgFullscreenAPI} from \"./vg-fullscreen-api\";\nimport {VgMedia} from \"../vg-media/vg-media\";\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('webkitFullscreenEnabled');\n        expect(fsAPI.polyfill.element).toBe('webkitFullscreenElement');\n        expect(fsAPI.polyfill.request).toBe('webkitRequestFullscreen');\n        expect(fsAPI.polyfill.exit).toBe('webkitExitFullscreen');\n        expect(fsAPI.polyfill.onchange).toBe('webkitfullscreenchange');\n        expect(fsAPI.polyfill.onerror).toBe('webkitfullscreenerror');\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, 'webkitRequestFullscreen').and.callThrough();\n\n        fsAPI.enterElementInFullScreen(elem);\n\n        expect((<any>elem).webkitRequestFullscreen).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').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').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\ninterface DecoratorInvocation {\n  type: Function;\n  args?: any[];\n}\n"]}