import { module, test } from 'qunit'; import EmberObject from '@ember/object'; import { setupRenderingTest } from 'ember-qunit'; import { render } from '@ember/test-helpers'; import { hbs } from 'ember-cli-htmlbars'; const minimumAttr = { name: 'my-input', type: 'text', }; const customLabelAttr = { name: 'test-input', type: 'text', options: { subText: 'Subtext here', label: 'Custom-label', }, }; module('Integration | Component | readonly-form-field', function (hooks) { setupRenderingTest(hooks); test('it renders', async function (assert) { this.set('attr', EmberObject.create(minimumAttr)); await render(hbs``); assert .dom('[data-test-readonly-label]') .includesText('My input', 'formats the attr name when no label provided'); assert.dom(`[data-test-input="${minimumAttr.name}"]`).hasValue('value', 'Uses the value as passed'); assert.dom(`[data-test-input="${minimumAttr.name}"]`).hasAttribute('readonly'); }); test('it renders with options', async function (assert) { this.set('attr', customLabelAttr); await render(hbs``); assert .dom('[data-test-readonly-label]') .includesText('Custom-label', 'Uses the provided label as passed'); assert.dom('.sub-text').includesText('Subtext here', 'Renders subtext'); assert .dom(`[data-test-input="${customLabelAttr.name}"]`) .hasValue('another value', 'Uses the value as passed'); assert.dom(`[data-test-input="${customLabelAttr.name}"]`).hasAttribute('readonly'); }); });