import assert from 'assert';
import moment from 'moment';
import React from 'react'; // jshint ignore:line
import UserCard from 'misago/components/users-list/user-card'; // jshint ignore:line
import * as testUtils from 'misago/utils/test-utils';
describe("Users List Item", function() {
afterEach(function() {
testUtils.unmountComponents();
});
it("renders with ui-preview", function(done) {
let user = testUtils.mockUser({
title: "Lorem ipsum",
joined_on: moment()
});
/* jshint ignore:start */
testUtils.render(
);
/* jshint ignore:end */
testUtils.onElement('#test-mount .user-card.ui-ready', function() {
assert.ok(true, "component renders");
assert.ok($('#test-mount .status-label.ui-preview').length,
"status preview is rendered");
assert.equal($('#test-mount .user-title').text(), user.title,
"user title is rendered");
done();
});
});
it("renders", function(done) {
let user = testUtils.mockUser({
title: "Lorem ipsum",
status: {
is_online: true
},
joined_on: moment()
});
/* jshint ignore:start */
testUtils.render(
);
/* jshint ignore:end */
testUtils.onElement('#test-mount .user-card.ui-ready', function() {
assert.ok(true, "component renders");
assert.equal($('#test-mount .status-label').text(), 'Online',
"status label is rendered");
assert.equal($('#test-mount .user-title').text(), user.title,
"user title is rendered");
done();
});
});
it("renders without status", function(done) {
let user = testUtils.mockUser({
title: "Lorem ipsum",
status: {is_online: true},
joined_on: moment()
});
/* jshint ignore:start */
testUtils.render(
);
/* jshint ignore:end */
testUtils.onElement('#test-mount .user-card.ui-ready', function() {
assert.ok(true, "component renders");
assert.ok(!$('#test-mount .user-status').length, "status is hidden");
assert.equal($('#test-mount .user-title').text(), user.title,
"user title is rendered");
done();
});
});
it("renders with rank", function(done) {
let user = testUtils.mockUser({
title: "Lorem ipsum",
status: {is_online: true},
joined_on: moment(),
rank: {
name: 'Some Yolo',
is_tab: false,
absolute_url: '/users/ranks/some-yolo/'
}
});
/* jshint ignore:start */
testUtils.render(
);
/* jshint ignore:end */
testUtils.onElement('#test-mount .user-card.ui-ready', function() {
assert.ok(true, "component renders");
assert.ok(!$('#test-mount .user-status').length, "status is hidden");
assert.equal($('#test-mount .user-title').text(), user.title,
"user title is rendered");
assert.equal($('#test-mount .rank-name').text(), user.rank.name,
"user rank is rendered");
done();
});
});
it("renders with rank url", function(done) {
let user = testUtils.mockUser({
title: "Lorem ipsum",
status: {is_online: true},
joined_on: moment(),
rank: {
name: 'Some Yolo',
is_tab: true,
absolute_url: '/users/ranks/some-yolo/'
}
});
/* jshint ignore:start */
testUtils.render(
);
/* jshint ignore:end */
testUtils.onElement('#test-mount .user-card.ui-ready', function() {
assert.ok(true, "component renders");
assert.ok(!$('#test-mount .user-status').length, "status is hidden");
assert.equal($('#test-mount .user-title').text(), user.title,
"user title is rendered");
assert.equal($('#test-mount .rank-name').text(), user.rank.name,
"user rank is rendered");
assert.equal($('#test-mount .rank-name').attr('href'),
user.rank.absolute_url,
"user rank is url to rank users list");
done();
});
});
});