From 9b1e8ac07e3f4aa957b139717fb2b9b37f529bde Mon Sep 17 00:00:00 2001 From: Romina Vargas Date: Tue, 12 Jul 2016 17:12:49 -0400 Subject: [PATCH] Add new test helpers * For https://github.com/DockYard/ember-cli-test-interactions/issues/8 * Adds `findByAutoId`, `findInputByName`, `clickByAutoId`, * Change `const` to `let` in test files * `fillInByAutoId`, `fillInByName` --- test-support/helpers/finders.js | 8 +++ test-support/helpers/interactions.js | 25 ++++++- tests/acceptance/finders-test.js | 21 +++++- tests/acceptance/interactions-test.js | 75 ++++++++++++++++++--- tests/dummy/app/templates/elements/form.hbs | 4 +- 5 files changed, 116 insertions(+), 17 deletions(-) diff --git a/test-support/helpers/finders.js b/test-support/helpers/finders.js index d6f3123..fa95ec9 100644 --- a/test-support/helpers/finders.js +++ b/test-support/helpers/finders.js @@ -13,3 +13,11 @@ export function findLabelByText(text) { return label; } + +export function findByAutoId(name) { + return find(`[data-auto-id="${name}"]`); +} + +export function findInputByName(name) { + return findWithAssert(`input[name="${name}"]`); +} diff --git a/test-support/helpers/interactions.js b/test-support/helpers/interactions.js index 8cc2446..91ea548 100644 --- a/test-support/helpers/interactions.js +++ b/test-support/helpers/interactions.js @@ -1,7 +1,9 @@ import Ember from 'ember'; import { findInputByLabel, - findLabelByText + findLabelByText, + findByAutoId, + findInputByName } from '../helpers/finders'; const { isEmpty } = Ember; @@ -60,3 +62,24 @@ export function selectByLabel(label, optionText) { .then(() => find(`#${selectId}`).trigger('focusout')); } } + +export function clickByAutoId(autoId) { + andThen(() => { + let element = findByAutoId(autoId); + click(element); + }); +} + +export function fillInByAutoId(autoId, value) { + andThen(() => { + let element = findByAutoId(autoId); + fillIn(element, value); + }); +} + +export function fillInByName(name, value) { + andThen(() => { + let element = findInputByName(name); + fillIn(element, value); + }); +} diff --git a/tests/acceptance/finders-test.js b/tests/acceptance/finders-test.js index b2705f2..e66141a 100644 --- a/tests/acceptance/finders-test.js +++ b/tests/acceptance/finders-test.js @@ -7,7 +7,9 @@ import startApp from '../helpers/start-app'; import { findInputByLabel, - findLabelByText + findLabelByText, + findInputByName, + findByAutoId } from '../helpers/finders'; let app; @@ -16,6 +18,7 @@ const { run } = Ember; module('Integration: Finders', { beforeEach() { app = startApp(); + visit('/'); }, afterEach() { @@ -28,7 +31,6 @@ test('#findLabelByText finds the label by the label text', function(assert) { let label; - visit('/'); andThen(function() { label = findLabelByText('Email'); @@ -42,7 +44,6 @@ test('#findInputByLabel finds the input by the label text', function(assert) { let label; let input; - visit('/'); andThen(function() { label = findLabelByText('Name'); input = findInputByLabel(label); @@ -50,3 +51,17 @@ test('#findInputByLabel finds the input by the label text', function(assert) { assert.equal('John Doe', input.val(), 'expected John Doe to be the input value'); }); }); + +test('#findByAutoId find a button with autoId', (assert) => { + assert.expect(1); + + let button = findByAutoId('first-target-btn'); + assert.equal(button.length, 1); +}); + +test('#findInputByName find input by name', (assert) => { + assert.expect(1); + + let input = findInputByName('node-2-input'); + assert.equal(input.val(), 'John Doe'); +}); diff --git a/tests/acceptance/interactions-test.js b/tests/acceptance/interactions-test.js index 786f1f4..6c37410 100644 --- a/tests/acceptance/interactions-test.js +++ b/tests/acceptance/interactions-test.js @@ -15,7 +15,10 @@ import { clickLink, clickRadioByLabel, fillInByLabel, - selectByLabel + selectByLabel, + clickByAutoId, + fillInByAutoId, + fillInByName } from '../helpers/interactions'; let app; @@ -35,7 +38,7 @@ module('Acceptance: Interactions', { test('#checkByLabel finds a checkbox and checks it', (assert) => { andThen(checkByLabel('This is the second checkbox')); andThen(() => { - const checkedInput = find('#checkbox2:checked'); + let checkedInput = find('#checkbox2:checked'); assert.equal('second_checkbox', checkedInput.val(), `expected the second checkbox to be checked but found ${checkedInput.val()}`); }); @@ -60,46 +63,96 @@ test('#clickLink finds a link by its text and clicks it', function(assert) { andThen(clickLink('First link')); andThen(() => { - const url = currentURL(); + let url = currentURL(); assert.equal(url, '/first-link-target'); }); }); test('#clickRadioByLabel adds checked attribute to corresponding input', (assert) => { + assert.expect(2); + andThen(clickRadioByLabel('Label for first radio')); andThen(() => { - const checkedInput = find('input:checked'); + let checkedInput = find('input:checked'); assert.equal('radio_1', checkedInput.val(), 'expected radio 1 to be checked'); }); andThen(clickRadioByLabel('Label for second radio')); andThen(() => { - const checkedInput = find('input:checked'); + let checkedInput = find('input:checked'); assert.equal('radio_2', checkedInput.val(), 'expected radio 2 to be checked'); }); }); test('#fillInByLabel enters text into an input corresponding to a label', function(assert) { - const targetInput = 'form input.node-2'; - const targetValue = 'Jane Doe'; - assert.expect(2); + let targetInput = 'form input.node-2'; + let targetValue = 'Jane Doe'; + andThen(() => { - const val = find(targetInput).val(); + let val = find(targetInput).val(); assert.notEqual(val, targetValue, 'did not expect the input to contain the target value yet'); }); andThen(fillInByLabel('Name', targetValue)); andThen(() => { - const val = find(targetInput).val(); + let val = find(targetInput).val(); assert.equal(val, targetValue, 'expected the input to contain the target value'); }); }); test('#selectByLabel selects a dropdown option by label and option', (assert) => { + assert.expect(1); + andThen(selectByLabel('Label for first select', 'Value 2')); andThen(() => { - const selectedOption = find('option:selected'); + let selectedOption = find('option:selected'); assert.equal('value2', selectedOption.val(), 'expected option 2 to be selected'); }); }); + + +test('#clickByAutoId finds a button by autoId and clicks it', (assert) => { + assert.expect(1); + + clickByAutoId('first-target-btn'); + andThen(assertHasMessage(assert, 'First target button clicked')); +}); + +test('#fillInByAutoId fills in input by autoId', (assert) => { + assert.expect(2); + + let targetInput = 'form input.node-2'; + let targetValue = 'Jane Doe'; + + andThen(() => { + let val = find(targetInput).val(); + assert.notEqual(val, targetValue, 'did not expect the input to contain the target value yet'); + }); + + fillInByAutoId('node-2-input', targetValue); + + andThen(() => { + let val = find(targetInput).val(); + assert.equal(val, targetValue, 'expected the input to contain the target value'); + }); +}); + +test('#fillInByName fills input by name', (assert) => { + assert.expect(2); + + let targetInput = 'form input.node-2'; + let targetValue = 'Jane Doe'; + + andThen(() => { + let val = find(targetInput).val(); + assert.notEqual(val, targetValue, 'did not expect the input to contain the target value yet'); + }); + + fillInByName('node-2-input', targetValue); + + andThen(() => { + let val = find(targetInput).val(); + assert.equal(val, targetValue, 'expect the input to have the target value'); + }); +}); diff --git a/tests/dummy/app/templates/elements/form.hbs b/tests/dummy/app/templates/elements/form.hbs index 29a0355..f8d553f 100644 --- a/tests/dummy/app/templates/elements/form.hbs +++ b/tests/dummy/app/templates/elements/form.hbs @@ -2,10 +2,10 @@
John Doe - + - +