From 5cb53406fe0f81b89793a5c69994c1ba387a6e7b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bar=C4=B1=C5=9F=20Soner=20U=C5=9Fakl=C4=B1?= Date: Wed, 24 May 2017 12:03:30 -0400 Subject: [PATCH] more picture tests --- src/socket.io/user/picture.js | 58 +++++++++++++++-------------------- test/user.js | 55 +++++++++++++++++++++++++++++++-- 2 files changed, 77 insertions(+), 36 deletions(-) diff --git a/src/socket.io/user/picture.js b/src/socket.io/user/picture.js index 3723699461..682cd59239 100644 --- a/src/socket.io/user/picture.js +++ b/src/socket.io/user/picture.js @@ -1,12 +1,12 @@ 'use strict'; var async = require('async'); -var winston = require('winston'); var path = require('path'); var nconf = require('nconf'); var user = require('../../user'); var plugins = require('../../plugins'); +var file = require('../../file'); module.exports = function (SocketUser) { SocketUser.changePicture = function (socket, data, callback) { @@ -38,11 +38,7 @@ module.exports = function (SocketUser) { type: type, picture: undefined, }, function (err, returnData) { - if (err) { - return next(err); - } - - next(null, returnData.picture || ''); + next(err, returnData && returnData.picture); }); break; } @@ -71,7 +67,7 @@ module.exports = function (SocketUser) { }; SocketUser.removeUploadedPicture = function (socket, data, callback) { - if (!socket.uid || !data.uid) { + if (!socket.uid || !data || !data.uid) { return callback(new Error('[[error:invalid-data]]')); } @@ -86,11 +82,7 @@ module.exports = function (SocketUser) { if (userData.uploadedpicture && !userData.uploadedpicture.startsWith('http')) { var pathToFile = path.join(nconf.get('base_dir'), 'public', userData.uploadedpicture); if (pathToFile.startsWith(nconf.get('upload_path'))) { - require('fs').unlink(pathToFile, function (err) { - if (err) { - winston.error(err); - } - }); + file.delete(pathToFile); } } @@ -109,27 +101,27 @@ module.exports = function (SocketUser) { if (!data || !data.uid) { return callback(new Error('[[error:invalid-data]]')); } + async.waterfall([ + function (next) { + async.parallel({ + list: async.apply(plugins.fireHook, 'filter:user.listPictures', { + uid: data.uid, + pictures: [], + }), + uploaded: async.apply(user.getUserField, data.uid, 'uploadedpicture'), + }, next); + }, + function (data, next) { + if (data.uploaded) { + data.list.pictures.push({ + type: 'uploaded', + url: data.uploaded, + text: '[[user:uploaded_picture]]', + }); + } - async.parallel({ - list: async.apply(plugins.fireHook, 'filter:user.listPictures', { - uid: data.uid, - pictures: [], - }), - uploaded: async.apply(user.getUserField, data.uid, 'uploadedpicture'), - }, function (err, data) { - if (err) { - return callback(err); - } - - if (data.uploaded) { - data.list.pictures.push({ - type: 'uploaded', - url: data.uploaded, - text: '[[user:uploaded_picture]]', - }); - } - - callback(null, data.list.pictures); - }); + next(null, data.list.pictures); + }, + ], callback); }; }; diff --git a/test/user.js b/test/user.js index 284192b8d4..f027543099 100644 --- a/test/user.js +++ b/test/user.js @@ -16,6 +16,7 @@ var groups = require('../src/groups'); var helpers = require('./helpers'); var meta = require('../src/meta'); var plugins = require('../src/plugins'); +var socketUser = require('../src/socket.io/user'); describe('User', function () { var userData; @@ -204,7 +205,6 @@ describe('User', function () { }); describe('.search()', function () { - var socketUser = require('../src/socket.io/user'); it('should return an object containing an array of matching users', function (done) { User.search({ query: 'john' }, function (err, searchData) { assert.ifError(err); @@ -501,7 +501,6 @@ describe('User', function () { }); it('should change a user\'s password', function (done) { - var socketUser = require('../src/socket.io/user'); User.create({ username: 'changepassword', password: '123456' }, function (err, uid) { assert.ifError(err); socketUser.changePassword({ uid: uid }, { uid: uid, newPassword: '654321', currentPassword: '123456' }, function (err) { @@ -554,7 +553,6 @@ describe('User', function () { it('should upload cropped profile picture', function (done) { var imageData = ''; - var socketUser = require('../src/socket.io/user'); socketUser.uploadCroppedPicture({ uid: uid }, { uid: uid, imageData: imageData }, function (err, result) { assert.ifError(err); assert(result.url); @@ -613,6 +611,34 @@ describe('User', function () { }); }); + it('should fail to change user picture with invalid data', function (done) { + socketUser.changePicture({ uid: uid }, null, function (err) { + assert.equal(err.message, '[[error:invalid-data]]'); + done(); + }); + }); + + it('should fail to change user picture with invalid uid', function (done) { + socketUser.changePicture({ uid: 0 }, null, function (err) { + assert.equal(err.message, '[[error:invalid-uid]]'); + done(); + }); + }); + + it('should set user picture to uploaded', function (done) { + User.setUserField(uid, 'uploadedpicture', 'test', function (err) { + assert.ifError(err); + socketUser.changePicture({ uid: uid }, { type: 'uploaded', uid: uid }, function (err) { + assert.ifError(err); + User.getUserField(uid, 'picture', function (err, picture) { + assert.ifError(err); + assert.equal(picture, 'test'); + done(); + }); + }); + }); + }); + it('should upload profile picture', function (done) { helpers.copyFile( path.join(nconf.get('base_dir'), 'test/files/test.png'), @@ -752,6 +778,16 @@ describe('User', function () { }); }); + it('should fail to get profile pictures with invalid data', function (done) { + socketUser.getProfilePictures({ uid: uid }, null, function (err) { + assert.equal(err.message, '[[error:invalid-data]]'); + socketUser.getProfilePictures({ uid: uid }, { uid: null }, function (err) { + assert.equal(err.message, '[[error:invalid-data]]'); + done(); + }); + }); + }); + it('should remove uploaded picture', function (done) { io.emit('user.removeUploadedPicture', { uid: uid }, function (err) { assert.ifError(err); @@ -763,6 +799,19 @@ describe('User', function () { }); }); + it('should fail to remove uploaded picture with invalid-data', function (done) { + socketUser.removeUploadedPicture({ uid: uid }, null, function (err) { + assert.equal(err.message, '[[error:invalid-data]]'); + socketUser.removeUploadedPicture({ uid: uid }, { }, function (err) { + assert.equal(err.message, '[[error:invalid-data]]'); + socketUser.removeUploadedPicture({ uid: null }, { }, function (err) { + assert.equal(err.message, '[[error:invalid-data]]'); + done(); + }); + }); + }); + }); + it('should load profile page', function (done) { request(nconf.get('url') + '/api/user/updatedagain', { jar: jar, json: true }, function (err, res, body) { assert.ifError(err);