123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428 |
- import assert from 'assert';
- import moment from 'moment'; // jshint ignore:line
- import React from 'react'; // jshint ignore:line
- import ListLoading from 'misago/components/users/rank/list-loading' // jshint ignore:line
- import List from 'misago/components/users/rank/list' // jshint ignore:line
- import Pager from 'misago/components/users/rank/pager' // jshint ignore:line
- import Root from 'misago/components/users/rank/root'; // jshint ignore:line
- import misago from 'misago/index';
- import reducer from 'misago/reducers/users';
- import ajax from 'misago/services/ajax';
- import polls from 'misago/services/polls';
- import snackbar from 'misago/services/snackbar';
- import store from 'misago/services/store';
- import * as testUtils from 'misago/utils/test-utils';
- let snackbarStore = null;
- describe("Rank Users List", function() {
- afterEach(function() {
- testUtils.unmountComponents();
- });
- it("renders users", function(done) {
- /* jshint ignore:start */
- let users = [
- testUtils.mockUser({
- id: 123,
- title: "Lorem ipsum",
- status: {is_online: true},
- joined_on: moment()
- }),
- testUtils.mockUser({
- id: 122,
- status: {is_online: true},
- joined_on: moment()
- })
- ];
- let state = {
- count: 2,
- page: 1,
- pages: 2,
- page_range: [1, 2],
- first: 1,
- previous: null,
- next: 2,
- last: 2,
- before: 0,
- more: 1
- };
- testUtils.render(
- <List baseUrl='/users/'
- users={users}
- {...state} />
- );
- /* jshint ignore:end */
- testUtils.onElement('#test-mount .users-cards-list.ui-ready', function() {
- assert.ok(true, "component renders");
- assert.ok($('#test-mount .pager-undercontent').length,
- "paginator is rendered");
- assert.equal($('#test-mount .user-card').length, 2,
- "two users are rendered");
- done();
- });
- });
- });
- describe("Rank Users List Pager", function() {
- afterEach(function() {
- testUtils.unmountComponents();
- });
- it("renders", function(done) {
- /* jshint ignore:start */
- let state = {
- baseUrl: '/users/rank-slug/',
- count: 10,
- page: 2,
- pages: 3,
- page_range: [1, 2, 3],
- first: 1,
- previous: null,
- next: 3,
- last: 3,
- before: 10,
- more: 10
- };
- testUtils.render(
- <Pager {...state} />
- );
- /* jshint ignore:end */
- testUtils.onElement('#test-mount .pager-undercontent', function() {
- assert.ok(true, "component renders");
- assert.ok($('#test-mount .pager .previous').length, "prev page renders");
- assert.ok($('#test-mount .pager .next').length, "next page renders");
- assert.equal($('#test-mount .pager-progress-bar li').length, 3,
- "progress bar renders");
- assert.equal($('#test-mount .pager-progress-bar .active').text().trim(),
- '2',
- "valid page is active in progress bar");
- done();
- });
- });
- it("renders without next page", function(done) {
- /* jshint ignore:start */
- let state = {
- baseUrl: '/users/rank-slug/',
- count: 10,
- page: 3,
- pages: 3,
- page_range: [1, 2, 3],
- first: 1,
- previous: null,
- next: null,
- last: null,
- before: 10,
- more: 0
- };
- testUtils.render(
- <Pager {...state} />
- );
- /* jshint ignore:end */
- testUtils.onElement('#test-mount .pager-undercontent', function() {
- assert.ok(true, "component renders");
- assert.ok($('#test-mount .pager .previous').length, "prev page renders");
- assert.ok(!$('#test-mount .pager .next').length, "next not rendering");
- assert.equal($('#test-mount .pager-progress-bar li').length, 3,
- "progress bar renders");
- assert.equal($('#test-mount .pager-progress-bar .active').text().trim(),
- '3',
- "valid page is active in progress bar");
- done();
- });
- });
- it("renders without prev page", function(done) {
- /* jshint ignore:start */
- let state = {
- baseUrl: '/users/rank-slug/',
- count: 10,
- page: 1,
- pages: 3,
- page_range: [1, 2, 3],
- first: null,
- previous: null,
- next: 2,
- last: 3,
- before: 0,
- more: 10
- };
- testUtils.render(
- <Pager {...state} />
- );
- /* jshint ignore:end */
- testUtils.onElement('#test-mount .pager-undercontent', function() {
- assert.ok(true, "component renders");
- assert.ok(!$('#test-mount .pager .previous').length,
- "prev page is not rendering");
- assert.ok($('#test-mount .pager .next').length, "next page renders");
- assert.equal($('#test-mount .pager-progress-bar li').length, 3,
- "progress bar renders");
- assert.equal($('#test-mount .pager-progress-bar .active').text().trim(),
- '1',
- "valid page is active in progress bar");
- done();
- });
- });
- });
- describe("Rank Users List Loading", function() {
- afterEach(function() {
- testUtils.unmountComponents();
- });
- it("renders", function(done) {
- /* jshint ignore:start */
- testUtils.render(<ListLoading />);
- /* jshint ignore:end */
- testUtils.onElement('#test-mount .users-cards-list', function() {
- assert.ok(true, "component renders");
- done();
- });
- });
- });
- describe("Rank Users List Root", function() {
- beforeEach(function() {
- snackbarStore = testUtils.snackbarStoreMock();
- snackbar.init(snackbarStore);
- polls.init(ajax, snackbar);
- testUtils.contextGuest(misago);
- misago._context = Object.assign(misago._context, {
- USERS_LIST_URL: '/users/',
- USERS_API: '/test-api/users/',
- USERS_LISTS: [
- {
- component: "rank",
- id: 424,
- name: "Forum team",
- slug: 'forum-team',
- css_class: 'forum-team',
- description: {
- plain: "This is forum team rank.",
- html: "<p class=\"test-description\">This is forum team rank.</p>"
- }
- }
- ]
- });
- store.constructor();
- store.addReducer('users', reducer, []);
- store.addReducer('auth', function(state, action) {
- if (action || true) {
- return {};
- }
- }, {});
- store.addReducer('tick', function(state, action) {
- if (action || true) {
- return {'tick': 123};
- }
- }, {});
- store.init();
- });
- afterEach(function() {
- testUtils.unmountComponents();
- testUtils.snackbarClear(snackbar);
- $.mockjax.clear();
- });
- it("renders preloaded", function(done) {
- let data = {
- results: [
- testUtils.mockUser({
- id: 123,
- title: "Lorem ipsum",
- status: {is_online: true}
- }),
- testUtils.mockUser({
- id: 122,
- status: {is_online: true}
- })
- ],
- count: 10,
- page: 1,
- pages: 1,
- page_range: [1],
- first: null,
- previous: null,
- next: null,
- last: null,
- before: 0,
- more: 0
- };
- $.mockjax({
- url: '/test-api/users/?rank=424&page=1',
- status: 200,
- responseText: data
- });
- misago._context.USERS = data;
- /* jshint ignore:start */
- let rank = {
- id: 424,
- name: "Forum team",
- slug: 'forum-team',
- css_class: 'forum-team',
- description: {
- plain: "This is forum team rank.",
- html: "<p class=\"test-description\">This is forum team rank.</p>"
- }
- };
- testUtils.render(
- <Root user={misago._context.user}
- users={[]}
- tick={123}
- route={{rank: rank}}
- params={{}} />
- );
- /* jshint ignore:end */
- testUtils.onElement('#test-mount .users-cards-list.ui-ready', function() {
- assert.ok(true, "component renders");
- assert.equal($('#test-mount p.test-description').text().trim(),
- "This is forum team rank.",
- "rank description was displayed");
- done();
- });
- });
- it("loads", function(done) {
- let data = {
- results: [
- testUtils.mockUser({
- id: 123,
- title: "Lorem ipsum",
- status: {is_online: true}
- }),
- testUtils.mockUser({
- id: 122,
- status: {is_online: true}
- })
- ],
- count: 10,
- page: 1,
- pages: 1,
- page_range: [1],
- first: null,
- previous: null,
- next: null,
- last: null,
- before: 0,
- more: 0
- };
- $.mockjax({
- url: '/test-api/users/?rank=424&page=1',
- status: 200,
- responseText: data
- });
- /* jshint ignore:start */
- let rank = {
- id: 424,
- name: "Forum team",
- slug: 'forum-team',
- css_class: 'forum-team',
- description: {
- plain: "This is forum team rank.",
- html: "<p class=\"test-description\">This is forum team rank.</p>"
- }
- };
- testUtils.render(
- <Root user={misago._context.user}
- users={[]}
- tick={123}
- route={{rank: rank}}
- params={{}} />
- );
- /* jshint ignore:end */
- testUtils.onElement('#test-mount .users-cards-list.ui-ready', function() {
- assert.ok(true, "component renders");
- assert.equal($('#test-mount p.test-description').text().trim(),
- "This is forum team rank.",
- "rank description was displayed");
- done();
- });
- });
- it("handles backend error", function(done) {
- $.mockjax({
- url: '/test-api/users/?rank=424&page=1',
- status: 500
- });
- /* jshint ignore:start */
- let rank = {
- id: 424,
- name: "Forum team",
- slug: 'forum-team',
- css_class: 'forum-team',
- description: {
- plain: "This is forum team rank.",
- html: "<p class=\"test-description\">This is forum team rank.</p>"
- }
- };
- testUtils.render(
- <Root user={misago._context.user}
- users={[]}
- tick={123}
- route={{rank: rank}}
- params={{}} />
- );
- /* jshint ignore:end */
- snackbarStore.callback(function(message) {
- assert.deepEqual(message, {
- message: "Unknown error has occured.",
- type: 'error'
- }, "error message was shown");
- done();
- });
- });
- });
|