Skip to content

Commit

Permalink
integration tests
Browse files Browse the repository at this point in the history
  • Loading branch information
far-fetched committed Jul 5, 2021
1 parent 4f12755 commit ecc81ad
Show file tree
Hide file tree
Showing 4 changed files with 420 additions and 17 deletions.
2 changes: 2 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,8 @@
"@glimmer/component": "^1.0.4",
"@glimmer/tracking": "^1.0.4",
"@tailwindcss/ui": "^0.6.0",
"@testing-library/dom": "^8.1.0",
"@testing-library/user-event": "^13.1.9",
"babel-eslint": "^10.1.0",
"broccoli-asset-rev": "^3.0.0",
"dotenv-cli": "^4.0.0",
Expand Down
19 changes: 16 additions & 3 deletions tests/accessibility-assertions.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,10 @@ function getDialog() {
return document.querySelector('[role="dialog"]');
}

function getDialogs() {
return Array.from(document.querySelectorAll('[role="dialog"]'));
}

function getDialogOverlay() {
return document.querySelector('[id$="-headlessui-dialog-overlay"]');
}
Expand All @@ -16,6 +20,12 @@ function getDialogDescription() {
return document.querySelector('[id$="-headlessui-dialog-description"]');
}

function getDialogOverlays() {
return Array.from(
document.querySelectorAll('[id$="-headlessui-dialog-overlay"]')
);
}

