// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-nocheck - TODO: add generic type to setupI18n to fix this
import { expect } from 'chai';
import { initI18n, testDictionary } from './util';
import { resetLocaleAndTranslationDict } from '../../../../../util/i18n/shared';
describe('getMessage', () => {
  let i18n;
  beforeEach(() => {
    i18n = initI18n(testDictionary);
  });
  afterEach(() => {
    resetLocaleAndTranslationDict();
  });
  it('returns the message for a token', () => {
    const message = i18n('greeting', { name: 'Alice' });
    expect(message).to.equal('Hello, Alice!');
  });
  it('returns the message for a plural token', () => {
    const message = i18n('search', { count: 1, found_count: 2 });
    expect(message).to.equal('2 of 1 match');
  });
  it('returns the message for a token with no args', () => {
    const message = i18n('noArgs');
    expect(message).to.equal('No args');
  });
  it('returns the message for a token with args', () => {
    const message = i18n('args', { name: 'Alice' });
    expect(message).to.equal('Hello, Alice!');
  });
  it('returns the message for a token with a tag', () => {
    const message = i18n('tag', { name: 'Alice' });
    expect(message).to.equal('Hello, Alice! Welcome!');
  });
  it('returns the message for a token with a tag and args', () => {
    const message = i18n('argInTag', { name: 'Alice', arg: 'Bob' });
    expect(message).to.equal('Hello, Alice! Welcome, Bob!');
  });
});