some more group tests

v1.18.x
barisusakli 8 years ago
parent 4d86262812
commit cecb4c0403

@ -1,14 +1,14 @@
"use strict"; "use strict";
var async = require('async'), var async = require('async');
groups = require('../groups'), var groups = require('../groups');
meta = require('../meta'), var meta = require('../meta');
user = require('../user'), var user = require('../user');
utils = require('../../public/src/utils'), var utils = require('../../public/src/utils');
groupsController = require('../controllers/groups'), var groupsController = require('../controllers/groups');
SocketGroups = {}; var SocketGroups = {};
SocketGroups.before = function (socket, method, data, next) { SocketGroups.before = function (socket, method, data, next) {
@ -27,34 +27,36 @@ SocketGroups.join = function (socket, data, callback) {
return callback(new Error('[[error:not-allowed]]')); return callback(new Error('[[error:not-allowed]]'));
} }
groups.exists(data.groupName, function (err, exists) { async.waterfall([
if (err || !exists) { function (next) {
return callback(err || new Error('[[error:no-group]]')); groups.exists(data.groupName, next);
} },
function (exists, next) {
if (parseInt(meta.config.allowPrivateGroups, 10) !== 1) { if (!exists) {
return groups.join(data.groupName, socket.uid, callback); return next(new Error('[[error:no-group]]'));
} }
async.parallel({ if (parseInt(meta.config.allowPrivateGroups, 10) !== 1) {
isAdmin: async.apply(user.isAdministrator, socket.uid), return groups.join(data.groupName, socket.uid, callback);
groupData: async.apply(groups.getGroupData, data.groupName)
}, function (err, results) {
if (err) {
return callback(err);
} }
async.parallel({
isAdmin: async.apply(user.isAdministrator, socket.uid),
groupData: async.apply(groups.getGroupData, data.groupName)
}, next);
},
function (results, next) {
if (results.groupData.private && results.groupData.disableJoinRequests) { if (results.groupData.private && results.groupData.disableJoinRequests) {
return callback(new Error('[[error:join-requests-disabled]]')); return next(new Error('[[error:join-requests-disabled]]'));
} }
if (!results.groupData.private || results.isAdmin) { if (!results.groupData.private || results.isAdmin) {
groups.join(data.groupName, socket.uid, callback); groups.join(data.groupName, socket.uid, next);
} else { } else {
groups.requestMembership(data.groupName, socket.uid, callback); groups.requestMembership(data.groupName, socket.uid, next);
} }
}); }
}); ], callback);
}; };
SocketGroups.leave = function (socket, data, callback) { SocketGroups.leave = function (socket, data, callback) {

@ -9,6 +9,8 @@ var Groups = require('../src/groups');
var User = require('../src/user'); var User = require('../src/user');
describe('Groups', function () { describe('Groups', function () {
var adminUid;
var testUid;
before(function (done) { before(function (done) {
Groups.resetCache(); Groups.resetCache();
async.parallel([ async.parallel([
@ -19,6 +21,22 @@ describe('Groups', function () {
description: 'Foobar!' description: 'Foobar!'
}, next); }, next);
}, },
function (next) {
Groups.create({
name: 'PrivateNoJoin',
description: 'Private group',
private: 1,
disableJoinRequests: 1
}, next);
},
function (next) {
Groups.create({
name: 'PrivateCanJoin',
description: 'Private group',
private: 1,
disableJoinRequests: 0
}, next);
},
function (next) { function (next) {
// Create a new user // Create a new user
User.create({ User.create({
@ -26,18 +44,29 @@ describe('Groups', function () {
email: 'b@c.com' email: 'b@c.com'
}, next); }, next);
}, },
function (next) {
User.create({
username: 'admin',
email: 'admin@admin.com'
}, next);
},
function (next) { function (next) {
// Also create a hidden group // Also create a hidden group
Groups.join('Hidden', 'Test', next); Groups.join('Hidden', 'Test', next);
} }
], done); ], function (err, results) {
assert.ifError(err);
testUid = results[3];
adminUid = results[4];
Groups.join('administrators', adminUid, done);
});
}); });
describe('.list()', function () { describe('.list()', function () {
it('should list the groups present', function (done) { it('should list the groups present', function (done) {
Groups.getGroupsFromSet('groups:createtime', 0, 0, -1, function (err, groups) { Groups.getGroupsFromSet('groups:createtime', 0, 0, -1, function (err, groups) {
assert.ifError(err); assert.ifError(err);
assert.equal(groups.length, 3); assert.equal(groups.length, 6);
done(); done();
}); });
}); });
@ -50,8 +79,7 @@ describe('Groups', function () {
it('with no options, should show group information', function (done) { it('with no options, should show group information', function (done) {
Groups.get('Test', {}, function (err, groupObj) { Groups.get('Test', {}, function (err, groupObj) {
if (err) return done(err); assert.ifError(err);
assert.equal(typeof groupObj, 'object'); assert.equal(typeof groupObj, 'object');
assert(Array.isArray(groupObj.members)); assert(Array.isArray(groupObj.members));
assert.strictEqual(groupObj.name, 'Test'); assert.strictEqual(groupObj.name, 'Test');
@ -67,7 +95,7 @@ describe('Groups', function () {
describe('.search()', function () { describe('.search()', function () {
it('should return the "Test" group when searched for', function (done) { it('should return the "Test" group when searched for', function (done) {
Groups.search('test', {}, function (err, groups) { Groups.search('test', {}, function (err, groups) {
if (err) return done(err); assert.ifError(err);
assert.equal(1, groups.length); assert.equal(1, groups.length);
assert.strictEqual('Test', groups[0].name); assert.strictEqual('Test', groups[0].name);
done(); done();
@ -78,20 +106,16 @@ describe('Groups', function () {
describe('.isMember()', function () { describe('.isMember()', function () {
it('should return boolean true when a user is in a group', function (done) { it('should return boolean true when a user is in a group', function (done) {
Groups.isMember(1, 'Test', function (err, isMember) { Groups.isMember(1, 'Test', function (err, isMember) {
if (err) return done(err); assert.ifError(err);
assert.strictEqual(isMember, true); assert.strictEqual(isMember, true);
done(); done();
}); });
}); });
it('should return boolean false when a user is not in a group', function (done) { it('should return boolean false when a user is not in a group', function (done) {
Groups.isMember(2, 'Test', function (err, isMember) { Groups.isMember(2, 'Test', function (err, isMember) {
if (err) return done(err); assert.ifError(err);
assert.strictEqual(isMember, false); assert.strictEqual(isMember, false);
done(); done();
}); });
}); });
@ -100,20 +124,16 @@ describe('Groups', function () {
describe('.isMemberOfGroupList', function () { describe('.isMemberOfGroupList', function () {
it('should report that a user is part of a groupList, if they are', function (done) { it('should report that a user is part of a groupList, if they are', function (done) {
Groups.isMemberOfGroupList(1, 'Hidden', function (err, isMember) { Groups.isMemberOfGroupList(1, 'Hidden', function (err, isMember) {
if (err) return done(err); assert.ifError(err);
assert.strictEqual(isMember, true); assert.strictEqual(isMember, true);
done(); done();
}); });
}); });
it('should report that a user is not part of a groupList, if they are not', function (done) { it('should report that a user is not part of a groupList, if they are not', function (done) {
Groups.isMemberOfGroupList(2, 'Hidden', function (err, isMember) { Groups.isMemberOfGroupList(2, 'Hidden', function (err, isMember) {
if (err) return done(err); assert.ifError(err);
assert.strictEqual(isMember, false); assert.strictEqual(isMember, false);
done(); done();
}); });
}); });
@ -122,28 +142,23 @@ describe('Groups', function () {
describe('.exists()', function () { describe('.exists()', function () {
it('should verify that the test group exists', function (done) { it('should verify that the test group exists', function (done) {
Groups.exists('Test', function (err, exists) { Groups.exists('Test', function (err, exists) {
if (err) return done(err); assert.ifError(err);
assert.strictEqual(exists, true); assert.strictEqual(exists, true);
done(); done();
}); });
}); });
it('should verify that a fake group does not exist', function (done) { it('should verify that a fake group does not exist', function (done) {
Groups.exists('Derp', function (err, exists) { Groups.exists('Derp', function (err, exists) {
if (err) return done(err); assert.ifError(err);
assert.strictEqual(exists, false); assert.strictEqual(exists, false);
done(); done();
}); });
}); });
it('should check if group exists using an array', function (done) { it('should check if group exists using an array', function (done) {
Groups.exists(['Test', 'Derp'], function (err, groupsExists) { Groups.exists(['Test', 'Derp'], function (err, groupsExists) {
if (err) return done(err); assert.ifError(err);
assert.strictEqual(groupsExists[0], true); assert.strictEqual(groupsExists[0], true);
assert.strictEqual(groupsExists[1], false); assert.strictEqual(groupsExists[1], false);
done(); done();
@ -157,8 +172,7 @@ describe('Groups', function () {
name: 'foo', name: 'foo',
description: 'bar' description: 'bar'
}, function (err) { }, function (err) {
if (err) return done(err); assert.ifError(err);
Groups.get('foo', {}, done); Groups.get('foo', {}, done);
}); });
}); });
@ -175,13 +189,11 @@ describe('Groups', function () {
describe('.hide()', function () { describe('.hide()', function () {
it('should mark the group as hidden', function (done) { it('should mark the group as hidden', function (done) {
Groups.hide('foo', function (err) { Groups.hide('foo', function (err) {
if (err) return done(err); assert.ifError(err);
Groups.get('foo', {}, function (err, groupObj) { Groups.get('foo', {}, function (err, groupObj) {
if (err) return done(err); assert.ifError(err);
assert.strictEqual(true, groupObj.hidden); assert.strictEqual(true, groupObj.hidden);
done(); done();
}); });
}); });
@ -202,13 +214,11 @@ describe('Groups', function () {
Groups.update('updateTestGroup', { Groups.update('updateTestGroup', {
description: 'baz' description: 'baz'
}, function (err) { }, function (err) {
if (err) return done(err); assert.ifError(err);
Groups.get('updateTestGroup', {}, function (err, groupObj) { Groups.get('updateTestGroup', {}, function (err, groupObj) {
if (err) return done(err); assert.ifError(err);
assert.strictEqual('baz', groupObj.description); assert.strictEqual('baz', groupObj.description);
done(); done();
}); });
}); });
@ -218,14 +228,12 @@ describe('Groups', function () {
Groups.update('updateTestGroup', { Groups.update('updateTestGroup', {
name: 'updateTestGroup?' name: 'updateTestGroup?'
}, function (err) { }, function (err) {
if (err) return done(err); assert.ifError(err);
Groups.get('updateTestGroup?', {}, function (err, groupObj) { Groups.get('updateTestGroup?', {}, function (err, groupObj) {
if (err) return done(err); assert.ifError(err);
assert.strictEqual('updateTestGroup?', groupObj.name); assert.strictEqual('updateTestGroup?', groupObj.name);
assert.strictEqual('updatetestgroup', groupObj.slug); assert.strictEqual('updatetestgroup', groupObj.slug);
done(); done();
}); });
}); });
@ -239,7 +247,7 @@ describe('Groups', function () {
it('should destroy a group', function (done) { it('should destroy a group', function (done) {
Groups.destroy('foobar?', function (err) { Groups.destroy('foobar?', function (err) {
if (err) return done(err); assert.ifError(err);
Groups.get('foobar?', {}, function (err) { Groups.get('foobar?', {}, function (err) {
assert(err, 'Group still exists!'); assert(err, 'Group still exists!');
@ -251,7 +259,7 @@ describe('Groups', function () {
it('should also remove the members set', function (done) { it('should also remove the members set', function (done) {
db.exists('group:foo:members', function (err, exists) { db.exists('group:foo:members', function (err, exists) {
if (err) return done(err); assert.ifError(err);
assert.strictEqual(false, exists); assert.strictEqual(false, exists);
@ -267,10 +275,10 @@ describe('Groups', function () {
it('should add a user to a group', function (done) { it('should add a user to a group', function (done) {
Groups.join('Test', 1, function (err) { Groups.join('Test', 1, function (err) {
if (err) return done(err); assert.ifError(err);
Groups.isMember(1, 'Test', function (err, isMember) { Groups.isMember(1, 'Test', function (err, isMember) {
assert.equal(err, null); assert.ifError(err);
assert.strictEqual(true, isMember); assert.strictEqual(true, isMember);
done(); done();
@ -282,10 +290,10 @@ describe('Groups', function () {
describe('.leave()', function () { describe('.leave()', function () {
it('should remove a user from a group', function (done) { it('should remove a user from a group', function (done) {
Groups.leave('Test', 1, function (err) { Groups.leave('Test', 1, function (err) {
if (err) return done(err); assert.ifError(err);
Groups.isMember(1, 'Test', function (err, isMember) { Groups.isMember(1, 'Test', function (err, isMember) {
assert.equal(err, null); assert.ifError(err);
assert.strictEqual(false, isMember); assert.strictEqual(false, isMember);
done(); done();
@ -297,15 +305,13 @@ describe('Groups', function () {
describe('.leaveAllGroups()', function () { describe('.leaveAllGroups()', function () {
it('should remove a user from all groups', function (done) { it('should remove a user from all groups', function (done) {
Groups.leaveAllGroups(1, function (err) { Groups.leaveAllGroups(1, function (err) {
if (err) return done(err); assert.ifError(err);
var groups = ['Test', 'Hidden']; var groups = ['Test', 'Hidden'];
async.every(groups, function (group, next) { async.every(groups, function (group, next) {
Groups.isMember(1, group, function (err, isMember) { Groups.isMember(1, group, function (err, isMember) {
if (err) done(err); assert.ifError(err);
else { next(!isMember);
next(!isMember);
}
}); });
}, function (result) { }, function (result) {
assert(result); assert(result);
@ -344,6 +350,109 @@ describe('Groups', function () {
}); });
}); });
describe('socket methods', function () {
var socketGroups = require('../src/socket.io/groups');
var meta = require('../src/meta');
it('should error if data is null', function (done) {
socketGroups.before({uid: 0}, 'groups.join', null, function (err) {
assert.equal(err.message, '[[error:invalid-data]]');
done();
});
});
it('should return error if not logged in', function (done) {
socketGroups.join({uid: 0}, {}, function (err) {
assert.equal(err.message, '[[error:invalid-uid]]');
done();
});
});
it('should return error if group name is special', function (done) {
socketGroups.join({uid: adminUid}, {groupName: 'administrators'}, function (err) {
assert.equal(err.message, '[[error:not-allowed]]');
done();
});
});
it('should error if group does not exist', function (done) {
socketGroups.join({uid: adminUid}, {groupName: 'doesnotexist'}, function (err) {
assert.equal(err.message, '[[error:no-group]]');
done();
});
});
it('should join test group', function (done) {
meta.config.allowPrivateGroups = 0;
socketGroups.join({uid: adminUid}, {groupName: 'Test'}, function (err) {
assert.ifError(err);
Groups.isMember(adminUid, 'Test', function (err, isMember) {
assert.ifError(err);
assert(isMember);
done();
});
});
});
it('should error if not logged in', function (done) {
socketGroups.leave({uid: 0}, {}, function (err) {
assert.equal(err.message, '[[error:invalid-uid]]');
done();
});
});
it('should return error if group name is special', function (done) {
socketGroups.leave({uid: adminUid}, {groupName: 'administrators'}, function (err) {
assert.equal(err.message, '[[error:cant-remove-self-as-admin]]');
done();
});
});
it('should leave test group', function (done) {
socketGroups.leave({uid: adminUid}, {groupName: 'Test'}, function (err) {
assert.ifError(err);
Groups.isMember('Test', adminUid, function (err, isMember) {
assert.ifError(err);
assert(!isMember);
done();
});
});
});
it('should fail to join if group is private and join requests are disabled', function (done) {
meta.config.allowPrivateGroups = 1;
socketGroups.join({uid: testUid}, {groupName: 'PrivateNoJoin'}, function (err) {
assert.equal(err.message, '[[error:join-requests-disabled]]');
done();
});
});
it('should join if user is admin', function (done) {
socketGroups.join({uid: adminUid}, {groupName: 'PrivateCanJoin'}, function (err) {
assert.ifError(err);
Groups.isMember(adminUid, 'PrivateCanJoin', function (err, isMember) {
assert.ifError(err);
assert(isMember);
done();
});
});
});
it('should request membership for regular user', function (done) {
socketGroups.join({uid: testUid}, {groupName: 'PrivateCanJoin'}, function (err) {
assert.ifError(err);
Groups.isPending(testUid, 'PrivateCanJoin', function (err, isPending) {
assert.ifError(err);
assert(isPending);
done();
});
});
});
});
after(function (done) { after(function (done) {
db.emptydb(done); db.emptydb(done);
}); });

@ -21,6 +21,7 @@ describe('Post\'s', function () {
var cid; var cid;
before(function (done) { before(function (done) {
groups.resetCache();
async.series({ async.series({
voterUid: function (next) { voterUid: function (next) {
user.create({username: 'upvoter'}, next); user.create({username: 'upvoter'}, next);

Loading…
Cancel
Save