You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1424 lines
50 KiB
JavaScript
1424 lines
50 KiB
JavaScript
10 years ago
|
'use strict';
|
||
|
|
||
4 years ago
|
const assert = require('assert');
|
||
|
const async = require('async');
|
||
4 years ago
|
const fs = require('fs');
|
||
4 years ago
|
const path = require('path');
|
||
|
const nconf = require('nconf');
|
||
11 years ago
|
|
||
4 years ago
|
const db = require('./mocks/databasemock');
|
||
|
const helpers = require('./helpers');
|
||
|
const Groups = require('../src/groups');
|
||
|
const User = require('../src/user');
|
||
2 years ago
|
const utils = require('../src/utils');
|
||
4 years ago
|
const socketGroups = require('../src/socket.io/groups');
|
||
3 years ago
|
const apiGroups = require('../src/api/groups');
|
||
4 years ago
|
const meta = require('../src/meta');
|
||
|
const navigation = require('../src/navigation/admin');
|
||
4 years ago
|
|
||
11 years ago
|
|
||
4 years ago
|
describe('Groups', () => {
|
||
4 years ago
|
let adminUid;
|
||
|
let testUid;
|
||
4 years ago
|
before(async () => {
|
||
4 years ago
|
const navData = require('../install/data/navigation.json');
|
||
|
await navigation.save(navData);
|
||
|
|
||
|
await Groups.create({
|
||
|
name: 'Test',
|
||
|
description: 'Foobar!',
|
||
|
});
|
||
|
|
||
|
await Groups.create({
|
||
|
name: 'PrivateNoJoin',
|
||
|
description: 'Private group',
|
||
|
private: 1,
|
||
|
disableJoinRequests: 1,
|
||
|
});
|
||
|
|
||
|
await Groups.create({
|
||
|
name: 'PrivateCanJoin',
|
||
|
description: 'Private group',
|
||
|
private: 1,
|
||
|
disableJoinRequests: 0,
|
||
|
});
|
||
|
|
||
|
await Groups.create({
|
||
|
name: 'PrivateNoLeave',
|
||
|
description: 'Private group',
|
||
|
private: 1,
|
||
|
disableLeave: 1,
|
||
|
});
|
||
|
|
||
|
await Groups.create({
|
||
|
name: 'Global Moderators',
|
||
|
userTitle: 'Global Moderator',
|
||
|
description: 'Forum wide moderators',
|
||
|
hidden: 0,
|
||
|
private: 1,
|
||
|
disableJoinRequests: 1,
|
||
|
});
|
||
|
|
||
|
// Also create a hidden group
|
||
|
await Groups.join('Hidden', 'Test');
|
||
|
// create another group that starts with test for search/sort
|
||
3 years ago
|
await Groups.create({ name: 'Test2', description: 'Foobar!' });
|
||
4 years ago
|
|
||
|
testUid = await User.create({
|
||
|
username: 'testuser',
|
||
|
email: '[email protected]',
|
||
|
});
|
||
|
|
||
|
adminUid = await User.create({
|
||
|
username: 'admin',
|
||
|
email: '[email protected]',
|
||
|
password: '123456',
|
||
8 years ago
|
});
|
||
4 years ago
|
await Groups.join('administrators', adminUid);
|
||
11 years ago
|
});
|
||
|
|
||
4 years ago
|
describe('.list()', () => {
|
||
|
it('should list the groups present', (done) => {
|
||
|
Groups.getGroupsFromSet('groups:visible:createtime', 0, -1, (err, groups) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
5 years ago
|
assert.equal(groups.length, 5);
|
||
11 years ago
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
describe('.get()', () => {
|
||
|
before((done) => {
|
||
8 years ago
|
Groups.join('Test', testUid, done);
|
||
11 years ago
|
});
|
||
|
|
||
4 years ago
|
it('with no options, should show group information', (done) => {
|
||
|
Groups.get('Test', {}, (err, groupObj) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
11 years ago
|
assert.equal(typeof groupObj, 'object');
|
||
|
assert(Array.isArray(groupObj.members));
|
||
|
assert.strictEqual(groupObj.name, 'Test');
|
||
|
assert.strictEqual(groupObj.description, 'Foobar!');
|
||
|
assert.strictEqual(groupObj.memberCount, 1);
|
||
|
assert.equal(typeof groupObj.members[0], 'object');
|
||
|
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
8 years ago
|
|
||
4 years ago
|
it('should return null if group does not exist', (done) => {
|
||
|
Groups.get('doesnotexist', {}, (err, groupObj) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
|
assert.strictEqual(groupObj, null);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
11 years ago
|
});
|
||
|
|
||
4 years ago
|
describe('.search()', () => {
|
||
4 years ago
|
const socketGroups = require('../src/socket.io/groups');
|
||
8 years ago
|
|
||
4 years ago
|
it('should return empty array if query is falsy', (done) => {
|
||
|
Groups.search(null, {}, (err, groups) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
|
assert.equal(0, groups.length);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should return the groups when search query is empty', (done) => {
|
||
|
socketGroups.search({ uid: adminUid }, { query: '' }, (err, groups) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
5 years ago
|
assert.equal(5, groups.length);
|
||
8 years ago
|
done();
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should return the "Test" group when searched for', (done) => {
|
||
|
socketGroups.search({ uid: adminUid }, { query: 'test' }, (err, groups) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
8 years ago
|
assert.equal(2, groups.length);
|
||
8 years ago
|
assert.strictEqual('Test', groups[0].name);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should return the "Test" group when searched for and sort by member count', (done) => {
|
||
|
Groups.search('test', { filterHidden: true, sort: 'count' }, (err, groups) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
8 years ago
|
assert.equal(2, groups.length);
|
||
8 years ago
|
assert.strictEqual('Test', groups[0].name);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should return the "Test" group when searched for and sort by creation time', (done) => {
|
||
|
Groups.search('test', { filterHidden: true, sort: 'date' }, (err, groups) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
8 years ago
|
assert.equal(2, groups.length);
|
||
|
assert.strictEqual('Test', groups[1].name);
|
||
11 years ago
|
done();
|
||
|
});
|
||
|
});
|
||
8 years ago
|
|
||
4 years ago
|
it('should return all users if no query', (done) => {
|
||
8 years ago
|
function createAndJoinGroup(username, email, callback) {
|
||
|
async.waterfall([
|
||
|
function (next) {
|
||
|
User.create({ username: username, email: email }, next);
|
||
|
},
|
||
|
function (uid, next) {
|
||
|
Groups.join('Test', uid, next);
|
||
|
},
|
||
|
], callback);
|
||
|
}
|
||
|
async.series([
|
||
|
function (next) {
|
||
|
createAndJoinGroup('newuser', '[email protected]', next);
|
||
|
},
|
||
|
function (next) {
|
||
|
createAndJoinGroup('bob', '[email protected]', next);
|
||
|
},
|
||
4 years ago
|
], (err) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
8 years ago
|
|
||
4 years ago
|
socketGroups.searchMembers({ uid: adminUid }, { groupName: 'Test', query: '' }, (err, data) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
8 years ago
|
assert.equal(data.users.length, 3);
|
||
|
done();
|
||
8 years ago
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should search group members', (done) => {
|
||
|
socketGroups.searchMembers({ uid: adminUid }, { groupName: 'Test', query: 'test' }, (err, data) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
|
assert.strictEqual('testuser', data.users[0].username);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
5 years ago
|
|
||
4 years ago
|
it('should not return hidden groups', async () => {
|
||
5 years ago
|
await Groups.create({
|
||
|
name: 'hiddenGroup',
|
||
|
hidden: '1',
|
||
|
});
|
||
|
const result = await socketGroups.search({ uid: testUid }, { query: 'hiddenGroup' });
|
||
|
assert.equal(result.length, 0);
|
||
|
});
|
||
11 years ago
|
});
|
||
|
|
||
4 years ago
|
describe('.isMember()', () => {
|
||
2 years ago
|
it('should return boolean true when a user is in a group', async () => {
|
||
|
const isMember = await Groups.isMember(1, 'Test');
|
||
|
assert.strictEqual(isMember, true);
|
||
11 years ago
|
});
|
||
|
|
||
2 years ago
|
it('should return boolean false when a user is not in a group', async () => {
|
||
|
const isMember = await Groups.isMember(2, 'Test');
|
||
|
assert.strictEqual(isMember, false);
|
||
11 years ago
|
});
|
||
6 years ago
|
|
||
2 years ago
|
it('should return true for uid 0 and guests group', async () => {
|
||
|
const isMember = await Groups.isMember(0, 'guests');
|
||
|
assert.strictEqual(isMember, true);
|
||
6 years ago
|
});
|
||
|
|
||
2 years ago
|
it('should return false for uid 0 and spiders group', async () => {
|
||
|
const isMember = await Groups.isMember(0, 'spiders');
|
||
|
assert.strictEqual(isMember, false);
|
||
|
});
|
||
|
|
||
|
it('should return true for uid -1 and spiders group', async () => {
|
||
|
const isMember = await Groups.isMember(-1, 'spiders');
|
||
|
assert.strictEqual(isMember, true);
|
||
|
});
|
||
|
|
||
|
it('should return false for uid -1 and guests group', async () => {
|
||
|
const isMember = await Groups.isMember(-1, 'guests');
|
||
|
assert.strictEqual(isMember, false);
|
||
|
});
|
||
|
|
||
|
it('should return true for uid 0, false for uid -1 with guests group', async () => {
|
||
|
const isMembers = await Groups.isMembers([1, 0, -1], 'guests');
|
||
|
assert.deepStrictEqual(isMembers, [false, true, false]);
|
||
|
});
|
||
|
|
||
|
it('should return false for uid 0, true for uid -1 with spiders group', async () => {
|
||
|
const isMembers = await Groups.isMembers([1, 0, -1], 'spiders');
|
||
|
assert.deepStrictEqual(isMembers, [false, false, true]);
|
||
|
});
|
||
|
|
||
|
it('should return true for uid 0 and guests group', async () => {
|
||
|
const isMembers = await Groups.isMemberOfGroups(0, ['guests', 'registered-users', 'spiders']);
|
||
|
assert.deepStrictEqual(isMembers, [true, false, false]);
|
||
|
});
|
||
|
|
||
|
it('should return true for uid -1 and spiders group', async () => {
|
||
|
const isMembers = await Groups.isMemberOfGroups(-1, ['guests', 'registered-users', 'spiders']);
|
||
|
assert.deepStrictEqual(isMembers, [false, false, true]);
|
||
6 years ago
|
});
|
||
11 years ago
|
});
|
||
|
|
||
4 years ago
|
describe('.isMemberOfGroupList', () => {
|
||
|
it('should report that a user is part of a groupList, if they are', (done) => {
|
||
|
Groups.isMemberOfGroupList(1, 'Hidden', (err, isMember) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
11 years ago
|
assert.strictEqual(isMember, true);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should report that a user is not part of a groupList, if they are not', (done) => {
|
||
|
Groups.isMemberOfGroupList(2, 'Hidden', (err, isMember) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
11 years ago
|
assert.strictEqual(isMember, false);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
describe('.exists()', () => {
|
||
|
it('should verify that the test group exists', (done) => {
|
||
|
Groups.exists('Test', (err, exists) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
11 years ago
|
assert.strictEqual(exists, true);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should verify that a fake group does not exist', (done) => {
|
||
|
Groups.exists('Derp', (err, exists) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
11 years ago
|
assert.strictEqual(exists, false);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
9 years ago
|
|
||
4 years ago
|
it('should check if group exists using an array', (done) => {
|
||
|
Groups.exists(['Test', 'Derp'], (err, groupsExists) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
9 years ago
|
assert.strictEqual(groupsExists[0], true);
|
||
|
assert.strictEqual(groupsExists[1], false);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
11 years ago
|
});
|
||
|
|
||
4 years ago
|
describe('.create()', () => {
|
||
|
it('should create another group', (done) => {
|
||
10 years ago
|
Groups.create({
|
||
|
name: 'foo',
|
||
8 years ago
|
description: 'bar',
|
||
4 years ago
|
}, (err) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
11 years ago
|
Groups.get('foo', {}, done);
|
||
|
});
|
||
|
});
|
||
9 years ago
|
|
||
4 years ago
|
it('should create a hidden group if hidden is 1', (done) => {
|
||
7 years ago
|
Groups.create({
|
||
|
name: 'hidden group',
|
||
|
hidden: '1',
|
||
4 years ago
|
}, (err) => {
|
||
7 years ago
|
assert.ifError(err);
|
||
4 years ago
|
db.isSortedSetMember('groups:visible:memberCount', 'visible group', (err, isMember) => {
|
||
7 years ago
|
assert.ifError(err);
|
||
|
assert(!isMember);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should create a visible group if hidden is 0', (done) => {
|
||
7 years ago
|
Groups.create({
|
||
|
name: 'visible group',
|
||
|
hidden: '0',
|
||
4 years ago
|
}, (err) => {
|
||
7 years ago
|
assert.ifError(err);
|
||
4 years ago
|
db.isSortedSetMember('groups:visible:memberCount', 'visible group', (err, isMember) => {
|
||
7 years ago
|
assert.ifError(err);
|
||
|
assert(isMember);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should create a visible group if hidden is not passed in', (done) => {
|
||
7 years ago
|
Groups.create({
|
||
|
name: 'visible group 2',
|
||
4 years ago
|
}, (err) => {
|
||
7 years ago
|
assert.ifError(err);
|
||
4 years ago
|
db.isSortedSetMember('groups:visible:memberCount', 'visible group 2', (err, isMember) => {
|
||
7 years ago
|
assert.ifError(err);
|
||
|
assert(isMember);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should fail to create group with duplicate group name', (done) => {
|
||
|
Groups.create({ name: 'foo' }, (err) => {
|
||
9 years ago
|
assert(err);
|
||
|
assert.equal(err.message, '[[error:group-already-exists]]');
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
8 years ago
|
|
||
4 years ago
|
it('should fail to create group if slug is empty', (done) => {
|
||
|
Groups.create({ name: '>>>>' }, (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:invalid-group-name]]');
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should fail if group name is invalid', (done) => {
|
||
|
Groups.create({ name: 'not/valid' }, (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:invalid-group-name]]');
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
8 years ago
|
|
||
4 years ago
|
it('should fail if group name is invalid', (done) => {
|
||
|
Groups.create({ name: ['array/'] }, (err) => {
|
||
5 years ago
|
assert.equal(err.message, '[[error:invalid-group-name]]');
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
|
||
3 years ago
|
it('should fail if group name is invalid', async () => {
|
||
|
try {
|
||
|
await apiGroups.create({ uid: adminUid }, { name: ['test', 'administrators'] });
|
||
|
} catch (err) {
|
||
|
return assert.equal(err.message, '[[error:invalid-group-name]]');
|
||
|
}
|
||
|
assert(false);
|
||
5 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should not create a system group', async () => {
|
||
|
await apiGroups.create({ uid: adminUid }, { name: 'mysystemgroup', system: true });
|
||
|
const data = await Groups.getGroupData('mysystemgroup');
|
||
|
assert.strictEqual(data.system, 0);
|
||
5 years ago
|
});
|
||
|
|
||
4 years ago
|
it('should fail if group name is invalid', (done) => {
|
||
|
Groups.create({ name: 'not:valid' }, (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:invalid-group-name]]');
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
6 years ago
|
|
||
4 years ago
|
it('should return falsy for userTitleEnabled', (done) => {
|
||
|
Groups.create({ name: 'userTitleEnabledGroup' }, (err) => {
|
||
6 years ago
|
assert.ifError(err);
|
||
4 years ago
|
Groups.setGroupField('userTitleEnabledGroup', 'userTitleEnabled', 0, (err) => {
|
||
6 years ago
|
assert.ifError(err);
|
||
4 years ago
|
Groups.getGroupData('userTitleEnabledGroup', (err, data) => {
|
||
6 years ago
|
assert.ifError(err);
|
||
|
assert.strictEqual(data.userTitleEnabled, 0);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
});
|
||
11 years ago
|
});
|
||
|
|
||
4 years ago
|
describe('.hide()', () => {
|
||
2 years ago
|
it('should mark the group as hidden', async () => {
|
||
|
await Groups.hide('foo');
|
||
|
const groupObj = await Groups.get('foo', {});
|
||
|
assert.strictEqual(1, groupObj.hidden);
|
||
|
const isMember = await db.isSortedSetMember('groups:visible:createtime', 'foo');
|
||
|
assert.strictEqual(isMember, false);
|
||
11 years ago
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
describe('.update()', () => {
|
||
|
before((done) => {
|
||
10 years ago
|
Groups.create({
|
||
|
name: 'updateTestGroup',
|
||
10 years ago
|
description: 'bar',
|
||
|
system: 0,
|
||
8 years ago
|
hidden: 0,
|
||
10 years ago
|
}, done);
|
||
10 years ago
|
});
|
||
10 years ago
|
|
||
4 years ago
|
it('should change an aspect of a group', (done) => {
|
||
10 years ago
|
Groups.update('updateTestGroup', {
|
||
8 years ago
|
description: 'baz',
|
||
4 years ago
|
}, (err) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
11 years ago
|
|
||
4 years ago
|
Groups.get('updateTestGroup', {}, (err, groupObj) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
11 years ago
|
assert.strictEqual('baz', groupObj.description);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
10 years ago
|
|
||
4 years ago
|
it('should rename a group and not break navigation routes', async () => {
|
||
4 years ago
|
await Groups.update('updateTestGroup', {
|
||
8 years ago
|
name: 'updateTestGroup?',
|
||
10 years ago
|
});
|
||
4 years ago
|
|
||
|
const groupObj = await Groups.get('updateTestGroup?', {});
|
||
|
assert.strictEqual('updateTestGroup?', groupObj.name);
|
||
|
assert.strictEqual('updatetestgroup', groupObj.slug);
|
||
|
|
||
|
const navItems = await navigation.get();
|
||
|
assert.strictEqual(navItems[0].route, '/categories');
|
||
10 years ago
|
});
|
||
8 years ago
|
|
||
4 years ago
|
it('should fail if system groups is being renamed', (done) => {
|
||
8 years ago
|
Groups.update('administrators', {
|
||
|
name: 'administrators_fail',
|
||
4 years ago
|
}, (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:not-allowed-to-rename-system-group]]');
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
8 years ago
|
|
||
3 years ago
|
it('should fail to rename if group name is invalid', async () => {
|
||
|
try {
|
||
|
await apiGroups.update({ uid: adminUid }, { slug: ['updateTestGroup?'], values: {} });
|
||
|
} catch (err) {
|
||
|
return assert.strictEqual(err.message, '[[error:invalid-group-name]]');
|
||
|
}
|
||
|
assert(false);
|
||
5 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should fail to rename if group name is too short', async () => {
|
||
|
try {
|
||
|
const slug = await Groups.getGroupField('updateTestGroup?', 'slug');
|
||
|
await apiGroups.update({ uid: adminUid }, { slug: slug, name: '' });
|
||
|
} catch (err) {
|
||
|
return assert.strictEqual(err.message, '[[error:group-name-too-short]]');
|
||
|
}
|
||
|
assert(false);
|
||
5 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should fail to rename if group name is invalid', async () => {
|
||
|
try {
|
||
|
const slug = await Groups.getGroupField('updateTestGroup?', 'slug');
|
||
|
await apiGroups.update({ uid: adminUid }, { slug: slug, name: ['invalid'] });
|
||
|
} catch (err) {
|
||
|
return assert.strictEqual(err.message, '[[error:invalid-group-name]]');
|
||
|
}
|
||
|
assert(false);
|
||
5 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should fail to rename if group name is invalid', async () => {
|
||
|
try {
|
||
|
const slug = await Groups.getGroupField('updateTestGroup?', 'slug');
|
||
|
await apiGroups.update({ uid: adminUid }, { slug: slug, name: 'cid:0:privileges:ban' });
|
||
|
} catch (err) {
|
||
|
return assert.strictEqual(err.message, '[[error:invalid-group-name]]');
|
||
|
}
|
||
|
assert(false);
|
||
5 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should fail to rename if group name is too long', async () => {
|
||
|
try {
|
||
|
const slug = await Groups.getGroupField('updateTestGroup?', 'slug');
|
||
|
await apiGroups.update({ uid: adminUid }, { slug: slug, name: 'verylongstringverylongstringverylongstringverylongstringverylongstringverylongstringverylongstringverylongstringverylongstringverylongstringverylongstringverylongstringverylongstringverylongstringverylongstringverylongstringverylongstringverylongstringverylongstringverylongstring' });
|
||
|
} catch (err) {
|
||
|
return assert.strictEqual(err.message, '[[error:group-name-too-long]]');
|
||
|
}
|
||
|
assert(false);
|
||
5 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should fail to rename if group name is invalid', async () => {
|
||
|
const slug = await Groups.getGroupField('updateTestGroup?', 'slug');
|
||
|
const invalidNames = ['test:test', 'another/test', '---'];
|
||
|
for (const name of invalidNames) {
|
||
|
try {
|
||
|
// eslint-disable-next-line no-await-in-loop
|
||
|
await apiGroups.update({ uid: adminUid }, { slug: slug, name: name });
|
||
|
assert(false);
|
||
|
} catch (err) {
|
||
|
assert.strictEqual(err.message, '[[error:invalid-group-name]]');
|
||
|
}
|
||
|
}
|
||
5 years ago
|
});
|
||
|
|
||
4 years ago
|
it('should fail to rename group to an existing group', (done) => {
|
||
8 years ago
|
Groups.create({
|
||
|
name: 'group2',
|
||
|
system: 0,
|
||
|
hidden: 0,
|
||
4 years ago
|
}, (err) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
|
Groups.update('group2', {
|
||
|
name: 'updateTestGroup?',
|
||
4 years ago
|
}, (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:group-already-exists]]');
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
11 years ago
|
});
|
||
|
|
||
4 years ago
|
describe('.destroy()', () => {
|
||
|
before((done) => {
|
||
10 years ago
|
Groups.join('foobar?', 1, done);
|
||
11 years ago
|
});
|
||
|
|
||
4 years ago
|
it('should destroy a group', (done) => {
|
||
|
Groups.destroy('foobar?', (err) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
11 years ago
|
|
||
4 years ago
|
Groups.get('foobar?', {}, (err, groupObj) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
|
assert.strictEqual(groupObj, null);
|
||
11 years ago
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
11 years ago
|
|
||
4 years ago
|
it('should also remove the members set', (done) => {
|
||
|
db.exists('group:foo:members', (err, exists) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
11 years ago
|
assert.strictEqual(false, exists);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
6 years ago
|
|
||
4 years ago
|
it('should remove group from privilege groups', (done) => {
|
||
6 years ago
|
const privileges = require('../src/privileges');
|
||
|
const cid = 1;
|
||
|
const groupName = '1';
|
||
|
const uid = 1;
|
||
|
async.waterfall([
|
||
|
function (next) {
|
||
|
Groups.create({ name: groupName }, next);
|
||
|
},
|
||
|
function (groupData, next) {
|
||
5 years ago
|
privileges.categories.give(['groups:topics:create'], cid, groupName, next);
|
||
6 years ago
|
},
|
||
|
function (next) {
|
||
|
Groups.isMember(groupName, 'cid:1:privileges:groups:topics:create', next);
|
||
|
},
|
||
|
function (isMember, next) {
|
||
|
assert(isMember);
|
||
|
Groups.destroy(groupName, next);
|
||
|
},
|
||
|
function (next) {
|
||
|
Groups.isMember(groupName, 'cid:1:privileges:groups:topics:create', next);
|
||
|
},
|
||
|
function (isMember, next) {
|
||
|
assert(!isMember);
|
||
|
Groups.isMember(uid, 'registered-users', next);
|
||
|
},
|
||
|
function (isMember, next) {
|
||
|
assert(isMember);
|
||
|
next();
|
||
|
},
|
||
|
], done);
|
||
|
});
|
||
11 years ago
|
});
|
||
|
|
||
4 years ago
|
describe('.join()', () => {
|
||
|
before((done) => {
|
||
8 years ago
|
Groups.leave('Test', testUid, done);
|
||
11 years ago
|
});
|
||
|
|
||
4 years ago
|
it('should add a user to a group', (done) => {
|
||
|
Groups.join('Test', testUid, (err) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
11 years ago
|
|
||
4 years ago
|
Groups.isMember(testUid, 'Test', (err, isMember) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
11 years ago
|
assert.strictEqual(true, isMember);
|
||
|
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
8 years ago
|
|
||
4 years ago
|
it('should fail to add user to admin group', async () => {
|
||
5 years ago
|
const oldValue = meta.config.allowPrivateGroups;
|
||
|
try {
|
||
|
meta.config.allowPrivateGroups = false;
|
||
|
const newUid = await User.create({ username: 'newadmin' });
|
||
3 years ago
|
await apiGroups.join({ uid: newUid }, { slug: ['test', 'administrators'], uid: newUid }, 1);
|
||
5 years ago
|
const isMember = await Groups.isMember(newUid, 'administrators');
|
||
|
assert(!isMember);
|
||
|
} catch (err) {
|
||
4 years ago
|
assert.strictEqual(err.message, '[[error:no-group]]');
|
||
5 years ago
|
}
|
||
|
meta.config.allowPrivateGroups = oldValue;
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should fail to add user to group if group name is invalid', (done) => {
|
||
|
Groups.join(0, 1, (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:invalid-data]]');
|
||
4 years ago
|
Groups.join(null, 1, (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:invalid-data]]');
|
||
4 years ago
|
Groups.join(undefined, 1, (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:invalid-data]]');
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should fail to add user to group if uid is invalid', (done) => {
|
||
|
Groups.join('Test', 0, (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:invalid-uid]]');
|
||
4 years ago
|
Groups.join('Test', null, (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:invalid-uid]]');
|
||
4 years ago
|
Groups.join('Test', undefined, (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:invalid-uid]]');
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
});
|
||
6 years ago
|
|
||
4 years ago
|
it('should add user to Global Moderators group', async () => {
|
||
4 years ago
|
const uid = await User.create({ username: 'glomod' });
|
||
3 years ago
|
const slug = await Groups.getGroupField('Global Moderators', 'slug');
|
||
|
await apiGroups.join({ uid: adminUid }, { slug: slug, uid: uid });
|
||
4 years ago
|
const isGlobalMod = await User.isGlobalModerator(uid);
|
||
|
assert.strictEqual(isGlobalMod, true);
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should add user to multiple groups', (done) => {
|
||
4 years ago
|
const groupNames = ['test-hidden1', 'Test', 'test-hidden2', 'empty group'];
|
||
4 years ago
|
Groups.create({ name: 'empty group' }, (err) => {
|
||
6 years ago
|
assert.ifError(err);
|
||
4 years ago
|
Groups.join(groupNames, testUid, (err) => {
|
||
6 years ago
|
assert.ifError(err);
|
||
4 years ago
|
Groups.isMemberOfGroups(testUid, groupNames, (err, isMembers) => {
|
||
6 years ago
|
assert.ifError(err);
|
||
|
assert(isMembers.every(Boolean));
|
||
4 years ago
|
db.sortedSetScores('groups:visible:memberCount', groupNames, (err, memberCounts) => {
|
||
6 years ago
|
assert.ifError(err);
|
||
|
// hidden groups are not in "groups:visible:memberCount" so they are null
|
||
|
assert.deepEqual(memberCounts, [null, 3, null, 1]);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should set group title when user joins the group', (done) => {
|
||
4 years ago
|
const groupName = 'this will be title';
|
||
4 years ago
|
User.create({ username: 'needstitle' }, (err, uid) => {
|
||
6 years ago
|
assert.ifError(err);
|
||
4 years ago
|
Groups.create({ name: groupName }, (err) => {
|
||
6 years ago
|
assert.ifError(err);
|
||
4 years ago
|
Groups.join([groupName], uid, (err) => {
|
||
6 years ago
|
assert.ifError(err);
|
||
4 years ago
|
User.getUserData(uid, (err, data) => {
|
||
6 years ago
|
assert.ifError(err);
|
||
4 years ago
|
assert.equal(data.groupTitle, `["${groupName}"]`);
|
||
6 years ago
|
assert.deepEqual(data.groupTitleArray, [groupName]);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
});
|
||
4 years ago
|
|
||
4 years ago
|
it('should fail to add user to system group', async () => {
|
||
4 years ago
|
const uid = await User.create({ username: 'eviluser' });
|
||
|
const oldValue = meta.config.allowPrivateGroups;
|
||
|
meta.config.allowPrivateGroups = 0;
|
||
|
async function test(groupName) {
|
||
|
let err;
|
||
|
try {
|
||
3 years ago
|
const slug = await Groups.getGroupField(groupName, 'slug');
|
||
|
await apiGroups.join({ uid: uid }, { slug: slug, uid: uid });
|
||
4 years ago
|
const isMember = await Groups.isMember(uid, groupName);
|
||
|
assert.strictEqual(isMember, false);
|
||
|
} catch (_err) {
|
||
|
err = _err;
|
||
|
}
|
||
|
assert.strictEqual(err.message, '[[error:not-allowed]]');
|
||
|
}
|
||
|
const groups = ['Global Moderators', 'verified-users', 'unverified-users'];
|
||
|
for (const g of groups) {
|
||
|
// eslint-disable-next-line no-await-in-loop
|
||
|
await test(g);
|
||
|
}
|
||
|
meta.config.allowPrivateGroups = oldValue;
|
||
|
});
|
||
4 years ago
|
|
||
2 years ago
|
it('should fail to add user to group if calling uid is non-self and non-admin', async () => {
|
||
|
const uid1 = await User.create({ username: utils.generateUUID().slice(0, 8) });
|
||
|
const uid2 = await User.create({ username: utils.generateUUID().slice(0, 8) });
|
||
|
|
||
2 years ago
|
await assert.rejects(
|
||
|
apiGroups.join({ uid: uid1 }, { slug: 'test', uid: uid2 }),
|
||
|
{ message: '[[error:not-allowed]]' }
|
||
|
);
|
||
2 years ago
|
});
|
||
|
|
||
4 years ago
|
it('should allow admins to join private groups', async () => {
|
||
3 years ago
|
await apiGroups.join({ uid: adminUid }, { uid: adminUid, slug: 'global-moderators' });
|
||
4 years ago
|
assert(await Groups.isMember(adminUid, 'Global Moderators'));
|
||
|
});
|
||
11 years ago
|
});
|
||
11 years ago
|
|
||
4 years ago
|
describe('.leave()', () => {
|
||
|
it('should remove a user from a group', (done) => {
|
||
|
Groups.leave('Test', testUid, (err) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
11 years ago
|
|
||
4 years ago
|
Groups.isMember(testUid, 'Test', (err, isMember) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
11 years ago
|
assert.strictEqual(false, isMember);
|
||
|
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
describe('.leaveAllGroups()', () => {
|
||
|
it('should remove a user from all groups', (done) => {
|
||
|
Groups.leaveAllGroups(testUid, (err) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
11 years ago
|
|
||
3 years ago
|
const groups = ['Test', 'Hidden'];
|
||
4 years ago
|
async.every(groups, (group, next) => {
|
||
|
Groups.isMember(testUid, group, (err, isMember) => {
|
||
8 years ago
|
next(err, !isMember);
|
||
11 years ago
|
});
|
||
4 years ago
|
}, (err, result) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
11 years ago
|
assert(result);
|
||
|
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
});
|
||
10 years ago
|
|
||
4 years ago
|
describe('.show()', () => {
|
||
|
it('should make a group visible', (done) => {
|
||
8 years ago
|
Groups.show('Test', function (err) {
|
||
9 years ago
|
assert.ifError(err);
|
||
|
assert.equal(arguments.length, 1);
|
||
4 years ago
|
db.isSortedSetMember('groups:visible:createtime', 'Test', (err, isMember) => {
|
||
9 years ago
|
assert.ifError(err);
|
||
|
assert.strictEqual(isMember, true);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
describe('socket methods', () => {
|
||
|
it('should error if data is null', (done) => {
|
||
|
socketGroups.before({ uid: 0 }, 'groups.join', null, (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:invalid-data]]');
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should not error if data is valid', (done) => {
|
||
|
socketGroups.before({ uid: 0 }, 'groups.join', {}, (err) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
|
||
3 years ago
|
it('should return error if not logged in', async () => {
|
||
|
try {
|
||
|
await apiGroups.join({ uid: 0 }, {});
|
||
|
assert(false);
|
||
|
} catch (err) {
|
||
8 years ago
|
assert.equal(err.message, '[[error:invalid-uid]]');
|
||
3 years ago
|
}
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should return error if group name is special', async () => {
|
||
|
try {
|
||
|
await apiGroups.join({ uid: testUid }, { slug: 'administrators', uid: testUid });
|
||
|
assert(false);
|
||
|
} catch (err) {
|
||
8 years ago
|
assert.equal(err.message, '[[error:not-allowed]]');
|
||
3 years ago
|
}
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should error if group does not exist', async () => {
|
||
|
try {
|
||
|
await apiGroups.join({ uid: adminUid }, { slug: 'doesnotexist', uid: adminUid });
|
||
|
assert(false);
|
||
|
} catch (err) {
|
||
8 years ago
|
assert.equal(err.message, '[[error:no-group]]');
|
||
3 years ago
|
}
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should join test group', async () => {
|
||
8 years ago
|
meta.config.allowPrivateGroups = 0;
|
||
3 years ago
|
await apiGroups.join({ uid: adminUid }, { slug: 'test', uid: adminUid });
|
||
|
const isMember = await Groups.isMember(adminUid, 'Test');
|
||
|
assert(isMember);
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should error if not logged in', async () => {
|
||
|
try {
|
||
|
await apiGroups.leave({ uid: 0 }, {});
|
||
|
assert(false);
|
||
|
} catch (err) {
|
||
8 years ago
|
assert.equal(err.message, '[[error:invalid-uid]]');
|
||
3 years ago
|
}
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should return error if group name is special', async () => {
|
||
|
try {
|
||
|
await apiGroups.leave({ uid: adminUid }, { slug: 'administrators', uid: adminUid });
|
||
|
assert(false);
|
||
|
} catch (err) {
|
||
8 years ago
|
assert.equal(err.message, '[[error:cant-remove-self-as-admin]]');
|
||
3 years ago
|
}
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should leave test group', async () => {
|
||
|
await apiGroups.leave({ uid: adminUid }, { slug: 'test', uid: adminUid });
|
||
|
const isMember = await Groups.isMember(adminUid, 'Test');
|
||
|
assert(!isMember);
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should fail to join if group is private and join requests are disabled', async () => {
|
||
8 years ago
|
meta.config.allowPrivateGroups = 1;
|
||
3 years ago
|
try {
|
||
|
await apiGroups.join({ uid: testUid }, { slug: 'privatenojoin', uid: testUid });
|
||
|
assert(false);
|
||
|
} catch (err) {
|
||
5 years ago
|
assert.equal(err.message, '[[error:group-join-disabled]]');
|
||
3 years ago
|
}
|
||
8 years ago
|
});
|
||
|
|
||
5 years ago
|
it('should fail to leave if group is private and leave is disabled', async () => {
|
||
3 years ago
|
await Groups.join('PrivateNoLeave', testUid);
|
||
|
const isMember = await Groups.isMember(testUid, 'PrivateNoLeave');
|
||
|
assert(isMember);
|
||
5 years ago
|
try {
|
||
3 years ago
|
await apiGroups.leave({ uid: testUid }, { slug: 'privatenoleave', uid: testUid });
|
||
|
assert(false);
|
||
5 years ago
|
} catch (err) {
|
||
|
assert.equal(err.message, '[[error:group-leave-disabled]]');
|
||
|
}
|
||
|
});
|
||
|
|
||
3 years ago
|
it('should join if user is admin', async () => {
|
||
|
await apiGroups.join({ uid: adminUid }, { slug: 'privatecanjoin', uid: adminUid });
|
||
|
const isMember = await Groups.isMember(adminUid, 'PrivateCanJoin');
|
||
|
assert(isMember);
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should request membership for regular user', async () => {
|
||
|
await apiGroups.join({ uid: testUid }, { slug: 'privatecanjoin', uid: testUid });
|
||
|
const isPending = await Groups.isPending(testUid, 'PrivateCanJoin');
|
||
|
assert(isPending);
|
||
8 years ago
|
});
|
||
|
|
||
2 years ago
|
it('should reject membership of user', async () => {
|
||
|
await apiGroups.reject({ uid: adminUid }, { slug: 'privatecanjoin', uid: testUid });
|
||
|
const invited = await Groups.isInvited(testUid, 'PrivateCanJoin');
|
||
|
assert.equal(invited, false);
|
||
8 years ago
|
});
|
||
|
|
||
2 years ago
|
it('should error if not owner or admin', async () => {
|
||
2 years ago
|
await assert.rejects(
|
||
|
apiGroups.accept({ uid: 0 }, { slug: 'privatecanjoin', uid: testUid }),
|
||
|
{ message: '[[error:no-privileges]]' }
|
||
|
);
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should accept membership of user', async () => {
|
||
|
await apiGroups.join({ uid: testUid }, { slug: 'privatecanjoin', uid: testUid });
|
||
2 years ago
|
await apiGroups.accept({ uid: adminUid }, { slug: 'privatecanjoin', uid: testUid });
|
||
3 years ago
|
const isMember = await Groups.isMember(testUid, 'PrivateCanJoin');
|
||
|
assert(isMember);
|
||
8 years ago
|
});
|
||
|
|
||
2 years ago
|
it('should issue invite to user', async () => {
|
||
|
const uid = await User.create({ username: 'invite1' });
|
||
|
await apiGroups.issueInvite({ uid: adminUid }, { slug: 'privatecanjoin', uid });
|
||
|
const isInvited = await Groups.isInvited(uid, 'PrivateCanJoin');
|
||
|
assert(isInvited);
|
||
8 years ago
|
});
|
||
|
|
||
2 years ago
|
it('should rescind invite', async () => {
|
||
|
const uid = await User.create({ username: 'invite3' });
|
||
|
await apiGroups.issueInvite({ uid: adminUid }, { slug: 'privatecanjoin', uid });
|
||
|
await apiGroups.rejectInvite({ uid: adminUid }, { slug: 'privatecanjoin', uid });
|
||
|
|
||
|
const isInvited = await Groups.isInvited(uid, 'PrivateCanJoin');
|
||
|
assert(!isInvited);
|
||
8 years ago
|
});
|
||
|
|
||
2 years ago
|
it('should error if user is not invited', async () => {
|
||
2 years ago
|
await assert.rejects(
|
||
|
apiGroups.acceptInvite({ uid: adminUid }, { slug: 'privatecanjoin', uid: adminUid }),
|
||
|
{ message: '[[error:not-invited]]' }
|
||
|
);
|
||
8 years ago
|
});
|
||
|
|
||
2 years ago
|
it('should accept invite', async () => {
|
||
|
const uid = await User.create({ username: 'invite4' });
|
||
|
await apiGroups.issueInvite({ uid: adminUid }, { slug: 'privatecanjoin', uid });
|
||
|
await apiGroups.acceptInvite({ uid }, { slug: 'privatecanjoin', uid });
|
||
|
const isMember = await Groups.isMember(uid, 'PrivateCanJoin');
|
||
|
assert(isMember);
|
||
8 years ago
|
});
|
||
|
|
||
2 years ago
|
it('should reject invite', async () => {
|
||
|
const uid = await User.create({ username: 'invite5' });
|
||
|
await apiGroups.issueInvite({ uid: adminUid }, { slug: 'privatecanjoin', uid });
|
||
|
await apiGroups.rejectInvite({ uid }, { slug: 'privatecanjoin', uid });
|
||
|
const isInvited = await Groups.isInvited(uid, 'PrivateCanJoin');
|
||
|
assert(!isInvited);
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should grant ownership to user', async () => {
|
||
|
await apiGroups.grant({ uid: adminUid }, { slug: 'privatecanjoin', uid: testUid });
|
||
|
const isOwner = await Groups.ownership.isOwner(testUid, 'PrivateCanJoin');
|
||
|
assert(isOwner);
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should rescind ownership from user', async () => {
|
||
|
await apiGroups.rescind({ uid: adminUid }, { slug: 'privatecanjoin', uid: testUid });
|
||
|
const isOwner = await Groups.ownership.isOwner(testUid, 'PrivateCanJoin');
|
||
|
assert(!isOwner);
|
||
8 years ago
|
});
|
||
|
|
||
2 years ago
|
it('should fail to kick user with invalid data', async () => {
|
||
2 years ago
|
await assert.rejects(
|
||
|
apiGroups.leave({ uid: adminUid }, { slug: 'privatecanjoin', uid: 8721632 }),
|
||
|
{ message: '[[error:group-not-member]]' }
|
||
|
);
|
||
8 years ago
|
});
|
||
|
|
||
2 years ago
|
it('should kick user from group', async () => {
|
||
|
await apiGroups.leave({ uid: adminUid }, { slug: 'privatecanjoin', uid: testUid });
|
||
|
const isMember = await Groups.isMember(testUid, 'PrivateCanJoin');
|
||
|
assert(!isMember);
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should fail to create group with invalid data', async () => {
|
||
2 years ago
|
await assert.rejects(
|
||
|
apiGroups.create({ uid: 0 }, {}),
|
||
|
{ message: '[[error:no-privileges]]' }
|
||
|
);
|
||
8 years ago
|
});
|
||
8 years ago
|
|
||
3 years ago
|
it('should fail to create group if group creation is disabled', async () => {
|
||
2 years ago
|
await assert.rejects(
|
||
|
apiGroups.create({ uid: testUid }, { name: 'avalidname' }),
|
||
|
{ message: '[[error:no-privileges]]' }
|
||
|
);
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should fail to create group if name is privilege group', async () => {
|
||
|
try {
|
||
|
await apiGroups.create({ uid: 1 }, { name: 'cid:1:privileges:groups:find' });
|
||
|
assert(false);
|
||
|
} catch (err) {
|
||
8 years ago
|
assert.equal(err.message, '[[error:invalid-group-name]]');
|
||
3 years ago
|
}
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should create/update group', async () => {
|
||
|
const groupData = await apiGroups.create({ uid: adminUid }, { name: 'createupdategroup' });
|
||
|
assert(groupData);
|
||
|
const data = {
|
||
|
slug: 'createupdategroup',
|
||
|
name: 'renamedupdategroup',
|
||
|
description: 'cat group',
|
||
|
userTitle: 'cats',
|
||
|
userTitleEnabled: 1,
|
||
|
disableJoinRequests: 1,
|
||
|
hidden: 1,
|
||
|
private: 0,
|
||
|
};
|
||
|
await apiGroups.update({ uid: adminUid }, data);
|
||
|
const updatedData = await Groups.get('renamedupdategroup', {});
|
||
|
assert.equal(updatedData.name, 'renamedupdategroup');
|
||
|
assert.equal(updatedData.userTitle, 'cats');
|
||
|
assert.equal(updatedData.description, 'cat group');
|
||
|
assert.equal(updatedData.hidden, true);
|
||
|
assert.equal(updatedData.disableJoinRequests, true);
|
||
|
assert.equal(updatedData.private, false);
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should fail to create a group with name guests', async () => {
|
||
|
try {
|
||
|
await apiGroups.create({ uid: adminUid }, { name: 'guests' });
|
||
|
assert(false);
|
||
|
} catch (err) {
|
||
7 years ago
|
assert.equal(err.message, '[[error:invalid-group-name]]');
|
||
3 years ago
|
}
|
||
7 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should fail to rename guests group', async () => {
|
||
4 years ago
|
const data = {
|
||
3 years ago
|
slug: 'guests',
|
||
|
name: 'guests2',
|
||
7 years ago
|
};
|
||
|
|
||
3 years ago
|
try {
|
||
|
await apiGroups.update({ uid: adminUid }, data);
|
||
|
assert(false);
|
||
|
} catch (err) {
|
||
|
assert.equal(err.message, '[[error:invalid-group-name]]');
|
||
|
}
|
||
8 years ago
|
});
|
||
8 years ago
|
|
||
3 years ago
|
it('should delete group', async () => {
|
||
|
await apiGroups.delete({ uid: adminUid }, { slug: 'renamedupdategroup' });
|
||
|
const exists = await Groups.exists('renamedupdategroup');
|
||
|
assert(!exists);
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should fail to delete group if name is special', async () => {
|
||
|
const specialGroups = [
|
||
|
'administrators', 'registered-users', 'verified-users',
|
||
|
'unverified-users', 'global-moderators',
|
||
|
];
|
||
|
for (const slug of specialGroups) {
|
||
|
try {
|
||
|
// eslint-disable-next-line no-await-in-loop
|
||
|
await apiGroups.delete({ uid: adminUid }, { slug: slug });
|
||
|
assert(false);
|
||
|
} catch (err) {
|
||
|
assert.equal(err.message, '[[error:not-allowed]]');
|
||
|
}
|
||
|
}
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should fail to delete group if name is special', async () => {
|
||
|
try {
|
||
|
await apiGroups.delete({ uid: adminUid }, { slug: 'guests' });
|
||
|
assert(false);
|
||
|
} catch (err) {
|
||
4 years ago
|
assert.equal(err.message, '[[error:invalid-group-name]]');
|
||
3 years ago
|
}
|
||
7 years ago
|
});
|
||
|
|
||
4 years ago
|
it('should fail to load more groups with invalid data', (done) => {
|
||
|
socketGroups.loadMore({ uid: adminUid }, {}, (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:invalid-data]]');
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should load more groups', (done) => {
|
||
|
socketGroups.loadMore({ uid: adminUid }, { after: 0, sort: 'count' }, (err, data) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
|
assert(Array.isArray(data.groups));
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should fail to load more members with invalid data', (done) => {
|
||
|
socketGroups.loadMoreMembers({ uid: adminUid }, {}, (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:invalid-data]]');
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should load more members', (done) => {
|
||
|
socketGroups.loadMoreMembers({ uid: adminUid }, { after: 0, groupName: 'PrivateCanJoin' }, (err, data) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
|
assert(Array.isArray(data.users));
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
describe('api methods', () => {
|
||
3 years ago
|
const apiGroups = require('../src/api/groups');
|
||
|
it('should fail to create group with invalid data', async () => {
|
||
|
let err;
|
||
|
try {
|
||
|
await apiGroups.create({ uid: adminUid }, null);
|
||
|
} catch (_err) {
|
||
|
err = _err;
|
||
|
}
|
||
|
assert.strictEqual(err.message, '[[error:invalid-data]]');
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should fail to create group if group name is privilege group', async () => {
|
||
|
let err;
|
||
|
try {
|
||
|
await apiGroups.create({ uid: adminUid }, { name: 'cid:1:privileges:read' });
|
||
|
} catch (_err) {
|
||
|
err = _err;
|
||
|
}
|
||
|
assert.strictEqual(err.message, '[[error:invalid-group-name]]');
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should create a group', async () => {
|
||
|
const groupData = await apiGroups.create({ uid: adminUid }, { name: 'newgroup', description: 'group created by admin' });
|
||
|
assert.equal(groupData.name, 'newgroup');
|
||
|
assert.equal(groupData.description, 'group created by admin');
|
||
|
assert.equal(groupData.private, 1);
|
||
|
assert.equal(groupData.hidden, 0);
|
||
|
assert.equal(groupData.memberCount, 1);
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should fail to join with invalid data', async () => {
|
||
|
let err;
|
||
|
try {
|
||
|
await apiGroups.join({ uid: adminUid }, null);
|
||
|
} catch (_err) {
|
||
|
err = _err;
|
||
|
}
|
||
|
assert.strictEqual(err.message, '[[error:invalid-data]]');
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should add user to group', async () => {
|
||
|
await apiGroups.join({ uid: adminUid }, { uid: testUid, slug: 'newgroup' });
|
||
|
const isMember = await Groups.isMember(testUid, 'newgroup');
|
||
|
assert(isMember);
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should not error if user is already member', async () => {
|
||
|
await apiGroups.join({ uid: adminUid }, { uid: testUid, slug: 'newgroup' });
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('it should fail with invalid data', async () => {
|
||
|
let err;
|
||
|
try {
|
||
|
await apiGroups.leave({ uid: adminUid }, null);
|
||
|
} catch (_err) {
|
||
|
err = _err;
|
||
|
}
|
||
|
assert.strictEqual(err.message, '[[error:invalid-data]]');
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('it should fail if admin tries to remove self', async () => {
|
||
|
let err;
|
||
|
try {
|
||
|
await apiGroups.leave({ uid: adminUid }, { uid: adminUid, slug: 'administrators' });
|
||
|
} catch (_err) {
|
||
|
err = _err;
|
||
|
}
|
||
|
assert.strictEqual(err.message, '[[error:cant-remove-self-as-admin]]');
|
||
8 years ago
|
});
|
||
|
|
||
2 years ago
|
it('should error if user is not member', async () => {
|
||
2 years ago
|
await assert.rejects(
|
||
|
apiGroups.leave({ uid: adminUid }, { uid: 3, slug: 'newgroup' }),
|
||
|
{ message: '[[error:group-not-member]]' }
|
||
|
);
|
||
4 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should fail if trying to remove someone else from group', async () => {
|
||
2 years ago
|
await assert.rejects(
|
||
|
apiGroups.leave({ uid: testUid }, { uid: adminUid, slug: 'newgroup' }),
|
||
|
{ message: '[[error:no-privileges]]' },
|
||
|
);
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should remove user from group', async () => {
|
||
|
await apiGroups.leave({ uid: adminUid }, { uid: testUid, slug: 'newgroup' });
|
||
|
const isMember = await Groups.isMember(testUid, 'newgroup');
|
||
|
assert(!isMember);
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should fail with invalid data', async () => {
|
||
|
let err;
|
||
|
try {
|
||
|
await apiGroups.update({ uid: adminUid }, null);
|
||
|
} catch (_err) {
|
||
|
err = _err;
|
||
|
}
|
||
|
assert.strictEqual(err.message, '[[error:invalid-data]]');
|
||
8 years ago
|
});
|
||
|
|
||
3 years ago
|
it('should update group', async () => {
|
||
4 years ago
|
const data = {
|
||
3 years ago
|
slug: 'newgroup',
|
||
|
name: 'renamedgroup',
|
||
|
description: 'cat group',
|
||
|
userTitle: 'cats',
|
||
|
userTitleEnabled: 1,
|
||
|
disableJoinRequests: 1,
|
||
|
hidden: 1,
|
||
|
private: 0,
|
||
8 years ago
|
};
|
||
3 years ago
|
await apiGroups.update({ uid: adminUid }, data);
|
||
|
const groupData = await Groups.get('renamedgroup', {});
|
||
|
assert.equal(groupData.name, 'renamedgroup');
|
||
|
assert.equal(groupData.userTitle, 'cats');
|
||
|
assert.equal(groupData.description, 'cat group');
|
||
|
assert.equal(groupData.hidden, true);
|
||
|
assert.equal(groupData.disableJoinRequests, true);
|
||
|
assert.equal(groupData.private, false);
|
||
8 years ago
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
describe('groups cover', () => {
|
||
4 years ago
|
const socketGroups = require('../src/socket.io/groups');
|
||
|
let regularUid;
|
||
|
const logoPath = path.join(__dirname, '../test/files/test.png');
|
||
|
const imagePath = path.join(__dirname, '../test/files/groupcover.png');
|
||
4 years ago
|
before((done) => {
|
||
|
User.create({ username: 'regularuser', password: '123456' }, (err, uid) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
|
regularUid = uid;
|
||
|
async.series([
|
||
|
function (next) {
|
||
|
Groups.join('Test', adminUid, next);
|
||
|
},
|
||
|
function (next) {
|
||
|
Groups.join('Test', regularUid, next);
|
||
|
},
|
||
|
function (next) {
|
||
|
helpers.copyFile(logoPath, imagePath, next);
|
||
8 years ago
|
},
|
||
8 years ago
|
], done);
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should fail if user is not logged in or not owner', (done) => {
|
||
|
socketGroups.cover.update({ uid: 0 }, { imageData: 'asd' }, (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:no-privileges]]');
|
||
4 years ago
|
socketGroups.cover.update({ uid: regularUid }, { groupName: 'Test', imageData: 'asd' }, (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:no-privileges]]');
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should upload group cover image from file', (done) => {
|
||
4 years ago
|
const data = {
|
||
8 years ago
|
groupName: 'Test',
|
||
5 years ago
|
file: {
|
||
|
path: imagePath,
|
||
|
type: 'image/png',
|
||
|
},
|
||
8 years ago
|
};
|
||
4 years ago
|
Groups.updateCover({ uid: adminUid }, data, (err, data) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
4 years ago
|
Groups.getGroupFields('Test', ['cover:url'], (err, groupData) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
6 years ago
|
assert.equal(nconf.get('relative_path') + data.url, groupData['cover:url']);
|
||
|
if (nconf.get('relative_path')) {
|
||
|
assert(!data.url.startsWith(nconf.get('relative_path')));
|
||
|
assert(groupData['cover:url'].startsWith(nconf.get('relative_path')), groupData['cover:url']);
|
||
|
}
|
||
8 years ago
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
|
|
||
4 years ago
|
it('should upload group cover image from data', (done) => {
|
||
4 years ago
|
const data = {
|
||
8 years ago
|
groupName: 'Test',
|
||
8 years ago
|
imageData: '
|
||
8 years ago
|
};
|
||
4 years ago
|
socketGroups.cover.update({ uid: adminUid }, data, (err, data) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
4 years ago
|
Groups.getGroupFields('Test', ['cover:url'], (err, groupData) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
6 years ago
|
assert.equal(nconf.get('relative_path') + data.url, groupData['cover:url']);
|
||
8 years ago
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should fail to upload group cover with invalid image', (done) => {
|
||
4 years ago
|
const data = {
|
||
5 years ago
|
groupName: 'Test',
|
||
|
file: {
|
||
|
path: imagePath,
|
||
|
type: 'image/png',
|
||
|
},
|
||
|
};
|
||
4 years ago
|
socketGroups.cover.update({ uid: adminUid }, data, (err) => {
|
||
5 years ago
|
assert.equal(err.message, '[[error:invalid-data]]');
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should fail to upload group cover with invalid image', (done) => {
|
||
4 years ago
|
const data = {
|
||
5 years ago
|
groupName: 'Test',
|
||
|
imageData: '',
|
||
|
};
|
||
4 years ago
|
socketGroups.cover.update({ uid: adminUid }, data, (err, data) => {
|
||
5 years ago
|
assert.equal(err.message, '[[error:invalid-image]]');
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should update group cover position', (done) => {
|
||
4 years ago
|
const data = {
|
||
8 years ago
|
groupName: 'Test',
|
||
8 years ago
|
position: '50% 50%',
|
||
8 years ago
|
};
|
||
4 years ago
|
socketGroups.cover.update({ uid: adminUid }, data, (err) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
4 years ago
|
Groups.getGroupFields('Test', ['cover:position'], (err, groupData) => {
|
||
8 years ago
|
assert.ifError(err);
|
||
|
assert.equal('50% 50%', groupData['cover:position']);
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should fail to update cover position if group name is missing', (done) => {
|
||
|
Groups.updateCoverPosition('', '50% 50%', (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:invalid-data]]');
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should fail to remove cover if not logged in', (done) => {
|
||
|
socketGroups.cover.remove({ uid: 0 }, { groupName: 'Test' }, (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:no-privileges]]');
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should fail to remove cover if not owner', (done) => {
|
||
|
socketGroups.cover.remove({ uid: regularUid }, { groupName: 'Test' }, (err) => {
|
||
8 years ago
|
assert.equal(err.message, '[[error:no-privileges]]');
|
||
|
done();
|
||
|
});
|
||
|
});
|
||
|
|
||
4 years ago
|
it('should remove cover', async () => {
|
||
|
const fields = ['cover:url', 'cover:thumb:url'];
|
||
|
const values = await Groups.getGroupFields('Test', fields);
|
||
|
await socketGroups.cover.remove({ uid: adminUid }, { groupName: 'Test' });
|
||
|
|
||
|
fields.forEach((field) => {
|
||
|
const filename = values[field].split('/').pop();
|
||
|
const filePath = path.join(nconf.get('upload_path'), 'files', filename);
|
||
|
assert.strictEqual(fs.existsSync(filePath), false);
|
||
8 years ago
|
});
|
||
4 years ago
|
|
||
|
const groupData = await db.getObjectFields('group:Test', ['cover:url']);
|
||
|
assert(!groupData['cover:url']);
|
||
8 years ago
|
});
|
||
|
});
|
||
1 year ago
|
|
||
|
describe('isPrivilegeGroup', () => {
|
||
|
assert.strictEqual(Groups.isPrivilegeGroup('cid:1:privileges:topics:find'), true);
|
||
|
assert.strictEqual(Groups.isPrivilegeGroup('cid:1:privileges:groups:topics:find'), true);
|
||
|
assert.strictEqual(Groups.isPrivilegeGroup('cid:0:privileges:groups:search:users'), true);
|
||
|
assert.strictEqual(Groups.isPrivilegeGroup('cid:admin:privileges:admin:users'), true);
|
||
|
assert.strictEqual(Groups.isPrivilegeGroup('cid::privileges:admin:users'), false);
|
||
|
assert.strictEqual(Groups.isPrivilegeGroup('cid:string:privileges:admin:users'), false);
|
||
|
assert.strictEqual(Groups.isPrivilegeGroup('admin'), false);
|
||
|
assert.strictEqual(Groups.isPrivilegeGroup('registered-users'), false);
|
||
|
assert.strictEqual(Groups.isPrivilegeGroup(''), false);
|
||
|
assert.strictEqual(Groups.isPrivilegeGroup(null), false);
|
||
|
assert.strictEqual(Groups.isPrivilegeGroup(undefined), false);
|
||
|
assert.strictEqual(Groups.isPrivilegeGroup(false), false);
|
||
|
assert.strictEqual(Groups.isPrivilegeGroup(true), false);
|
||
|
});
|
||
11 years ago
|
});
|