import { Map as ImmutableMap, fromJS } from 'immutable';
import React from 'react';

import { render, screen } from '../../../../jest/test-helpers';
import TrendsPanel from '../trends-panel';

describe('<TrendsPanel />', () => {
  it('renders trending hashtags', () => {
    const store = {
      trends: ImmutableMap({
        items: fromJS([{
          name: 'hashtag 1',
          history: [{ accounts: [] }],
        }]),
      }),
    };

    render(<TrendsPanel limit={1} />, null, store);
    expect(screen.getByTestId('hashtag')).toHaveTextContent(/hashtag 1/i);
  });

  it('renders multiple trends', () => {
    const store = {
      trends: ImmutableMap({
        items: fromJS([
          {
            name: 'hashtag 1',
            history: [{ accounts: [] }],
          },
          {
            name: 'hashtag 2',
            history: [{ accounts: [] }],
          },
        ]),
      }),
    };

    render(<TrendsPanel limit={3} />, null, store);
    expect(screen.queryAllByTestId('hashtag')).toHaveLength(2);
  });

  it('respects the limit prop', () => {
    const store = {
      trends: ImmutableMap({
        items: fromJS([
          {
            name: 'hashtag 1',
            history: [{ accounts: [] }],
          },
          {
            name: 'hashtag 2',
            history: [{ accounts: [] }],
          },
        ]),
      }),
    };

    render(<TrendsPanel limit={1} />, null, store);
    expect(screen.queryAllByTestId('hashtag')).toHaveLength(1);
  });

  it('renders empty', () => {
    const store = {
      trends: ImmutableMap({
        items: fromJS([]),
      }),
    };

    render(<TrendsPanel limit={1} />, null, store);
    expect(screen.queryAllByTestId('hashtag')).toHaveLength(0);
  });
});