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;
+ });
+ });
+ });
+});