123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361 |
- import assert from 'assert';
- import moment from 'moment'; // jshint ignore:line
- import React from 'react'; // jshint ignore:line
- import UserStatus, { StatusIcon, StatusLabel } from 'misago/components/user-status'; // jshint ignore:line
- import * as testUtils from 'misago/utils/test-utils';
- let status = {
- is_hidden: false,
- is_online_hidden: false,
- is_offline_hidden: false,
- is_online: false,
- is_offline: false,
- last_click: moment().subtract(7, 'days'),
- is_banned: false,
- banned_until: moment().add(7, 'days')
- };
- /* jshint ignore:start */
- let user = {
- username: 'Boberson'
- };
- /* jshint ignore:end */
- describe("User Status", function() {
- afterEach(function() {
- testUtils.unmountComponents();
- });
- it('renders for offline user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_offline: true
- });
- testUtils.render(
- <UserStatus status={testStatus}>
- Some stuff
- </UserStatus>
- );
- /* jshint ignore:end */
- let element = $('#test-mount .user-status');
- assert.ok(element.hasClass('user-offline'),
- "component renders with valid class");
- assert.equal(element.text().trim(), "Some stuff",
- "component renders its children");
- });
- it('renders for offline (hidden) user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_offline_hidden: true
- });
- testUtils.render(
- <UserStatus status={testStatus}>
- Some stuff
- </UserStatus>
- );
- /* jshint ignore:end */
- let element = $('#test-mount .user-status');
- assert.ok(element.hasClass('user-offline'),
- "component renders with valid class");
- assert.equal(element.text().trim(), "Some stuff",
- "component renders its children");
- });
- it('renders for online user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_online: true
- });
- testUtils.render(
- <UserStatus status={testStatus}>
- Some stuff
- </UserStatus>
- );
- /* jshint ignore:end */
- let element = $('#test-mount .user-status');
- assert.ok(element.hasClass('user-online'),
- "component renders with valid class");
- assert.equal(element.text().trim(), "Some stuff",
- "component renders its children");
- });
- it('renders for online (hidden) user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_online_hidden: true
- });
- testUtils.render(
- <UserStatus status={testStatus}>
- Some stuff
- </UserStatus>
- );
- /* jshint ignore:end */
- let element = $('#test-mount .user-status');
- assert.ok(element.hasClass('user-online'),
- "component renders with valid class");
- assert.equal(element.text().trim(), "Some stuff",
- "component renders its children");
- });
- it('renders for hidden user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_hidden: true
- });
- testUtils.render(
- <UserStatus status={testStatus}>
- Some stuff
- </UserStatus>
- );
- /* jshint ignore:end */
- let element = $('#test-mount .user-status');
- assert.ok(element.hasClass('user-offline'),
- "component renders with valid class");
- assert.equal(element.text().trim(), "Some stuff",
- "component renders its children");
- });
- it('renders for banned user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_banned: true
- });
- testUtils.render(
- <UserStatus status={testStatus}>
- Some stuff
- </UserStatus>
- );
- /* jshint ignore:end */
- let element = $('#test-mount .user-status');
- assert.ok(element.hasClass('user-banned'),
- "component renders with valid class");
- assert.equal(element.text().trim(), "Some stuff",
- "component renders its children");
- });
- });
- describe("User Status Icon", function() {
- afterEach(function() {
- testUtils.unmountComponents();
- });
- it('renders for offline user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_offline: true
- });
- testUtils.render(<StatusIcon status={testStatus} />);
- /* jshint ignore:end */
- let element = $('#test-mount .status-icon');
- assert.equal(element.text().trim(), 'panorama_fish_eye',
- "component renders with valid icon");
- });
- it('renders for offline (hidden) user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_offline_hidden: true
- });
- testUtils.render(<StatusIcon status={testStatus} />);
- /* jshint ignore:end */
- let element = $('#test-mount .status-icon');
- assert.equal(element.text().trim(), 'label_outline',
- "component renders with valid icon");
- });
- it('renders for online user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_online: true
- });
- testUtils.render(<StatusIcon status={testStatus} />);
- /* jshint ignore:end */
- let element = $('#test-mount .status-icon');
- assert.equal(element.text().trim(), 'lens',
- "component renders with valid icon");
- });
- it('renders for online (hidden) user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_online_hidden: true
- });
- testUtils.render(<StatusIcon status={testStatus} />);
- /* jshint ignore:end */
- let element = $('#test-mount .status-icon');
- assert.equal(element.text().trim(), 'label',
- "component renders with valid icon");
- });
- it('renders for hidden user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_hidden: true
- });
- testUtils.render(<StatusIcon status={testStatus} />);
- /* jshint ignore:end */
- let element = $('#test-mount .status-icon');
- assert.equal(element.text().trim(), 'help_outline',
- "component renders with valid icon");
- });
- it('renders for banned user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_banned: true
- });
- testUtils.render(<StatusIcon status={testStatus} />);
- /* jshint ignore:end */
- let element = $('#test-mount .status-icon');
- assert.equal(element.text().trim(), 'remove_circle_outline',
- "component renders with valid icon");
- });
- });
- describe("User Status Label", function() {
- afterEach(function() {
- testUtils.unmountComponents();
- });
- it('renders for offline user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_offline: true
- });
- testUtils.render(<StatusLabel user={user} status={testStatus} />);
- /* jshint ignore:end */
- let element = $('#test-mount .status-label');
- assert.equal(element.text().trim(), gettext("Offline"),
- "component renders with valid label");
- assert.equal(element.attr('title'),
- "Boberson was last seen " + status.last_click.fromNow(),
- "component renders with valid help");
- });
- it('renders for offline (hidden) user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_offline_hidden: true
- });
- testUtils.render(<StatusLabel user={user} status={testStatus} />);
- /* jshint ignore:end */
- let element = $('#test-mount .status-label');
- assert.equal(element.text().trim(), gettext("Offline (hidden)"),
- "component renders with valid label");
- assert.equal(element.attr('title'),
- "Boberson was last seen " + status.last_click.fromNow() + " (hidden)",
- "component renders with valid status.help");
- });
- it('renders for online user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_online: true
- });
- testUtils.render(<StatusLabel user={user} status={testStatus} />);
- /* jshint ignore:end */
- let element = $('#test-mount .status-label');
- assert.equal(element.text().trim(), gettext("Online"),
- "component renders with valid label");
- assert.equal(element.attr('title'), "Boberson is online",
- "component renders with valid help");
- });
- it('renders for online (hidden) user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_online_hidden: true
- });
- testUtils.render(<StatusLabel user={user} status={testStatus} />);
- /* jshint ignore:end */
- let element = $('#test-mount .status-label');
- assert.equal(element.text().trim(), gettext("Online (hidden)"),
- "component renders with valid label");
- assert.equal(element.attr('title'), "Boberson is online (hidden)",
- "component renders with valid help");
- });
- it('renders for hidden user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_hidden: true
- });
- testUtils.render(<StatusLabel user={user} status={testStatus} />);
- /* jshint ignore:end */
- let element = $('#test-mount .status-label');
- assert.equal(element.text().trim(), gettext("Hidden"),
- "component renders with valid label");
- assert.equal(element.attr('title'), "Boberson is hiding presence",
- "component renders with valid help");
- });
- it('renders for banned user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_banned: true
- });
- testUtils.render(<StatusLabel user={user} status={testStatus} />);
- /* jshint ignore:end */
- let element = $('#test-mount .status-label');
- assert.equal(element.text().trim(), gettext("Banned"),
- "component renders with valid label");
- assert.equal(element.attr('title'),
- "Boberson is banned until " + status.banned_until.format('LL, LT'),
- "component renders with valid help");
- });
- it('renders for permabanned user', function() {
- /* jshint ignore:start */
- let testStatus = Object.assign({}, status, {
- is_banned: true,
- banned_until: null
- });
- testUtils.render(<StatusLabel user={user} status={testStatus} />);
- /* jshint ignore:end */
- let element = $('#test-mount .status-label');
- assert.equal(element.text().trim(), gettext("Banned"),
- "component renders with valid label");
- assert.equal(element.attr('title'), "Boberson is banned",
- "component renders with valid help");
- });
- });
|