2 * @jest-environment jsdom
5 import '@testing-library/jest-dom/extend-expect';
7 import { render } from '@testing-library/svelte';
10 import { addMessages } from 'svelte-i18n';
12 import ForumList from './forum_list.svelte';
18 describe('Forum List component', () => {
21 'test_forums.yes': 'Absolutely yes',
22 'test_forums.no': 'No, not at all',
23 'test_forums.maybe': 'OK, maybe...'
28 internals.results = render(ForumList, {
34 label: 'test_forums.yes',
40 label: 'test_forums.no',
46 label: 'test_forums.maybe',
54 test('It should display each forum according to their position', () => {
55 expect(internals.results.container).toHaveTextContent(/^◯.+⏀.+☆.+$/);
58 test('It should translate forum labels', () => {
59 expect(internals.results.getByText('Absolutely yes')).toBeVisible();
60 expect(internals.results.getByText('No, not at all')).toBeVisible();
61 expect(internals.results.getByText('OK, maybe...')).toBeVisible();
64 test('It should display forum glyphs', () => {
65 expect(internals.results.getByText('☆')).toBeVisible();
66 expect(internals.results.getByText('◯')).toBeVisible();
67 expect(internals.results.getByText('⏀')).toBeVisible();
70 test('Label should be a permalink to the forum', () => {
71 expect(internals.results.getByText('Absolutely yes').closest('a')).toHaveAttribute(
75 expect(internals.results.getByText('No, not at all').closest('a')).toHaveAttribute(
79 expect(internals.results.getByText('OK, maybe...').closest('a')).toHaveAttribute(
85 test('Glyph should be a permalink to the forum', () => {
86 expect(internals.results.getByText('☆').closest('a')).toHaveAttribute('href', '/f/yes');
87 expect(internals.results.getByText('◯').closest('a')).toHaveAttribute('href', '/f/no');
88 expect(internals.results.getByText('⏀').closest('a')).toHaveAttribute('href', '/f/maybe');