diff --git a/src/socket.io/posts/flag.js b/src/socket.io/posts/flag.js index 565c4ec7c9..42c789eb54 100644 --- a/src/socket.io/posts/flag.js +++ b/src/socket.io/posts/flag.js @@ -107,7 +107,7 @@ module.exports = function (SocketPosts) { SocketPosts.dismissFlag = function (socket, pid, callback) { if (!pid || !socket.uid) { - return callback('[[error:invalid-data]]'); + return callback(new Error('[[error:invalid-data]]')); } async.waterfall([ function (next) { @@ -138,7 +138,7 @@ module.exports = function (SocketPosts) { SocketPosts.updateFlag = function (socket, data, callback) { if (!data || !(data.pid && data.data)) { - return callback('[[error:invalid-data]]'); + return callback(new Error('[[error:invalid-data]]')); } var payload = {}; diff --git a/src/socket.io/user/picture.js b/src/socket.io/user/picture.js index 95f1613501..995b184b47 100644 --- a/src/socket.io/user/picture.js +++ b/src/socket.io/user/picture.js @@ -11,7 +11,7 @@ module.exports = function (SocketUser) { SocketUser.changePicture = function (socket, data, callback) { if (!socket.uid) { - return callback('[[error:invalid-uid]]'); + return callback(new Error('[[error:invalid-uid]]')); } if (!data) { diff --git a/src/socket.io/user/profile.js b/src/socket.io/user/profile.js index 63726cb31d..8e2cbda7bd 100644 --- a/src/socket.io/user/profile.js +++ b/src/socket.io/user/profile.js @@ -84,12 +84,13 @@ module.exports = function (SocketUser) { } SocketUser.changePassword = function (socket, data, callback) { + if (!socket.uid) { + return callback(new Error('[[error:invalid-uid]]')); + } + if (!data || !data.uid) { return callback(new Error('[[error:invalid-data]]')); } - if (!socket.uid) { - return callback('[[error:invalid-uid]]'); - } user.changePassword(socket.uid, data, function (err) { if (err) { @@ -108,7 +109,7 @@ module.exports = function (SocketUser) { SocketUser.updateProfile = function (socket, data, callback) { if (!socket.uid) { - return callback('[[error:invalid-uid]]'); + return callback(new Error('[[error:invalid-uid]]')); } if (!data || !data.uid) { diff --git a/test/helpers/index.js b/test/helpers/index.js index 116f48d49d..a519771839 100644 --- a/test/helpers/index.js +++ b/test/helpers/index.js @@ -3,6 +3,8 @@ var request = require('request'); var nconf = require('nconf'); +var myXhr = require('../mocks/newXhr'); + var helpers = module.exports; helpers.loginUser = function (username, password, callback) { @@ -11,8 +13,8 @@ helpers.loginUser = function (username, password, callback) { url: nconf.get('url') + '/api/config', json: true, jar: jar - }, function (err, response, body) { - if (err || response.statusCode !== 200) { + }, function (err, res, body) { + if (err || res.statusCode !== 200) { return callback(err || new Error('[[error:invalid-response]]')); } @@ -26,11 +28,61 @@ helpers.loginUser = function (username, password, callback) { headers: { 'x-csrf-token': body.csrf_token } - }, function (err, response) { - if (err || response.statusCode !== 200) { + }, function (err, res) { + if (err || res.statusCode !== 200) { return callback(err || new Error('[[error:invalid-response]]')); } - callback(null, jar); + myXhr.callbacks.test2 = function () { + this.setDisableHeaderCheck(true); + var stdOpen = this.open; + this.open = function () { + stdOpen.apply(this, arguments); + this.setRequestHeader('Cookie', res.headers['set-cookie'][0].split(';')[0]); + }; + }; + + var socketClient = require('socket.io-client'); + + var io = socketClient.connect(nconf.get('url'), {forceNew: true, multiplex: false}); + io.on('connect', function () { + callback(null, jar, io); + }); + + io.on('error', function (err) { + callback(err); + }); + }); + }); +}; + +helpers.initSocketIO = function (callback) { + var jar; + request.get({ + url: nconf.get('url') + '/api/config', + jar: jar, + json: true + }, function (err, res, body) { + if (err) { + return callback(err); + } + + myXhr.callbacks.test2 = function () { + this.setDisableHeaderCheck(true); + var stdOpen = this.open; + this.open = function () { + stdOpen.apply(this, arguments); + this.setRequestHeader('Cookie', res.headers['set-cookie'][0].split(';')[0]); + }; + }; + + var io = require('socket.io-client')(nconf.get('url'), {forceNew: true}); + + io.on('connect', function () { + callback(null, jar, io); + }); + + io.on('error', function (err) { + callback(err); }); }); -}; \ No newline at end of file +}; diff --git a/test/user.js b/test/user.js index 722188ed8b..34e1c329be 100644 --- a/test/user.js +++ b/test/user.js @@ -1,7 +1,4 @@ 'use strict'; -/*global require, process, before, beforeEach, after*/ - -var winston = require('winston'); var assert = require('assert'); var async = require('async'); @@ -12,6 +9,7 @@ var Topics = require('../src/topics'); var Categories = require('../src/categories'); var Meta = require('../src/meta'); var Password = require('../src/password'); +var helpers = require('./helpers'); describe('User', function () { var userData; @@ -290,18 +288,61 @@ describe('User', function () { }); }); - describe('updateProfile', function () { + describe('not logged in', function () { + var jar; + var io; + before(function (done) { + helpers.initSocketIO(function (err, _jar, _io) { + assert.ifError(err); + jar = _jar; + io = _io; + done(); + }); + }); + + it('should return error if not logged in', function (done) { + io.emit('user.updateProfile', {}, function (err) { + assert.equal(err.message, '[[error:invalid-uid]]'); + done(); + }); + }); + }); + + describe('profile methods', function () { var uid; + var jar; + var io; + before(function (done) { - User.create({username: 'updateprofile', email: 'update@me.com'}, function (err, newUid) { + User.create({username: 'updateprofile', email: 'update@me.com', password: '123456'}, function (err, newUid) { assert.ifError(err); uid = newUid; + helpers.loginUser('updateprofile', '123456', function (err, _jar, _io) { + assert.ifError(err); + jar = _jar; + io = _io; + done(); + }); + }); + }); + + it('should return error if data is invalid', function (done) { + io.emit('user.updateProfile', null, function (err) { + assert.equal(err.message, '[[error:invalid-data]]'); + done(); + }); + }); + + it('should return error if data is missing uid', function (done) { + io.emit('user.updateProfile', {username: 'bip', email: 'bop'}, function (err) { + assert.equal(err.message, '[[error:invalid-data]]'); done(); }); }); it('should update a user\'s profile', function (done) { var data = { + uid: uid, username: 'updatedUserName', email: 'updatedEmail@me.com', fullname: 'updatedFullname', @@ -311,10 +352,13 @@ describe('User', function () { birthday: '01/01/1980', signature: 'nodebb is good' }; - - User.updateProfile(uid, data, function (err, result) { + io.emit('user.updateProfile', data, function (err, result) { assert.ifError(err); - assert(result); + + assert.equal(result.username, 'updatedUserName'); + assert.equal(result.userslug, 'updatedusername'); + assert.equal(result.email, 'updatedEmail@me.com'); + db.getObject('user:' + uid, function (err, userData) { assert.ifError(err); Object.keys(data).forEach(function (key) { @@ -324,6 +368,65 @@ describe('User', function () { }); }); }); + + it('should change a user\'s password', function (done) { + io.emit('user.changePassword', {uid: uid, newPassword: '654321', currentPassword: '123456'}, function (err) { + assert.ifError(err); + User.isPasswordCorrect(uid, '654321', function (err, correct) { + assert.ifError(err); + assert(correct); + done(); + }); + }); + }); + + it('should change username', function (done) { + io.emit('user.changeUsernameEmail', {uid: uid, username: 'updatedAgain', password: '654321'}, function (err) { + assert.ifError(err); + db.getObjectField('user:' + uid, 'username', function (err, username) { + assert.ifError(err); + assert.equal(username, 'updatedAgain'); + done(); + }); + }); + }); + + it('should change email', function (done) { + io.emit('user.changeUsernameEmail', {uid: uid, email: 'updatedAgain@me.com', password: '654321'}, function (err) { + assert.ifError(err); + db.getObjectField('user:' + uid, 'email', function (err, email) { + assert.ifError(err); + assert.equal(email, 'updatedAgain@me.com'); + done(); + }); + }); + }); + + it('should update cover image', function (done) { + var imageData = ''; + var position = '50.0301% 19.2464%'; + io.emit('user.updateCover', {uid: uid, imageData: imageData, position: position}, function (err, result) { + assert.ifError(err); + assert(result.url); + db.getObjectFields('user:' + uid, ['cover:url', 'cover:position'], function (err, data) { + assert.ifError(err); + assert.equal(data['cover:url'], result.url); + assert.equal(data['cover:position'], position); + done(); + }); + }); + }); + + it('should remove cover image', function (done) { + io.emit('user.removeCover', {uid: uid}, function (err) { + assert.ifError(err); + db.getObjectField('user:' + uid, 'cover:url', function (err, url) { + assert.ifError(err); + assert.equal(url, null); + done(); + }); + }); + }); }); after(function (done) {