videogular2
Version:
Videogular is a video application framework for desktop and mobile powered by Angular 2.0
129 lines • 16.8 kB
JavaScript
;
var vg_volume_1 = require("./vg-volume");
var vg_api_1 = require("../../core/services/vg-api");
describe('Volume control', function () {
var vgVol;
var ref;
var api;
beforeEach(function () {
ref = {
nativeElement: {
getAttribute: function (name) {
return name;
}
}
};
api = new vg_api_1.VgAPI();
vgVol = new vg_volume_1.VgVolume(ref, api);
});
it('Should have isDragging set to false initially', function () {
expect(vgVol.isDragging).toBe(false);
});
describe('onPlayerReady', function () {
it('Should set vgFor', function () {
vgVol.vgFor = 'test';
vgVol.onPlayerReady();
expect(vgVol.vgFor).toBe('test');
});
it('Should set target', function () {
spyOn(api, 'getMediaById');
vgVol.onPlayerReady();
expect(api.getMediaById).toHaveBeenCalled();
});
});
describe('onMouseDown', function () {
it('Should set isDragging to true', function () {
vgVol.onMouseDown({ clientX: 0 });
expect(vgVol.isDragging).toBe(true);
});
it('Should set mouseDownPosX to event.x', function () {
vgVol.onMouseDown({ clientX: 99 });
expect(vgVol.mouseDownPosX).toBe(99);
});
});
describe('onDrag', function () {
beforeEach(function () {
spyOn(vgVol, 'setVolume');
spyOn(vgVol, 'calculateVolume');
});
it('Should call setVolume when dragging', function () {
vgVol.isDragging = true;
vgVol.onDrag({ clientX: 0 });
expect(vgVol.setVolume).toHaveBeenCalled();
});
it('Should not call setVolume when not dragging', function () {
vgVol.isDragging = false;
vgVol.onDrag({ clientX: 0 });
expect(vgVol.setVolume).not.toHaveBeenCalled();
});
});
describe('onStopDrag', function () {
beforeEach(function () {
spyOn(vgVol, 'setVolume');
spyOn(vgVol, 'calculateVolume');
});
it('Should toggle dragging value when dragging', function () {
vgVol.isDragging = true;
vgVol.mouseDownPosX = 0;
vgVol.onStopDrag({ clientX: 0 });
expect(vgVol.isDragging).toBe(false);
});
it('Should call setVolume when dragging and x positions match', function () {
vgVol.isDragging = true;
vgVol.mouseDownPosX = 0;
vgVol.onStopDrag({ clientX: 0 });
expect(vgVol.setVolume).toHaveBeenCalled();
});
it('Should not call setVolume when dragging but x positions dont match', function () {
vgVol.isDragging = true;
vgVol.mouseDownPosX = 1;
vgVol.onStopDrag({ clientX: 0 });
expect(vgVol.setVolume).not.toHaveBeenCalled();
});
it('Should not call setVolume when not dragging', function () {
vgVol.isDragging = false;
vgVol.mouseDownPosX = 0;
vgVol.onStopDrag({ clientX: 0 });
expect(vgVol.setVolume).not.toHaveBeenCalled();
});
});
describe('calculateVolume', function () {
it('Shoud calculate volume based on volumeBar position', function () {
// mock volumeBarRef ViewChild
vgVol.volumeBarRef = {
nativeElement: {
getBoundingClientRect: function () {
return { left: 5, width: 100 };
}
}
};
expect(vgVol.calculateVolume(10)).toBe(5);
});
});
describe('setVolume', function () {
it('Shoud convert volume to a value between 0 and 1', function () {
vgVol.target = {
volume: 3.33
};
vgVol.setVolume(50);
expect(vgVol.target.volume).toBe(0.5);
vgVol.setVolume(110);
expect(vgVol.target.volume).toBe(1);
vgVol.setVolume(-10);
expect(vgVol.target.volume).toBe(0);
});
});
describe('getVolume', function () {
it('Shoud get target volume when target is set', function () {
vgVol.target = {
volume: 3.33
};
expect(vgVol.getVolume()).toBe(3.33);
});
it('Shoud get 0 volume when target is not set', function () {
vgVol.target = undefined;
expect(vgVol.getVolume()).toBe(0);
});
});
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vg-volume.spec.js","sourceRoot":"","sources":["vg-volume.spec.ts"],"names":[],"mappings":"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","sourcesContent":["import {VgVolume} from \"./vg-volume\";\nimport {VgAPI} from \"../../core/services/vg-api\";\nimport {ElementRef} from \"@angular/core\";\n\ndescribe('Volume control', () => {\n    let vgVol:VgVolume;\n    let ref:ElementRef;\n    let api:VgAPI;\n\n    beforeEach(() => {\n        ref = {\n            nativeElement: {\n                getAttribute: (name) => {\n                    return name;\n                }\n            }\n        };\n\n        api = new VgAPI();\n        vgVol = new VgVolume(ref, api);\n    });\n\n    it('Should have isDragging set to false initially', () => {\n        expect(vgVol.isDragging).toBe(false);\n    });\n    \n    describe('onPlayerReady', ()=>{\n        it('Should set vgFor', () => {\n            vgVol.vgFor = 'test';\n            vgVol.onPlayerReady();\n            expect(vgVol.vgFor).toBe('test');\n        });\n        it('Should set target', () => {\n            spyOn(api, 'getMediaById');\n            vgVol.onPlayerReady();\n            expect(api.getMediaById).toHaveBeenCalled();\n        });\n    });\n\n    describe('onMouseDown', ()=>{\n        it('Should set isDragging to true', ()=>{\n            vgVol.onMouseDown({clientX: 0});\n            expect(vgVol.isDragging).toBe(true);\n        });\n        it('Should set mouseDownPosX to event.x', ()=>{\n            vgVol.onMouseDown({clientX: 99});\n            expect(vgVol.mouseDownPosX).toBe(99);\n        });\n    });\n    \n    describe('onDrag', ()=>{\n        beforeEach(()=>{\n            spyOn(vgVol, 'setVolume');\n            spyOn(vgVol, 'calculateVolume');\n        });\n        it('Should call setVolume when dragging', ()=>{\n            vgVol.isDragging = true;\n            vgVol.onDrag({clientX: 0});\n            expect(vgVol.setVolume).toHaveBeenCalled();\n        });\n        it('Should not call setVolume when not dragging', ()=>{\n            vgVol.isDragging = false;\n            vgVol.onDrag({clientX: 0});\n            expect(vgVol.setVolume).not.toHaveBeenCalled();\n        });\n    });\n\n    describe('onStopDrag', ()=>{\n        beforeEach(()=>{\n            spyOn(vgVol, 'setVolume');\n            spyOn(vgVol, 'calculateVolume');\n        });\n        it('Should toggle dragging value when dragging', ()=>{\n            vgVol.isDragging = true;\n            vgVol.mouseDownPosX = 0;\n            vgVol.onStopDrag({clientX:0});\n            expect(vgVol.isDragging).toBe(false);\n        });\n        it('Should call setVolume when dragging and x positions match', ()=>{\n            vgVol.isDragging = true;\n            vgVol.mouseDownPosX = 0;\n            vgVol.onStopDrag({clientX:0});\n            expect(vgVol.setVolume).toHaveBeenCalled();\n        });\n        it('Should not call setVolume when dragging but x positions dont match', ()=>{\n            vgVol.isDragging = true;\n            vgVol.mouseDownPosX = 1;\n            vgVol.onStopDrag({clientX:0});\n            expect(vgVol.setVolume).not.toHaveBeenCalled();\n        });\n        it('Should not call setVolume when not dragging', ()=>{\n            vgVol.isDragging = false;\n            vgVol.mouseDownPosX = 0;\n            vgVol.onStopDrag({clientX:0});\n            expect(vgVol.setVolume).not.toHaveBeenCalled();\n        });\n    });\n\n    describe('calculateVolume', ()=>{\n        it('Shoud calculate volume based on volumeBar position', ()=>{\n            // mock volumeBarRef ViewChild\n            vgVol.volumeBarRef = {\n              nativeElement: {\n                getBoundingClientRect() {\n                  return { left: 5, width: 100 }\n                }\n              }\n            };\n            expect(vgVol.calculateVolume(10)).toBe(5);\n        });\n    });\n\n    describe('setVolume', ()=>{\n        it('Shoud convert volume to a value between 0 and 1', ()=>{\n            vgVol.target = {\n                volume: 3.33\n            };\n            vgVol.setVolume(50);\n            expect(vgVol.target.volume).toBe(0.5);\n\n            vgVol.setVolume(110);\n            expect(vgVol.target.volume).toBe(1);\n            \n            vgVol.setVolume(-10);\n            expect(vgVol.target.volume).toBe(0);\n        });\n    });\n    \n    describe('getVolume', ()=>{\n        it('Shoud get target volume when target is set', ()=>{\n            vgVol.target = {\n                volume: 3.33\n            };\n            expect(vgVol.getVolume()).toBe(3.33);\n        });\n        it('Shoud get 0 volume when target is not set', ()=>{\n            vgVol.target = undefined;\n            expect(vgVol.getVolume()).toBe(0);\n        });\n    });\n});\n\ninterface DecoratorInvocation {\n  type: Function;\n  args?: any[];\n}\n"]}