import { module, test } from 'qunit'; import { setupRenderingTest } from 'ember-qunit'; import { render } from '@ember/test-helpers'; import { format } from 'date-fns'; import hbs from 'htmlbars-inline-precompile'; module('Integration | Helper | date-format', function(hooks) { setupRenderingTest(hooks); test('it is able to format a date object', async function(assert) { let today = new Date(); this.set('today', today); await render(hbs`

Date: {{date-format today "yyyy"}}

`); assert .dom('[data-test-date-format]') .includesText(today.getFullYear(), 'it renders the date in the year format'); }); test('it supports date timestamps', async function(assert) { let today = new Date().getTime(); this.set('today', today); await render(hbs`

{{date-format today 'hh:mm:ss'}}

`); let formattedDate = document.querySelector('.date-format').innerText; assert.ok(formattedDate.match(/^\d{2}:\d{2}:\d{2}$/)); }); test('it supports date strings', async function(assert) { let todayString = new Date().getFullYear().toString(); this.set('todayString', todayString); await render(hbs`

Date: {{date-format todayString "yyyy"}}

`); assert .dom('[data-test-date-format]') .includesText(todayString, 'it renders the a date if passed in as a string'); }); test('it supports ten digit dates', async function(assert) { let tenDigitDate = 1621785298; this.set('tenDigitDate', tenDigitDate); await render(hbs`

Date: {{date-format tenDigitDate "MM/dd/yyyy"}}

`); assert.dom('[data-test-date-format]').includesText('05/23/2021'); }); test('it supports already formatted dates', async function(assert) { let formattedDate = new Date(); this.set('formattedDate', formattedDate); await render( hbs`

Date: {{date-format formattedDate 'MMMM dd, yyyy hh:mm:ss a' isFormatted=true}}

` ); assert.dom('[data-test-date-format]').includesText(format(formattedDate, 'MMMM dd, yyyy hh:mm:ss a')); }); });