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.
nodebb/test/template-helpers.js

239 lines
9.7 KiB
JavaScript

'use strict';
var nconf = require('nconf');
var assert = require('assert');
var db = require('./mocks/databasemock');
var helpers = require('../public/src/modules/helpers');
describe('helpers', function () {
it('should return false if item doesn\'t exist', function (done) {
8 years ago
var flag = helpers.displayMenuItem({ navigation: [] }, 0);
assert(!flag);
done();
});
it('should return false if route is /users and user does not have view:users privilege', function (done) {
var flag = helpers.displayMenuItem({
8 years ago
navigation: [{ route: '/users' }],
user: {
privileges: {
'view:users': false,
},
8 years ago
},
}, 0);
assert(!flag);
done();
});
it('should return false if route is /tags and user does not have view:tags privilege', function (done) {
var flag = helpers.displayMenuItem({
8 years ago
navigation: [{ route: '/tags' }],
user: {
privileges: {
'view:tags': false,
},
},
}, 0);
assert(!flag);
done();
});
it('should return false if route is /groups and user does not have view:groups privilege', function (done) {
var flag = helpers.displayMenuItem({
navigation: [{ route: '/groups' }],
user: {
privileges: {
'view:groups': false,
},
8 years ago
},
}, 0);
assert(!flag);
done();
});
it('should stringify object', function (done) {
8 years ago
var str = helpers.stringify({ a: 'herp < derp > and & quote "' });
assert.equal(str, '{&quot;a&quot;:&quot;herp &lt; derp &gt; and &amp; quote \\&quot;&quot;}');
done();
});
it('should escape html', function (done) {
var str = helpers.escape('gdkfhgk < some > and &');
assert.equal(str, 'gdkfhgk &lt; some &gt; and &amp;');
done();
});
8 years ago
it('should return empty string if category is falsy', function (done) {
assert.equal(helpers.generateCategoryBackground(null), '');
done();
});
it('should generate category background', function (done) {
var category = {
bgColor: '#ff0000',
color: '#00ff00',
backgroundImage: '/assets/uploads/image.png',
imageClass: 'auto',
};
var bg = helpers.generateCategoryBackground(category);
assert.equal(bg, 'background-color: #ff0000; color: #00ff00; background-image: url(/assets/uploads/image.png); background-size: auto;');
done();
});
it('should return empty string if category has no children', function (done) {
var category = {
children: [],
};
var bg = helpers.generateChildrenCategories(category);
assert.equal(bg, '');
done();
});
it('should generate html for children', function (done) {
var category = {
children: [
{
link: '',
bgColor: '#ff0000',
color: '#00ff00',
name: 'children',
},
],
};
var html = helpers.generateChildrenCategories(category);
6 years ago
assert.equal(html, '<span class="category-children"><span class="category-children-item pull-left"><div role="presentation" class="icon pull-left" style="background-color: #ff0000; color: #00ff00;"><i class="fa fa-fw undefined"></i></div><a href="' + nconf.get('relative_path') + '/category/undefined"><small>children</small></a></span></span>');
8 years ago
done();
});
it('should generate topic class', function (done) {
var className = helpers.generateTopicClass({ locked: true, pinned: true, deleted: true, unread: true });
assert.equal(className, 'locked pinned deleted unread');
done();
});
it('should show leave button if isMember and group is not administrators', function (done) {
var btn = helpers.membershipBtn({ displayName: 'some group', name: 'some group', isMember: true });
assert.equal(btn, '<button class="btn btn-danger" data-action="leave" data-group="some group"><i class="fa fa-times"></i> [[groups:membership.leave-group]]</button>');
done();
});
it('should show pending button if isPending and group is not administrators', function (done) {
var btn = helpers.membershipBtn({ displayName: 'some group', name: 'some group', isPending: true });
assert.equal(btn, '<button class="btn btn-warning disabled"><i class="fa fa-clock-o"></i> [[groups:membership.invitation-pending]]</button>');
done();
});
it('should show reject invite button if isInvited', function (done) {
var btn = helpers.membershipBtn({ displayName: 'some group', name: 'some group', isInvited: true });
assert.equal(btn, '<button class="btn btn-link" data-action="rejectInvite" data-group="some group">[[groups:membership.reject]]</button><button class="btn btn-success" data-action="acceptInvite" data-group="some group"><i class="fa fa-plus"></i> [[groups:membership.accept-invitation]]</button>');
done();
});
it('should show join button if join requests are not disabled and group is not administrators', function (done) {
var btn = helpers.membershipBtn({ displayName: 'some group', name: 'some group', disableJoinRequests: false });
assert.equal(btn, '<button class="btn btn-success" data-action="join" data-group="some group"><i class="fa fa-plus"></i> [[groups:membership.join-group]]</button>');
done();
});
it('should show nothing if group is administrators ', function (done) {
var btn = helpers.membershipBtn({ displayName: 'administrators', name: 'administrators' });
assert.equal(btn, '');
done();
});
it('should spawn privilege states', function (done) {
var privs = {
find: true,
read: true,
};
var html = helpers.spawnPrivilegeStates('guests', privs);
feat: more discrete commit-on-save instead of commit-on-change w/ confirm modals (#8541) * feat: privileges save button, #8537, WIP * fix: disable firefox autocomplete on privilege form fields * feat: closes #8537 privilege changes commit on save - new language strings for confirmation and success modals/toasts - indeterminate privilege handling (/cc @psychobunny) - added new discard button - both discard and save buttons now have confirmation dialogs * fix(tests): remove duplicate template helper test * fix(tests): broken template helper test * feat: confirm dialogs for all privilege copy actions Also, ability to add user to a privilege table without needing to refresh the privilege table. * feat: group row addition w/o table refresh breaking: helpers.getUserPrivileges and helpers.getGroupPrivileges no longer make socket calls to the following hooks: - filter:privileges.list, filter:privileges.admin.list, filter:privileges.global.list, filter:privileges.groups.list, filter:privileges.admin.groups.list, filter:privileges.gloval.groups.list The filters are still called, but done before the helper method is called, and the results are passed in instead. This change should only affect you if you directly call the helper methods, otherwise the change is transparent. * fix: stale ajaxify data on privilege category switch * fix: implicit privileges not showing for user privs * fix: groups, not group, also fix tests * fix(tests): again * fix: wrong tpl rendered when adding group to global priv table
5 years ago
assert.equal(html, '<td class="text-center" data-privilege="find" data-value="true"><input autocomplete="off" type="checkbox" checked /></td><td class="text-center" data-privilege="read" data-value="true"><input autocomplete="off" type="checkbox" checked /></td>');
8 years ago
done();
});
it('should render thumb as topic image', function (done) {
var topicObj = { thumb: '/uploads/1.png', user: { username: 'baris' } };
var html = helpers.renderTopicImage(topicObj);
assert.equal(html, '<img src="' + topicObj.thumb + '" class="img-circle user-img" title="' + topicObj.user.username + '" />');
done();
});
it('should render user picture as topic image', function (done) {
var topicObj = { thumb: '', user: { uid: 1, username: 'baris', picture: '/uploads/2.png' } };
var html = helpers.renderTopicImage(topicObj);
assert.equal(html, '<img component="user/picture" data-uid="' + topicObj.user.uid + '" src="' + topicObj.user.picture + '" class="user-img" title="' + topicObj.user.username + '" />');
done();
});
it('should render digest avatar', function (done) {
var block = { teaser: { user: { username: 'baris', picture: '/uploads/1.png' } } };
var html = helpers.renderDigestAvatar(block);
assert.equal(html, '<img style="vertical-align: middle; width: 32px; height: 32px; border-radius: 50%;" src="' + block.teaser.user.picture + '" title="' + block.teaser.user.username + '" />');
8 years ago
done();
});
it('should render digest avatar', function (done) {
var block = { teaser: { user: { username: 'baris', 'icon:text': 'B', 'icon:bgColor': '#ff000' } } };
var html = helpers.renderDigestAvatar(block);
assert.equal(html, '<div style="vertical-align: middle; width: 32px; height: 32px; line-height: 32px; font-size: 16px; background-color: ' + block.teaser.user['icon:bgColor'] + '; color: white; text-align: center; display: inline-block; border-radius: 50%;">' + block.teaser.user['icon:text'] + '</div>');
8 years ago
done();
});
it('should render digest avatar', function (done) {
var block = { user: { username: 'baris', picture: '/uploads/1.png' } };
var html = helpers.renderDigestAvatar(block);
assert.equal(html, '<img style="vertical-align: middle; width: 32px; height: 32px; border-radius: 50%;" src="' + block.user.picture + '" title="' + block.user.username + '" />');
8 years ago
done();
});
it('should render digest avatar', function (done) {
var block = { user: { username: 'baris', 'icon:text': 'B', 'icon:bgColor': '#ff000' } };
var html = helpers.renderDigestAvatar(block);
assert.equal(html, '<div style="vertical-align: middle; width: 32px; height: 32px; line-height: 32px; font-size: 16px; background-color: ' + block.user['icon:bgColor'] + '; color: white; text-align: center; display: inline-block; border-radius: 50%;">' + block.user['icon:text'] + '</div>');
8 years ago
done();
});
it('shoud render user agent/browser icons', function (done) {
var html = helpers.userAgentIcons({ platform: 'Linux', browser: 'Chrome' });
assert.equal(html, '<i class="fa fa-fw fa-linux"></i><i class="fa fa-fw fa-chrome"></i>');
done();
});
it('shoud render user agent/browser icons', function (done) {
var html = helpers.userAgentIcons({ platform: 'Microsoft Windows', browser: 'Firefox' });
assert.equal(html, '<i class="fa fa-fw fa-windows"></i><i class="fa fa-fw fa-firefox"></i>');
done();
});
it('shoud render user agent/browser icons', function (done) {
var html = helpers.userAgentIcons({ platform: 'Apple Mac', browser: 'Safari' });
assert.equal(html, '<i class="fa fa-fw fa-apple"></i><i class="fa fa-fw fa-safari"></i>');
done();
});
it('shoud render user agent/browser icons', function (done) {
var html = helpers.userAgentIcons({ platform: 'Android', browser: 'IE' });
assert.equal(html, '<i class="fa fa-fw fa-android"></i><i class="fa fa-fw fa-internet-explorer"></i>');
done();
});
it('shoud render user agent/browser icons', function (done) {
var html = helpers.userAgentIcons({ platform: 'iPad', browser: 'Edge' });
assert.equal(html, '<i class="fa fa-fw fa-tablet"></i><i class="fa fa-fw fa-edge"></i>');
done();
});
it('shoud render user agent/browser icons', function (done) {
var html = helpers.userAgentIcons({ platform: 'iPhone', browser: 'unknow' });
assert.equal(html, '<i class="fa fa-fw fa-mobile"></i><i class="fa fa-fw fa-question-circle"></i>');
done();
});
it('shoud render user agent/browser icons', function (done) {
var html = helpers.userAgentIcons({ platform: 'unknow', browser: 'unknown' });
assert.equal(html, '<i class="fa fa-fw fa-question-circle"></i><i class="fa fa-fw fa-question-circle"></i>');
done();
});
});