From 988c4858744c8f2c9cae474635be70f76022b91c Mon Sep 17 00:00:00 2001 From: barisusakli Date: Tue, 20 Dec 2016 16:03:01 +0300 Subject: [PATCH] post tools test --- src/socket.io/posts/tools.js | 193 +++++++++++++++++----------------- src/socket.io/topics/tools.js | 53 +++++----- test/posts.js | 87 ++++++++++++--- 3 files changed, 196 insertions(+), 137 deletions(-) diff --git a/src/socket.io/posts/tools.js b/src/socket.io/posts/tools.js index 06f7e0b22c..dec866ce70 100644 --- a/src/socket.io/posts/tools.js +++ b/src/socket.io/posts/tools.js @@ -15,47 +15,47 @@ var social = require('../../social'); module.exports = function (SocketPosts) { SocketPosts.loadPostTools = function (socket, data, callback) { - if (!data) { + if (!data || !data.pid || !data.cid) { return callback(new Error('[[error:invalid-data]]')); } - - async.parallel({ - posts: function (next) { - posts.getPostFields(data.pid, ['deleted', 'bookmarks', 'uid'], next); - }, - isAdminOrMod: function (next) { - privileges.categories.isAdminOrMod(data.cid, socket.uid, next); - }, - canEdit: function (next) { - privileges.posts.canEdit(data.pid, socket.uid, next); - }, - canDelete: function (next) { - privileges.posts.canDelete(data.pid, socket.uid, next); - }, - bookmarked: function (next) { - posts.hasBookmarked(data.pid, socket.uid, next); - }, - tools: function (next) { - plugins.fireHook('filter:post.tools', {pid: data.pid, uid: socket.uid, tools: []}, next); + async.waterfall([ + function (next) { + async.parallel({ + posts: function (next) { + posts.getPostFields(data.pid, ['deleted', 'bookmarks', 'uid'], next); + }, + isAdminOrMod: function (next) { + privileges.categories.isAdminOrMod(data.cid, socket.uid, next); + }, + canEdit: function (next) { + privileges.posts.canEdit(data.pid, socket.uid, next); + }, + canDelete: function (next) { + privileges.posts.canDelete(data.pid, socket.uid, next); + }, + bookmarked: function (next) { + posts.hasBookmarked(data.pid, socket.uid, next); + }, + tools: function (next) { + plugins.fireHook('filter:post.tools', {pid: data.pid, uid: socket.uid, tools: []}, next); + }, + postSharing: function (next) { + social.getActivePostSharing(next); + } + }, next); }, - postSharing: function (next) { - social.getActivePostSharing(next); - } - }, function (err, results) { - if (err) { - return callback(err); + function (results, next) { + results.posts.tools = results.tools.tools; + results.posts.deleted = parseInt(results.posts.deleted, 10) === 1; + results.posts.bookmarked = results.bookmarked; + results.posts.selfPost = socket.uid && socket.uid === parseInt(results.posts.uid, 10); + results.posts.display_edit_tools = results.canEdit.flag; + results.posts.display_delete_tools = results.canDelete.flag; + results.posts.display_moderator_tools = results.posts.display_edit_tools || results.posts.display_delete_tools; + results.posts.display_move_tools = results.isAdminOrMod; + next(null, results); } - - results.posts.tools = results.tools.tools; - results.posts.deleted = parseInt(results.posts.deleted, 10) === 1; - results.posts.bookmarked = results.bookmarked; - results.posts.selfPost = socket.uid && socket.uid === parseInt(results.posts.uid, 10); - results.posts.display_edit_tools = results.canEdit.flag; - results.posts.display_delete_tools = results.canDelete.flag; - results.posts.display_moderator_tools = results.posts.display_edit_tools || results.posts.display_delete_tools; - results.posts.display_move_tools = results.isAdminOrMod; - callback(null, results); - }); + ], callback); }; SocketPosts.delete = function (socket, data, callback) { @@ -98,29 +98,31 @@ module.exports = function (SocketPosts) { return callback(new Error('[[error:invalid-data]]')); } - posts.tools.restore(socket.uid, data.pid, function (err, postData) { - if (err) { - return callback(err); - } + async.waterfall([ + function (next) { + posts.tools.restore(socket.uid, data.pid, next); + }, + function (postData, next) { - websockets.in('topic_' + data.tid).emit('event:post_restored', postData); + websockets.in('topic_' + data.tid).emit('event:post_restored', postData); - events.log({ - type: 'post-restore', - uid: socket.uid, - pid: data.pid, - ip: socket.ip - }); + events.log({ + type: 'post-restore', + uid: socket.uid, + pid: data.pid, + ip: socket.ip + }); - callback(); - }); + setImmediate(next); + } + ], callback); }; SocketPosts.deletePosts = function (socket, data, callback) { if (!data || !Array.isArray(data.pids)) { return callback(new Error('[[error:invalid-data]]')); } - async.each(data.pids, function (pid, next) { + async.eachSeries(data.pids, function (pid, next) { SocketPosts.delete(socket, {pid: pid, tid: data.tid}, next); }, callback); }; @@ -129,66 +131,61 @@ module.exports = function (SocketPosts) { if (!data || !Array.isArray(data.pids)) { return callback(new Error('[[error:invalid-data]]')); } - async.each(data.pids, function (pid, next) { + async.eachSeries(data.pids, function (pid, next) { SocketPosts.purge(socket, {pid: pid, tid: data.tid}, next); }, callback); }; SocketPosts.purge = function (socket, data, callback) { - function purgePost() { - var postData; - async.waterfall([ - function (next) { - posts.getPostField(data.pid, 'toPid', next); - }, - function (toPid, next) { - postData = {pid: data.pid, toPid: toPid}; - posts.tools.purge(socket.uid, data.pid, next); - }, - function (next) { - websockets.in('topic_' + data.tid).emit('event:post_purged', postData); - topics.getTopicField(data.tid, 'title', next); - }, - function (title, next) { - events.log({ - type: 'post-purge', - uid: socket.uid, - pid: data.pid, - ip: socket.ip, - title: validator.escape(String(title)) - }, next); - } - ], callback); - } - if (!data || !parseInt(data.pid, 10)) { return callback(new Error('[[error:invalid-data]]')); } - - isMainAndLastPost(data.pid, function (err, results) { - if (err) { - return callback(err); - } - - if (!results.isMain) { - return purgePost(); - } - - if (!results.isLast) { - return callback(new Error('[[error:cant-purge-main-post]]')); + var postData; + async.waterfall([ + function (next) { + isMainAndLastPost(data.pid, next); + }, + function (results, next) { + if (results.isMain && !results.isLast) { + return callback(new Error('[[error:cant-purge-main-post]]')); + } + if (results.isMain && results.isLast) { + deleteTopicOf(data.pid, socket, next); + } + setImmediate(next); + }, + function (next) { + posts.getPostField(data.pid, 'toPid', next); + }, + function (toPid, next) { + postData = {pid: data.pid, toPid: toPid}; + posts.tools.purge(socket.uid, data.pid, next); + }, + function (next) { + websockets.in('topic_' + data.tid).emit('event:post_purged', postData); + topics.getTopicField(data.tid, 'title', next); + }, + function (title, next) { + events.log({ + type: 'post-purge', + uid: socket.uid, + pid: data.pid, + ip: socket.ip, + title: validator.escape(String(title)) + }, next); } - - deleteTopicOf(data.pid, socket, callback); - }); + ], callback); }; function deleteTopicOf(pid, socket, callback) { - posts.getTopicFields(pid, ['tid', 'cid'], function (err, topic) { - if (err) { - return callback(err); + async.waterfall([ + function (next) { + posts.getTopicFields(pid, ['tid', 'cid'], next); + }, + function (topic, next) { + socketTopics.doTopicAction('delete', 'event:topic_deleted', socket, {tids: [topic.tid], cid: topic.cid}, next); } - socketTopics.doTopicAction('delete', 'event:topic_deleted', socket, {tids: [topic.tid], cid: topic.cid}, callback); - }); + ], callback); } function isMainAndLastPost(pid, callback) { diff --git a/src/socket.io/topics/tools.js b/src/socket.io/topics/tools.js index 62e159f9fd..b124c7e3fd 100644 --- a/src/socket.io/topics/tools.js +++ b/src/socket.io/topics/tools.js @@ -1,7 +1,6 @@ 'use strict'; var async = require('async'); -var winston = require('winston'); var validator = require('validator'); var topics = require('../../topics'); @@ -89,31 +88,37 @@ module.exports = function (SocketTopics) { } async.each(data.tids, function (tid, next) { - topics.tools[action](tid, socket.uid, function (err, data) { - if (err) { - return next(err); + async.waterfall([ + function (next) { + topics.tools[action](tid, socket.uid, next); + }, + function (data, next) { + socketHelpers.emitToTopicAndCategory(event, data); + logTopicAction(action, socket, tid, next); } - - socketHelpers.emitToTopicAndCategory(event, data); - - if (action === 'delete' || action === 'restore' || action === 'purge') { - topics.getTopicField(tid, 'title', function (err, title) { - if (err) { - return winston.error(err); - } - events.log({ - type: 'topic-' + action, - uid: socket.uid, - ip: socket.ip, - tid: tid, - title: validator.escape(String(title)) - }); - }); - } - - next(); - }); + ], next); }, callback); }; + function logTopicAction(action, socket, tid, callback) { + var actionsToLog = ['delete', 'restore', 'purge']; + if (actionsToLog.indexOf(action) === -1) { + return setImmediate(callback); + } + async.waterfall([ + function (next) { + topics.getTopicField(tid, 'title', next); + }, + function (title, next) { + events.log({ + type: 'topic-' + action, + uid: socket.uid, + ip: socket.ip, + tid: tid, + title: validator.escape(String(title)) + }, next); + } + ], callback); + } + }; \ No newline at end of file diff --git a/test/posts.js b/test/posts.js index 1ddbd83399..997de8c7bf 100644 --- a/test/posts.js +++ b/test/posts.js @@ -162,26 +162,68 @@ describe('Post\'s', function () { }); }); + describe('post tools', function () { + var socketPosts = require('../src/socket.io/posts'); + + it('should error if data is invalid', function (done) { + socketPosts.loadPostTools({uid: globalModUid}, null, function (err) { + assert.equal(err.message, '[[error:invalid-data]]'); + done(); + }); + }); + + it('should load post tools', function (done) { + socketPosts.loadPostTools({uid: globalModUid}, {pid: postData.pid, cid: cid}, function (err, data) { + assert.ifError(err); + assert(data.posts.display_edit_tools); + assert(data.posts.display_delete_tools); + assert(data.posts.display_moderator_tools); + assert(data.posts.display_move_tools); + done(); + }); + }); + }); + describe('delete/restore/purge', function () { - var pid; + var tid; + var mainPid; + var replyPid; + var socketPosts = require('../src/socket.io/posts'); before(function (done) { - topics.reply({ + topics.post({ uid: voterUid, - tid: topicData.tid, - timestamp: Date.now(), - content: 'A post to delete/restore and purge' + cid: cid, + title: 'topic to delete/restore/purge', + content: 'A post to delete/restore/purge' }, function (err, data) { assert.ifError(err); - pid = data.pid; - privileges.categories.give(['purge'], cid, 'registered-users', done); + tid = data.topicData.tid; + mainPid = data.postData.pid; + topics.reply({ + uid: voterUid, + tid: topicData.tid, + timestamp: Date.now(), + content: 'A post to delete/restore and purge' + }, function (err, data) { + assert.ifError(err); + replyPid = data.pid; + privileges.categories.give(['purge'], cid, 'registered-users', done); + }); + }); + }); + + it('should error with invalid data', function (done) { + socketPosts.delete({uid: voterUid}, null, function (err) { + assert.equal(err.message, '[[error:invalid-data]]'); + done(); }); }); it('should delete a post', function (done) { - socketPosts.delete({uid: voterUid}, {pid: pid, tid: topicData.tid}, function (err) { + socketPosts.delete({uid: voterUid}, {pid: replyPid, tid: tid}, function (err) { assert.ifError(err); - posts.getPostField(pid, 'deleted', function (err, isDeleted) { + posts.getPostField(replyPid, 'deleted', function (err, isDeleted) { assert.ifError(err); assert.equal(parseInt(isDeleted, 10), 1); done(); @@ -190,9 +232,9 @@ describe('Post\'s', function () { }); it('should restore a post', function (done) { - socketPosts.restore({uid: voterUid}, {pid: pid, tid: topicData.tid}, function (err) { + socketPosts.restore({uid: voterUid}, {pid: replyPid, tid: tid}, function (err) { assert.ifError(err); - posts.getPostField(pid, 'deleted', function (err, isDeleted) { + posts.getPostField(replyPid, 'deleted', function (err, isDeleted) { assert.ifError(err); assert.equal(parseInt(isDeleted, 10), 0); done(); @@ -200,16 +242,31 @@ describe('Post\'s', function () { }); }); - it('should purge a post', function (done) { - socketPosts.purge({uid: voterUid}, {pid: pid}, function (err) { + it('should delete posts and topic', function (done) { + socketPosts.deletePosts({uid: globalModUid}, {pids: [replyPid, mainPid], tid: tid}, function (err) { assert.ifError(err); - posts.exists('post:' + pid, function (err, exists) { + topics.getTopicField(tid, 'deleted', function (err, deleted) { assert.ifError(err); - assert.equal(exists, false); + assert.equal(parseInt(deleted, 10), 1); done(); }); }); }); + + it('should purge posts', function (done) { + var socketTopics = require('../src/socket.io/topics'); + socketTopics.restore({uid: globalModUid}, {tids: [tid], cid: cid}, function (err) { + assert.ifError(err); + socketPosts.purgePosts({uid: voterUid}, {pids: [replyPid, mainPid], tid: tid}, function (err) { + assert.ifError(err); + posts.exists('post:' + replyPid, function (err, exists) { + assert.ifError(err); + assert.equal(exists, false); + done(); + }); + }); + }); + }); }); describe('edit', function () {