const DialogState = {
/** The dialog is visible to the user. */
Visible: 'Visible',
Expand All @@ -31,14 +41,15 @@ function assertNever(x) {
throw new Error('Unexpected object: ' + x);
}

function assertActiveElement(element) {
function assertActiveElement(element, comment) {
try {
if (element === null) {
Qunit.assert.notEqual(element, null);
return;
}

Qunit.assert.equal(document.activeElement, element);
return Qunit.assert.waitFor(() => {
Qunit.assert.equal(document.activeElement, element, comment);
});
} catch (err) {
Error.captureStackTrace(err, assertActiveElement);
throw err;
Expand Down Expand Up @@ -523,7 +534,9 @@ export {
assertDialogOverlay,
assertDialogTitle,
getDialog,
getDialogs,
getDialogOverlay,
getDialogOverlays,
assertActiveElement,
getByText,
};
288 changes: 275 additions & 13 deletions tests/integration/components/dialog-test.js
Original file line number Diff line number Diff line change
@@ -1,8 +1,13 @@
import { module, test, todo } from 'qunit';
import { setupRenderingTest } from 'ember-qunit';
import { click, render, setupOnerror } from '@ember/test-helpers';
import triggerKeyEvent from '@ember/test-helpers/dom/trigger-key-event';
import {
click,
render,
setupOnerror,
triggerKeyEvent,
} from '@ember/test-helpers';
import { hbs } from 'ember-cli-htmlbars';
import userEvent from '@testing-library/user-event';

import { Keys } from 'ember-headlessui/utils/keyboard';

Expand All @@ -13,7 +18,9 @@ import {
assertDialogOverlay,
assertDialogTitle,
getDialog,
getDialogs,
getDialogOverlay,
getDialogOverlays,
assertActiveElement,
getByText,
} from '../../accessibility-assertions';
Expand Down Expand Up @@ -484,19 +491,274 @@ module('Integration | Component | <Dialog>', function (hooks) {
});

module('Nesting', function () {
todo(
'it should be possible to open nested Dialog components and close them with `Escape`',
async function () {}
);
test.each(
'it should be possible to open nested Dialog components and close them with `$strategy`',
[
{
strategy: 'outside click',
action: () => click(document.body),
},
{
strategy: 'ESCAPE click',
action: () =>
triggerKeyEvent(document.activeElement, 'keyup', Keys.Escape),
},
{
strategy: 'click on Dialog.Overlay',
action: () => click(getDialogOverlays().pop()),
},
],
async function (assert, { action }) {
await render(hbs`
{{#let (hash value=false) as |state|}}
<button
type="button"
{{on 'click' (set state.value true)}}>
Open 1
</button>
<Dialogs::Nested
@isOpen={{state.value}}
@onClose={{set state.value false}}
@level={{1}}
/>
{{/let}}
`);

todo(
'it should be possible to open nested Dialog components and close them with `Outside Click`',
async function () {}
);
assert.equal(getDialogs(), 0, 'Verify we have no open dialogs');

todo(
'it should be possible to open nested Dialog components and close them with `Click on Dialog.Overlay`',
async function () {}
await click(getByText('Open 1'), 'Open Dialog 1');

assert.equal(
getDialogs().length,
1,
'Verify that we have 1 open dialog'
);

await assertActiveElement(
getByText('Open 2 a'),
'Verify that the `Open 2 a` has focus'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 2 b'),
'Verify that we can tab around'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 2 c'),
'Verify that we can tab around'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 2 a'),
'Verify that we can tab around'
);

// Open Dialog 2 via the second button
await click(getByText('Open 2 b'));

assert.equal(
getDialogs().length,
2,
'Verify that we have 2 open dialogs'
);

await assertActiveElement(
getByText('Open 3 a'),
'Verify that the `Open 3 a` has focus'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 3 b'),
'Verify that we can tab around'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 3 c'),
'Verify that we can tab around'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 3 a'),
'Verify that we can tab around'
);

//close the top most dialog with ${strategy}
await action();

assert.equal(
getDialogs().length,
1,
'Verify that we have 1 open dialog'
);

await assertActiveElement(
getByText('Open 2 b'),
'Verify that the `Open 2 b` button got focused again'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 2 c'),
'Verify that we can tab around'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 2 a'),
'Verify that we can tab around'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 2 b'),
'Verify that we can tab around'
);

// Open Dialog 2 via the second button
await click(getByText('Open 2 b'));

await assertActiveElement(
getByText('Open 3 a'),
'Verify that the `Open 3 a` has focus'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 3 b'),
'Verify that we can tab around'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 3 c'),
'Verify that we can tab around'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 3 a'),
'Verify that we can tab around'
);

assert.equal(
getDialogs().length,
2,
'Verify that we have 2 open dialogs'
);

// Open Dialog 3 via button c
await click(getByText('Open 3 c'));

await assertActiveElement(
getByText('Open 4 a'),
'Verify that the `Open 4 a` has focus'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 4 b'),
'Verify that we can tab around'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 4 c'),
'Verify that we can tab around'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 4 a'),
'Verify that we can tab around'
);

assert.equal(
getDialogs().length,
3,
'Verify that we have 3 open dialogs'
);

//close the top most dialog with ${strategy}
await action();

await assertActiveElement(
getByText('Open 3 c'),
'Verify that the `Open 3 c` button got focused again'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 3 a'),
'Verify that we can tab around'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 3 b'),
'Verify that we can tab around'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 3 c'),
'Verify that we can tab around'
);

assert.equal(
getDialogs().length,
2,
'Verify that we have 2 open dialogs'
);

//close the top most dialog with ${strategy}
await action();

assert.equal(
getDialogs().length,
1,
'Verify that we have 1 open dialog'
);

await assertActiveElement(
getByText('Open 2 b'),
'Verify that the `Open 2 b` button got focused again'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 2 c'),
'Verify that we can tab around'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 2 a'),
'Verify that we can tab around'
);

userEvent.tab();
await assertActiveElement(
getByText('Open 2 b'),
'Verify that we can tab around'
);

//close the top most dialog with ${strategy}
await action();

assert.equal(getDialogs(), 0, 'Verify that we have 0 open dialogs');

await assertActiveElement(
getByText('Open 1'),
'Verify that we have 1 open dialog'
);
}
);
});

Expand Down
Loading

0 comments on commit ecc81ad

Please sign in to comment.