/**
 * Copyright (c) HashiCorp, Inc.
 * SPDX-License-Identifier: BUSL-1.1
 */
import { module, test } from 'qunit';
import { setupRenderingTest } from 'vault/tests/helpers';
import { click, find, render } from '@ember/test-helpers';
import { hbs } from 'ember-cli-htmlbars';
import sinon from 'sinon';
module('Integration | Component | flash-toast', function (hooks) {
  setupRenderingTest(hooks);
  hooks.beforeEach(function () {
    this.flash = {
      type: 'info',
      message: 'The bare minimum flash message',
    };
    this.closeSpy = sinon.spy();
  });
  test('it renders', async function (assert) {
    await render(hbs``);
    assert.dom('[data-test-flash-message-body]').hasText('The bare minimum flash message');
    assert.dom('[data-test-flash-toast]').hasClass('hds-alert--color-highlight');
    await click('button');
    assert.ok(this.closeSpy.calledOnce, 'close action was called');
  });
  [
    { type: 'info', title: 'Info', color: 'hds-alert--color-highlight' },
    { type: 'success', title: 'Success', color: 'hds-alert--color-success' },
    { type: 'warning', title: 'Warning', color: 'hds-alert--color-warning' },
    { type: 'danger', title: 'Error', color: 'hds-alert--color-critical' },
    { type: 'foobar', title: 'Foobar', color: 'hds-alert--color-neutral' },
  ].forEach(({ type, title, color }) => {
    test(`it has correct title and color for type: ${type}`, async function (assert) {
      this.flash.type = type;
      await render(hbs``);
      assert.dom('[data-test-flash-toast-title]').hasText(title, 'title is correct');
      assert.dom('[data-test-flash-toast]').hasClass(color, 'color is correct');
    });
  });
  test('it renders messages with whitespaces correctly', async function (assert) {
    this.flash.message = `multi-
line msg`;
    await render(hbs``);
    const dom = find('[data-test-flash-message-body]');
    const lineHeight = 20;
    assert.true(dom.clientHeight > lineHeight, 'renders message on multiple lines');
  });
});