diff --git a/src/frontend/js/modules/avatar.spec.js b/src/frontend/js/modules/avatar.spec.js index 47b5d393..56cd4787 100644 --- a/src/frontend/js/modules/avatar.spec.js +++ b/src/frontend/js/modules/avatar.spec.js @@ -5,414 +5,8 @@ var { expect } = chai; describe('The Avatar Angular module', function() { - - var picture130x130 = ''; - beforeEach(angular.mock.module('esn.avatar')); - describe('imgLoaded directive', function() { - var html = ''; - - beforeEach(angular.mock.inject(['$compile', '$rootScope', 'selectionService', function($c, $r, selectionService) { - this.$compile = $c; - this.$rootScope = $r; - this.selectionService = selectionService; - }])); - - it('should draw the loaded image in a canvas on crop:loaded event', function(done) { - var img = { img: 'mock' }; - - this.selectionService.image = img; - var element = this.$compile(html)(this.$rootScope); - var document = element[0].ownerDocument; - var create = document.createElement; - - var drawImage = function(image) { - document.createElement = create; - expect(image).to.equal(img); - done(); - }; - - document.createElement = function() { - return { - getContext: function() { - return { - drawImage: drawImage - }; - } - }; - }; - this.$rootScope.$broadcast('crop:loaded'); - }); - - it('should set image width to optimal size when width greater than height of original image', function(done) { - var img = { width: 2, height: 1 }; - - this.selectionService.image = img; - var element = this.$compile(html)(this.$rootScope); - var document = element[0].ownerDocument; - var create = document.createElement; - - var drawImage = function(img, a, b, width, height) { - document.createElement = create; - expect(width).to.equal(512); - expect(height).to.equal(256); - done(); - }; - - document.createElement = function() { - return { - getContext: function() { - return { - drawImage: drawImage - }; - } - }; - }; - - this.$rootScope.$broadcast('crop:loaded'); - }); - - it('should set image height to optimal size when height greater than width of original image', function(done) { - var img = { width: 1, height: 2 }; - - this.selectionService.image = img; - var element = this.$compile(html)(this.$rootScope); - var document = element[0].ownerDocument; - var create = document.createElement; - - var drawImage = function(img, a, b, width, height) { - document.createElement = create; - expect(width).to.equal(256); - expect(height).to.equal(512); - done(); - }; - - document.createElement = function() { - return { - getContext: function() { - return { - drawImage: drawImage - }; - } - }; - }; - - this.$rootScope.$broadcast('crop:loaded'); - }); - }); - - describe('loadButton directive', function() { - var html = ''; - var initDirective; - - beforeEach(angular.mock.inject(['$compile', '$rootScope', 'selectionService', function($c, $r, selectionService) { - this.$compile = $c; - this.$rootScope = $r; - this.selectionService = selectionService; - this.$scope = this.$rootScope.$new(); - }])); - - beforeEach(function() { - var self = this; - - initDirective = function() { - var element = self.$compile(html)(self.$scope); - - self.$scope.$digest(); - - return element; - }; - }); - - it('should set an error in the scope if file is not set', function(done) { - var element = initDirective(); - - element.trigger('change'); - expect(this.selectionService.getError()).to.equal('Wrong file type, please select a valid image'); - done(); - }); - - it('should set an error in the scope if file size is > 5MB', function(done) { - var element = initDirective(); - var file = { - type: 'change', - dataTransfer: { - files: [{ - type: 'image/', - size: Math.pow(2, 24) - }] - } - }; - - element.trigger(file); - expect(this.selectionService.getError()).to.equal('File is too large (maximum size is 5 Mb)'); - done(); - }); - - it('should not set an error in the scope if file size is < 5MB', function(done) { - var element = initDirective(); - const smallFile = new File(['foo'], 'foot.txt', { - type: 'image/', - size: Math.pow(2, 10) - }); - - var event = { - type: 'change', - dataTransfer: { - files: [smallFile] - } - }; - - element.trigger(event); - expect(this.selectionService.getError()).to.be.null; - done(); - }); - }); - - describe('selectionService service', function() { - var AVATAR_MIN_SIZE; - - beforeEach(angular.mock.inject(function(selectionService, $rootScope, _AVATAR_MIN_SIZE_PX_) { - this.selectionService = selectionService; - AVATAR_MIN_SIZE = _AVATAR_MIN_SIZE_PX_; - this.$rootScope = $rootScope; - })); - - it('should fire an event to crop:loaded topic when setting an image', function(done) { - var image = 'foo.png'; - - this.$rootScope.$broadcast = function(topic) { - expect(topic).to.equal('crop:loaded'); - done(); - }; - this.selectionService.setImage(image); - }); - - it('should broadcast x to crop:selected topic when calling broadcastSelection(x)', function(done) { - var selection = { x: 0, y: 1 }; - - this.$rootScope.$broadcast = function(topic, data) { - expect(topic).to.equal('crop:selected'); - expect(data).to.equal(selection); - done(); - }; - this.selectionService.broadcastSelection(selection); - }); - - it('should save the input image', function(done) { - var input = 'foo.png'; - - this.selectionService.setImage(input); - expect(this.selectionService.image).to.equal(input); - done(); - }); - - it('should save the error', function(done) { - var error = 'fail'; - - this.selectionService.setError(error); - expect(this.selectionService.error).to.equal(error); - done(); - }); - - it('should broadcast the error to crop:error topic when calling setError(err)', function(done) { - var error = 'fail'; - - this.$rootScope.$broadcast = function(topic, data) { - expect(topic).to.equal('crop:error'); - expect(data).to.equal(error); - done(); - }; - this.selectionService.setError(error); - }); - - it('should return the stored image when calling getImage', function(done) { - var input = 'foo.png'; - - this.selectionService.image = input; - var image = this.selectionService.getImage(); - - expect(image).to.equal(input); - done(); - }); - - it('should return 130x130 for tested picture', function(done) { - var originalImage = new Image(); - - originalImage.src = picture130x130; - originalImage.onload = function() { - expect(originalImage.width).to.equal(130); - expect(originalImage.height).to.equal(130); - done(); - }; - this.selectionService.setImage(originalImage); - this.$rootScope.$digest(); - }); - - it('should return AVATAR_MIN_SIZE * AVATAR_MIN_SIZE image when calling getBlob and no selection', function(done) { - this.selectionService.broadcastSelection({ cords: { w: 0, h: 0 } }); - var originalImage = new Image(); - - originalImage.src = picture130x130; - this.selectionService.setImage(originalImage); - this.selectionService.getBlob('image/png', function(blob) { - - var reader = new FileReader(); - - reader.onload = function(e) { - var img = new Image(); - - img.src = e.target.result; - img.onload = function() { - expect(img.width).to.equal(AVATAR_MIN_SIZE); - expect(img.height).to.equal(AVATAR_MIN_SIZE); - done(); - }; - }; - reader.readAsDataURL(blob); - }); - }); - - it('should return AVATAR_MIN_SIZE * AVATAR_MIN_SIZE image when calling getBlob and selection', function(done) { - this.selectionService.broadcastSelection({ cords: { w: 1, h: 1 } }); - var originalImage = new Image(); - - originalImage.src = picture130x130; - this.selectionService.setImage(originalImage); - this.selectionService.getBlob('image/png', function(blob) { - - var reader = new FileReader(); - - reader.onload = function(e) { - var img = new Image(); - - img.src = e.target.result; - img.onload = function() { - expect(img.width).to.equal(AVATAR_MIN_SIZE); - expect(img.height).to.equal(AVATAR_MIN_SIZE); - done(); - }; - }; - reader.readAsDataURL(blob); - }); - }); - }); - - describe('The avatarEdit controller', function() { - var userId = '123'; - var domainId = '456'; - - beforeEach(function() { - angular.mock.module('esn.avatar'); - - angular.mock.inject(function( - session, - selectionService, - avatarAPI, - $rootScope, - $controller - ) { - this.session = session; - this.selectionService = selectionService; - this.$rootScope = $rootScope; - this.avatarAPI = avatarAPI; - this.scope = $rootScope.$new(); - - $controller('avatarEdit', { - $rootScope: this.$rootScope, - $scope: this.scope, - session: this.session, - selectionService: this.selectionService, - avatarAPI: this.avatarAPI - }); - }); - }); - - describe('The send function', function() { - it('should call the avatarAPI.uploadAvatar to upload avatar for current user', function(done) { - this.session.user = { _id: userId }; - this.scope.user = { _id: userId }; - var blob = 'foo'; - var mime = 'bar'; - - this.avatarAPI.uploadAvatar = function(_blob, _mime) { - expect(_blob).to.equal(blob); - expect(_mime).to.equal(mime); - done(); - }; - - this.scope.send(blob, mime); - done(new Error('Should not be called')); - }); - - it('should call the avatarAPI.uploadUserAvatar to upload avatar for a specific user', function(done) { - var specificUserId = '456'; - var blob = 'foo'; - var mime = 'bar'; - - this.session.user = { _id: userId }; - this.session.domain = { _id: domainId }; - this.scope.user = { _id: specificUserId }; - this.avatarAPI.uploadUserAvatar = function(_blob, _mime, _userId, _domainId) { - expect(_blob).to.equal(blob); - expect(_mime).to.equal(mime); - expect(_userId).to.equal(specificUserId); - expect(_domainId).to.equal(domainId); - done(); - }; - - this.scope.send(blob, mime); - done(new Error('Should not be called')); - }); - }); - }); - - describe('avatarAPI service', function() { - beforeEach(angular.mock.inject(function(selectionService, $rootScope, $httpBackend, avatarAPI) { - this.selectionService = selectionService; - this.$rootScope = $rootScope; - this.avatarAPI = avatarAPI; - this.$httpBackend = $httpBackend; - })); - - describe('The uploadAvatar function', function() { - it('should send POST to /api/user/profile/avatar with valid mime, parameters and blob', function() { - var blob = '123'; - var mime = 'image/png'; - - this.$httpBackend.expectPOST('/api/user/profile/avatar?mimetype=image%2Fpng', blob).respond(200); - this.avatarAPI.uploadAvatar(blob, mime); - this.$httpBackend.flush(); - }); - - it('should return a promise', function() { - var promise = this.avatarAPI.uploadAvatar('foo', 'bar'); - - expect(promise.then).to.be.a.function; - }); - }); - - describe('The uploadUserAvatar function', function() { - it('should PUT to right endpoint to upload avatar for a specific user', function() { - var blob = 'foobar'; - var mime = 'image/png'; - var userId = '123'; - var domainId = '456'; - - this.$httpBackend.expectPUT('/api/users/' + userId + '/profile/avatar?domain_id=' + domainId + '&mimetype=image%2Fpng', blob).respond(200); - this.avatarAPI.uploadUserAvatar(blob, mime, userId, domainId); - this.$httpBackend.flush(); - }); - - it('should return a promise', function() { - var promise = this.avatarAPI.uploadUserAvatar('foo', 'bar', '123', '456'); - - expect(promise.then).to.be.a.function; - }); - }); - }); - describe('the EsnAvatarController', function() { var $q, $compile, $rootScope, $logMock, element, controller, esnAvatarUrlServiceMock, userAPIMock, user, result; diff --git a/src/frontend/js/modules/avatar/avatar-edition.spec.js b/src/frontend/js/modules/avatar/avatar-edition.spec.js new file mode 100644 index 00000000..f6c417f1 --- /dev/null +++ b/src/frontend/js/modules/avatar/avatar-edition.spec.js @@ -0,0 +1,413 @@ +'use strict'; + +/* global chai */ + +const { expect } = chai; +const picture130x130 = ''; + +describe('The Avatar Angular module', function() { + beforeEach(angular.mock.module('esn.avatar')); + + describe('imgLoaded directive', function() { + var html = ''; + + beforeEach(angular.mock.inject(['$compile', '$rootScope', 'selectionService', function($c, $r, selectionService) { + this.$compile = $c; + this.$rootScope = $r; + this.selectionService = selectionService; + }])); + + it('should draw the loaded image in a canvas on crop:loaded event', function(done) { + var img = { img: 'mock' }; + + this.selectionService.image = img; + var element = this.$compile(html)(this.$rootScope); + var document = element[0].ownerDocument; + var create = document.createElement; + + var drawImage = function(image) { + document.createElement = create; + expect(image).to.equal(img); + done(); + }; + + document.createElement = function() { + return { + getContext: function() { + return { + drawImage: drawImage + }; + } + }; + }; + this.$rootScope.$broadcast('crop:loaded'); + }); + + it('should set image width to optimal size when width greater than height of original image', function(done) { + var img = { width: 2, height: 1 }; + + this.selectionService.image = img; + var element = this.$compile(html)(this.$rootScope); + var document = element[0].ownerDocument; + var create = document.createElement; + + var drawImage = function(img, a, b, width, height) { + document.createElement = create; + expect(width).to.equal(512); + expect(height).to.equal(256); + done(); + }; + + document.createElement = function() { + return { + getContext: function() { + return { + drawImage: drawImage + }; + } + }; + }; + + this.$rootScope.$broadcast('crop:loaded'); + }); + + it('should set image height to optimal size when height greater than width of original image', function(done) { + var img = { width: 1, height: 2 }; + + this.selectionService.image = img; + var element = this.$compile(html)(this.$rootScope); + var document = element[0].ownerDocument; + var create = document.createElement; + + var drawImage = function(img, a, b, width, height) { + document.createElement = create; + expect(width).to.equal(256); + expect(height).to.equal(512); + done(); + }; + + document.createElement = function() { + return { + getContext: function() { + return { + drawImage: drawImage + }; + } + }; + }; + + this.$rootScope.$broadcast('crop:loaded'); + }); + }); + + describe('loadButton directive', function() { + var html = ''; + var initDirective; + + beforeEach(angular.mock.inject(['$compile', '$rootScope', 'selectionService', function($c, $r, selectionService) { + this.$compile = $c; + this.$rootScope = $r; + this.selectionService = selectionService; + this.$scope = this.$rootScope.$new(); + }])); + + beforeEach(function() { + var self = this; + + initDirective = function() { + var element = self.$compile(html)(self.$scope); + + self.$scope.$digest(); + + return element; + }; + }); + + it('should set an error in the scope if file is not set', function(done) { + var element = initDirective(); + + element.trigger('change'); + expect(this.selectionService.getError()).to.equal('Wrong file type, please select a valid image'); + done(); + }); + + it('should set an error in the scope if file size is > 5MB', function(done) { + var element = initDirective(); + var file = { + type: 'change', + dataTransfer: { + files: [{ + type: 'image/', + size: Math.pow(2, 24) + }] + } + }; + + element.trigger(file); + expect(this.selectionService.getError()).to.equal('File is too large (maximum size is 5 Mb)'); + done(); + }); + + it('should not set an error in the scope if file size is < 5MB', function(done) { + var element = initDirective(); + const smallFile = new File(['foo'], 'foot.txt', { + type: 'image/', + size: Math.pow(2, 10) + }); + + var event = { + type: 'change', + dataTransfer: { + files: [smallFile] + } + }; + + element.trigger(event); + expect(this.selectionService.getError()).to.be.null; + done(); + }); + }); + + describe('selectionService service', function() { + var AVATAR_MIN_SIZE; + + beforeEach(angular.mock.inject(function(selectionService, $rootScope, _AVATAR_MIN_SIZE_PX_) { + this.selectionService = selectionService; + AVATAR_MIN_SIZE = _AVATAR_MIN_SIZE_PX_; + this.$rootScope = $rootScope; + })); + + it('should fire an event to crop:loaded topic when setting an image', function(done) { + var image = 'foo.png'; + + this.$rootScope.$broadcast = function(topic) { + expect(topic).to.equal('crop:loaded'); + done(); + }; + this.selectionService.setImage(image); + }); + + it('should broadcast x to crop:selected topic when calling broadcastSelection(x)', function(done) { + var selection = { x: 0, y: 1 }; + + this.$rootScope.$broadcast = function(topic, data) { + expect(topic).to.equal('crop:selected'); + expect(data).to.equal(selection); + done(); + }; + this.selectionService.broadcastSelection(selection); + }); + + it('should save the input image', function(done) { + var input = 'foo.png'; + + this.selectionService.setImage(input); + expect(this.selectionService.image).to.equal(input); + done(); + }); + + it('should save the error', function(done) { + var error = 'fail'; + + this.selectionService.setError(error); + expect(this.selectionService.error).to.equal(error); + done(); + }); + + it('should broadcast the error to crop:error topic when calling setError(err)', function(done) { + var error = 'fail'; + + this.$rootScope.$broadcast = function(topic, data) { + expect(topic).to.equal('crop:error'); + expect(data).to.equal(error); + done(); + }; + this.selectionService.setError(error); + }); + + it('should return the stored image when calling getImage', function(done) { + var input = 'foo.png'; + + this.selectionService.image = input; + var image = this.selectionService.getImage(); + + expect(image).to.equal(input); + done(); + }); + + it('should return 130x130 for tested picture', function(done) { + var originalImage = new Image(); + + originalImage.src = picture130x130; + originalImage.onload = function() { + expect(originalImage.width).to.equal(130); + expect(originalImage.height).to.equal(130); + done(); + }; + this.selectionService.setImage(originalImage); + this.$rootScope.$digest(); + }); + + it('should return AVATAR_MIN_SIZE * AVATAR_MIN_SIZE image when calling getBlob and no selection', function(done) { + this.selectionService.broadcastSelection({ cords: { w: 0, h: 0 } }); + var originalImage = new Image(); + + originalImage.src = picture130x130; + this.selectionService.setImage(originalImage); + this.selectionService.getBlob('image/png', function(blob) { + + var reader = new FileReader(); + + reader.onload = function(e) { + var img = new Image(); + + img.src = e.target.result; + img.onload = function() { + expect(img.width).to.equal(AVATAR_MIN_SIZE); + expect(img.height).to.equal(AVATAR_MIN_SIZE); + done(); + }; + }; + reader.readAsDataURL(blob); + }); + }); + + it('should return AVATAR_MIN_SIZE * AVATAR_MIN_SIZE image when calling getBlob and selection', function(done) { + this.selectionService.broadcastSelection({ cords: { w: 1, h: 1 } }); + var originalImage = new Image(); + + originalImage.src = picture130x130; + this.selectionService.setImage(originalImage); + this.selectionService.getBlob('image/png', function(blob) { + + var reader = new FileReader(); + + reader.onload = function(e) { + var img = new Image(); + + img.src = e.target.result; + img.onload = function() { + expect(img.width).to.equal(AVATAR_MIN_SIZE); + expect(img.height).to.equal(AVATAR_MIN_SIZE); + done(); + }; + }; + reader.readAsDataURL(blob); + }); + }); + }); + + describe('The avatarEdit controller', function() { + var userId = '123'; + var domainId = '456'; + + beforeEach(function() { + angular.mock.module('esn.avatar'); + + angular.mock.inject(function( + session, + selectionService, + avatarAPI, + $rootScope, + $controller + ) { + this.session = session; + this.selectionService = selectionService; + this.$rootScope = $rootScope; + this.avatarAPI = avatarAPI; + this.scope = $rootScope.$new(); + + $controller('avatarEdit', { + $rootScope: this.$rootScope, + $scope: this.scope, + session: this.session, + selectionService: this.selectionService, + avatarAPI: this.avatarAPI + }); + }); + }); + + describe('The send function', function() { + it('should call the avatarAPI.uploadAvatar to upload avatar for current user', function(done) { + this.session.user = { _id: userId }; + this.scope.user = { _id: userId }; + var blob = 'foo'; + var mime = 'bar'; + + this.avatarAPI.uploadAvatar = function(_blob, _mime) { + expect(_blob).to.equal(blob); + expect(_mime).to.equal(mime); + done(); + }; + + this.scope.send(blob, mime); + done(new Error('Should not be called')); + }); + + it('should call the avatarAPI.uploadUserAvatar to upload avatar for a specific user', function(done) { + var specificUserId = '456'; + var blob = 'foo'; + var mime = 'bar'; + + this.session.user = { _id: userId }; + this.session.domain = { _id: domainId }; + this.scope.user = { _id: specificUserId }; + this.avatarAPI.uploadUserAvatar = function(_blob, _mime, _userId, _domainId) { + expect(_blob).to.equal(blob); + expect(_mime).to.equal(mime); + expect(_userId).to.equal(specificUserId); + expect(_domainId).to.equal(domainId); + done(); + }; + + this.scope.send(blob, mime); + done(new Error('Should not be called')); + }); + }); + }); + + describe('avatarAPI service', function() { + beforeEach(angular.mock.inject(function(selectionService, $rootScope, $httpBackend, avatarAPI) { + this.selectionService = selectionService; + this.$rootScope = $rootScope; + this.avatarAPI = avatarAPI; + this.$httpBackend = $httpBackend; + })); + + describe('The uploadAvatar function', function() { + it('should send POST to /api/user/profile/avatar with valid mime, parameters and blob', function() { + var blob = '123'; + var mime = 'image/png'; + + this.$httpBackend.expectPOST('/api/user/profile/avatar?mimetype=image%2Fpng', blob).respond(200); + this.avatarAPI.uploadAvatar(blob, mime); + this.$httpBackend.flush(); + }); + + it('should return a promise', function() { + var promise = this.avatarAPI.uploadAvatar('foo', 'bar'); + + expect(promise.then).to.be.a.function; + }); + }); + + describe('The uploadUserAvatar function', function() { + it('should PUT to right endpoint to upload avatar for a specific user', function() { + var blob = 'foobar'; + var mime = 'image/png'; + var userId = '123'; + var domainId = '456'; + + this.$httpBackend.expectPUT('/api/users/' + userId + '/profile/avatar?domain_id=' + domainId + '&mimetype=image%2Fpng', blob).respond(200); + this.avatarAPI.uploadUserAvatar(blob, mime, userId, domainId); + this.$httpBackend.flush(); + }); + + it('should return a promise', function() { + var promise = this.avatarAPI.uploadUserAvatar('foo', 'bar', '123', '456'); + + expect(promise.then).to.be.a.function; + }); + }); + }); +});