// import { Map as ImmutableMap } from 'immutable'; import React from 'react'; import { render, screen } from '../../../../jest/test-helpers'; import { normalizeAccount, normalizeRelationship } from '../../../../normalizers'; import SubscribeButton from '../subscription-button'; import type { ReducerAccount } from 'soapbox/reducers/accounts'; const justin = { id: '1', acct: 'justin-username', display_name: 'Justin L', avatar: 'test.jpg', }; describe('<SubscribeButton />', () => { let store: any; describe('with "accountNotifies" disabled', () => { it('renders nothing', () => { const account = normalizeAccount({ ...justin, relationship: normalizeRelationship({ following: true }) }) as ReducerAccount; render(<SubscribeButton account={account} />, undefined, store); expect(screen.queryAllByTestId('icon-button')).toHaveLength(0); }); }); // describe('with "accountNotifies" enabled', () => { // beforeEach(() => { // store = { // ...store, // instance: normalizeInstance({ // version: '3.4.1 (compatible; TruthSocial 1.0.0)', // software: 'TRUTHSOCIAL', // pleroma: ImmutableMap({}), // }), // }; // }); // describe('when the relationship is requested', () => { // beforeEach(() => { // account = normalizeAccount({ ...account, relationship: normalizeRelationship({ requested: true }) }); // store = { // ...store, // accounts: ImmutableMap({ // '1': account, // }), // }; // }); // it('renders the button', () => { // render(<SubscribeButton account={account} />, null, store); // expect(screen.getByTestId('icon-button')).toBeInTheDocument(); // }); // describe('when the user "isSubscribed"', () => { // beforeEach(() => { // account = normalizeAccount({ // ...account, // relationship: normalizeRelationship({ requested: true, notifying: true }), // }); // store = { // ...store, // accounts: ImmutableMap({ // '1': account, // }), // }; // }); // it('renders the unsubscribe button', () => { // render(<SubscribeButton account={account} />, null, store); // expect(screen.getByTestId('icon-button').title).toEqual(`Unsubscribe to notifications from @${account.acct}`); // }); // }); // describe('when the user is not "isSubscribed"', () => { // beforeEach(() => { // account = normalizeAccount({ // ...account, // relationship: normalizeRelationship({ requested: true, notifying: false }), // }); // store = { // ...store, // accounts: ImmutableMap({ // '1': account, // }), // }; // }); // it('renders the unsubscribe button', () => { // render(<SubscribeButton account={account} />, null, store); // expect(screen.getByTestId('icon-button').title).toEqual(`Subscribe to notifications from @${account.acct}`); // }); // }); // }); // describe('when the user is not following the account', () => { // beforeEach(() => { // account = normalizeAccount({ ...account, relationship: normalizeRelationship({ following: false }) }); // store = { // ...store, // accounts: ImmutableMap({ // '1': account, // }), // }; // }); // it('renders nothing', () => { // render(<SubscribeButton account={account} />, null, store); // expect(screen.queryAllByTestId('icon-button')).toHaveLength(0); // }); // }); // describe('when the user is following the account', () => { // beforeEach(() => { // account = normalizeAccount({ ...account, relationship: normalizeRelationship({ following: true }) }); // store = { // ...store, // accounts: ImmutableMap({ // '1': account, // }), // }; // }); // it('renders the button', () => { // render(<SubscribeButton account={account} />, null, store); // expect(screen.getByTestId('icon-button')).toBeInTheDocument(); // }); // describe('when the user "isSubscribed"', () => { // beforeEach(() => { // account = normalizeAccount({ // ...account, // relationship: normalizeRelationship({ requested: true, notifying: true }), // }); // store = { // ...store, // accounts: ImmutableMap({ // '1': account, // }), // }; // }); // it('renders the unsubscribe button', () => { // render(<SubscribeButton account={account} />, null, store); // expect(screen.getByTestId('icon-button').title).toEqual(`Unsubscribe to notifications from @${account.acct}`); // }); // }); // describe('when the user is not "isSubscribed"', () => { // beforeEach(() => { // account = normalizeAccount({ // ...account, // relationship: normalizeRelationship({ requested: true, notifying: false }), // }); // store = { // ...store, // accounts: ImmutableMap({ // '1': account, // }), // }; // }); // it('renders the unsubscribe button', () => { // render(<SubscribeButton account={account} />, null, store); // expect(screen.getByTestId('icon-button').title).toEqual(`Subscribe to notifications from @${account.acct}`); // }); // }); // }); // }); });