mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-01 19:46:01 +01:00
some more group tests
This commit is contained in:
@@ -1,14 +1,14 @@
|
||||
"use strict";
|
||||
|
||||
var async = require('async'),
|
||||
var async = require('async');
|
||||
|
||||
groups = require('../groups'),
|
||||
meta = require('../meta'),
|
||||
user = require('../user'),
|
||||
utils = require('../../public/src/utils'),
|
||||
groupsController = require('../controllers/groups'),
|
||||
var groups = require('../groups');
|
||||
var meta = require('../meta');
|
||||
var user = require('../user');
|
||||
var utils = require('../../public/src/utils');
|
||||
var groupsController = require('../controllers/groups');
|
||||
|
||||
SocketGroups = {};
|
||||
var SocketGroups = {};
|
||||
|
||||
|
||||
SocketGroups.before = function (socket, method, data, next) {
|
||||
@@ -27,9 +27,13 @@ SocketGroups.join = function (socket, data, callback) {
|
||||
return callback(new Error('[[error:not-allowed]]'));
|
||||
}
|
||||
|
||||
groups.exists(data.groupName, function (err, exists) {
|
||||
if (err || !exists) {
|
||||
return callback(err || new Error('[[error:no-group]]'));
|
||||
async.waterfall([
|
||||
function (next) {
|
||||
groups.exists(data.groupName, next);
|
||||
},
|
||||
function (exists, next) {
|
||||
if (!exists) {
|
||||
return next(new Error('[[error:no-group]]'));
|
||||
}
|
||||
|
||||
if (parseInt(meta.config.allowPrivateGroups, 10) !== 1) {
|
||||
@@ -39,22 +43,20 @@ SocketGroups.join = function (socket, data, callback) {
|
||||
async.parallel({
|
||||
isAdmin: async.apply(user.isAdministrator, socket.uid),
|
||||
groupData: async.apply(groups.getGroupData, data.groupName)
|
||||
}, function (err, results) {
|
||||
if (err) {
|
||||
return callback(err);
|
||||
}
|
||||
|
||||
}, next);
|
||||
},
|
||||
function (results, next) {
|
||||
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) {
|
||||
groups.join(data.groupName, socket.uid, callback);
|
||||
groups.join(data.groupName, socket.uid, next);
|
||||
} else {
|
||||
groups.requestMembership(data.groupName, socket.uid, callback);
|
||||
groups.requestMembership(data.groupName, socket.uid, next);
|
||||
}
|
||||
});
|
||||
});
|
||||
}
|
||||
], callback);
|
||||
};
|
||||
|
||||
SocketGroups.leave = function (socket, data, callback) {
|
||||
|
||||
207
test/groups.js
207
test/groups.js
@@ -9,6 +9,8 @@ var Groups = require('../src/groups');
|
||||
var User = require('../src/user');
|
||||
|
||||
describe('Groups', function () {
|
||||
var adminUid;
|
||||
var testUid;
|
||||
before(function (done) {
|
||||
Groups.resetCache();
|
||||
async.parallel([
|
||||
@@ -19,6 +21,22 @@ describe('Groups', function () {
|
||||
description: 'Foobar!'
|
||||
}, 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) {
|
||||
// Create a new user
|
||||
User.create({
|
||||
@@ -26,18 +44,29 @@ describe('Groups', function () {
|
||||
email: 'b@c.com'
|
||||
}, next);
|
||||
},
|
||||
function (next) {
|
||||
User.create({
|
||||
username: 'admin',
|
||||
email: 'admin@admin.com'
|
||||
}, next);
|
||||
},
|
||||
function (next) {
|
||||
// Also create a hidden group
|
||||
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 () {
|
||||
it('should list the groups present', function (done) {
|
||||
Groups.getGroupsFromSet('groups:createtime', 0, 0, -1, function (err, groups) {
|
||||
assert.ifError(err);
|
||||
assert.equal(groups.length, 3);
|
||||
assert.equal(groups.length, 6);
|
||||
done();
|
||||
});
|
||||
});
|
||||
@@ -50,8 +79,7 @@ describe('Groups', function () {
|
||||
|
||||
it('with no options, should show group information', function (done) {
|
||||
Groups.get('Test', {}, function (err, groupObj) {
|
||||
if (err) return done(err);
|
||||
|
||||
assert.ifError(err);
|
||||
assert.equal(typeof groupObj, 'object');
|
||||
assert(Array.isArray(groupObj.members));
|
||||
assert.strictEqual(groupObj.name, 'Test');
|
||||
@@ -67,7 +95,7 @@ describe('Groups', function () {
|
||||
describe('.search()', function () {
|
||||
it('should return the "Test" group when searched for', function (done) {
|
||||
Groups.search('test', {}, function (err, groups) {
|
||||
if (err) return done(err);
|
||||
assert.ifError(err);
|
||||
assert.equal(1, groups.length);
|
||||
assert.strictEqual('Test', groups[0].name);
|
||||
done();
|
||||
@@ -78,20 +106,16 @@ describe('Groups', function () {
|
||||
describe('.isMember()', function () {
|
||||
it('should return boolean true when a user is in a group', function (done) {
|
||||
Groups.isMember(1, 'Test', function (err, isMember) {
|
||||
if (err) return done(err);
|
||||
|
||||
assert.ifError(err);
|
||||
assert.strictEqual(isMember, true);
|
||||
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
it('should return boolean false when a user is not in a group', function (done) {
|
||||
Groups.isMember(2, 'Test', function (err, isMember) {
|
||||
if (err) return done(err);
|
||||
|
||||
assert.ifError(err);
|
||||
assert.strictEqual(isMember, false);
|
||||
|
||||
done();
|
||||
});
|
||||
});
|
||||
@@ -100,20 +124,16 @@ describe('Groups', function () {
|
||||
describe('.isMemberOfGroupList', function () {
|
||||
it('should report that a user is part of a groupList, if they are', function (done) {
|
||||
Groups.isMemberOfGroupList(1, 'Hidden', function (err, isMember) {
|
||||
if (err) return done(err);
|
||||
|
||||
assert.ifError(err);
|
||||
assert.strictEqual(isMember, true);
|
||||
|
||||
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) {
|
||||
if (err) return done(err);
|
||||
|
||||
assert.ifError(err);
|
||||
assert.strictEqual(isMember, false);
|
||||
|
||||
done();
|
||||
});
|
||||
});
|
||||
@@ -122,28 +142,23 @@ describe('Groups', function () {
|
||||
describe('.exists()', function () {
|
||||
it('should verify that the test group exists', function (done) {
|
||||
Groups.exists('Test', function (err, exists) {
|
||||
if (err) return done(err);
|
||||
|
||||
assert.ifError(err);
|
||||
assert.strictEqual(exists, true);
|
||||
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
it('should verify that a fake group does not exist', function (done) {
|
||||
Groups.exists('Derp', function (err, exists) {
|
||||
if (err) return done(err);
|
||||
|
||||
assert.ifError(err);
|
||||
assert.strictEqual(exists, false);
|
||||
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
it('should check if group exists using an array', function (done) {
|
||||
Groups.exists(['Test', 'Derp'], function (err, groupsExists) {
|
||||
if (err) return done(err);
|
||||
|
||||
assert.ifError(err);
|
||||
assert.strictEqual(groupsExists[0], true);
|
||||
assert.strictEqual(groupsExists[1], false);
|
||||
done();
|
||||
@@ -157,8 +172,7 @@ describe('Groups', function () {
|
||||
name: 'foo',
|
||||
description: 'bar'
|
||||
}, function (err) {
|
||||
if (err) return done(err);
|
||||
|
||||
assert.ifError(err);
|
||||
Groups.get('foo', {}, done);
|
||||
});
|
||||
});
|
||||
@@ -175,13 +189,11 @@ describe('Groups', function () {
|
||||
describe('.hide()', function () {
|
||||
it('should mark the group as hidden', function (done) {
|
||||
Groups.hide('foo', function (err) {
|
||||
if (err) return done(err);
|
||||
assert.ifError(err);
|
||||
|
||||
Groups.get('foo', {}, function (err, groupObj) {
|
||||
if (err) return done(err);
|
||||
|
||||
assert.ifError(err);
|
||||
assert.strictEqual(true, groupObj.hidden);
|
||||
|
||||
done();
|
||||
});
|
||||
});
|
||||
@@ -202,13 +214,11 @@ describe('Groups', function () {
|
||||
Groups.update('updateTestGroup', {
|
||||
description: 'baz'
|
||||
}, function (err) {
|
||||
if (err) return done(err);
|
||||
assert.ifError(err);
|
||||
|
||||
Groups.get('updateTestGroup', {}, function (err, groupObj) {
|
||||
if (err) return done(err);
|
||||
|
||||
assert.ifError(err);
|
||||
assert.strictEqual('baz', groupObj.description);
|
||||
|
||||
done();
|
||||
});
|
||||
});
|
||||
@@ -218,14 +228,12 @@ describe('Groups', function () {
|
||||
Groups.update('updateTestGroup', {
|
||||
name: 'updateTestGroup?'
|
||||
}, function (err) {
|
||||
if (err) return done(err);
|
||||
assert.ifError(err);
|
||||
|
||||
Groups.get('updateTestGroup?', {}, function (err, groupObj) {
|
||||
if (err) return done(err);
|
||||
|
||||
assert.ifError(err);
|
||||
assert.strictEqual('updateTestGroup?', groupObj.name);
|
||||
assert.strictEqual('updatetestgroup', groupObj.slug);
|
||||
|
||||
done();
|
||||
});
|
||||
});
|
||||
@@ -239,7 +247,7 @@ describe('Groups', function () {
|
||||
|
||||
it('should destroy a group', function (done) {
|
||||
Groups.destroy('foobar?', function (err) {
|
||||
if (err) return done(err);
|
||||
assert.ifError(err);
|
||||
|
||||
Groups.get('foobar?', {}, function (err) {
|
||||
assert(err, 'Group still exists!');
|
||||
@@ -251,7 +259,7 @@ describe('Groups', function () {
|
||||
|
||||
it('should also remove the members set', function (done) {
|
||||
db.exists('group:foo:members', function (err, exists) {
|
||||
if (err) return done(err);
|
||||
assert.ifError(err);
|
||||
|
||||
assert.strictEqual(false, exists);
|
||||
|
||||
@@ -267,10 +275,10 @@ describe('Groups', function () {
|
||||
|
||||
it('should add a user to a group', function (done) {
|
||||
Groups.join('Test', 1, function (err) {
|
||||
if (err) return done(err);
|
||||
assert.ifError(err);
|
||||
|
||||
Groups.isMember(1, 'Test', function (err, isMember) {
|
||||
assert.equal(err, null);
|
||||
assert.ifError(err);
|
||||
assert.strictEqual(true, isMember);
|
||||
|
||||
done();
|
||||
@@ -282,10 +290,10 @@ describe('Groups', function () {
|
||||
describe('.leave()', function () {
|
||||
it('should remove a user from a group', function (done) {
|
||||
Groups.leave('Test', 1, function (err) {
|
||||
if (err) return done(err);
|
||||
assert.ifError(err);
|
||||
|
||||
Groups.isMember(1, 'Test', function (err, isMember) {
|
||||
assert.equal(err, null);
|
||||
assert.ifError(err);
|
||||
assert.strictEqual(false, isMember);
|
||||
|
||||
done();
|
||||
@@ -297,15 +305,13 @@ describe('Groups', function () {
|
||||
describe('.leaveAllGroups()', function () {
|
||||
it('should remove a user from all groups', function (done) {
|
||||
Groups.leaveAllGroups(1, function (err) {
|
||||
if (err) return done(err);
|
||||
assert.ifError(err);
|
||||
|
||||
var groups = ['Test', 'Hidden'];
|
||||
async.every(groups, function (group, next) {
|
||||
Groups.isMember(1, group, function (err, isMember) {
|
||||
if (err) done(err);
|
||||
else {
|
||||
assert.ifError(err);
|
||||
next(!isMember);
|
||||
}
|
||||
});
|
||||
}, function (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) {
|
||||
db.emptydb(done);
|
||||
});
|
||||
|
||||
@@ -21,6 +21,7 @@ describe('Post\'s', function () {
|
||||
var cid;
|
||||
|
||||
before(function (done) {
|
||||
groups.resetCache();
|
||||
async.series({
|
||||
voterUid: function (next) {
|
||||
user.create({username: 'upvoter'}, next);
|
||||
|
||||
Reference in New Issue
Block a user