-
-
Notifications
You must be signed in to change notification settings - Fork 33
/
Copy pathwill-destroy-test.js
65 lines (49 loc) · 1.96 KB
/
will-destroy-test.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
import { module, test } from 'qunit';
import { setupRenderingTest } from 'ember-qunit';
import { render, setupOnerror } from '@ember/test-helpers';
import hbs from 'htmlbars-inline-precompile';
module('Integration | Modifier | will-destroy', function(hooks) {
setupRenderingTest(hooks);
test('it basically works', async function(assert) {
assert.expect(2);
this.someMethod = element => {
assert.equal(element.tagName, 'DIV', 'correct element tagName');
assert.dom(element).hasAttribute('data-foo', 'some-thing');
};
this.set('show', true);
await render(
hbs`{{#if show}}<div data-foo="some-thing" {{will-destroy this.someMethod}}></div>{{/if}}`
);
// trigger destroy
this.set('show', false);
});
test('it can accept arguments', async function(assert) {
assert.expect(4);
this.someMethod = (element, positional, named) => {
assert.equal(element.tagName, 'DIV', 'correct element tagName');
assert.dom(element).hasAttribute('data-foo', 'some-thing');
assert.namedArgsEqual(named, { some: 'hash-value' }, 'named args match');
assert.deepEqual(positional, ['some-positional-value'], 'positional args match');
};
this.set('show', true);
await render(
hbs`{{#if show}}<div data-foo="some-thing" {{will-destroy this.someMethod "some-positional-value" some="hash-value"}}></div>{{/if}}`
);
// trigger destroy
this.set('show', false);
});
test('throws meaningful error when will-destroy does not receive a function', async function(assert) {
assert.expect(2);
this.notAFunction = null;
this.set('show', true);
setupOnerror(function(error) {
assert.equal(
error.message,
'Assertion Failed: You need to pass a function as the first argument to `will-destroy` you passed null'
);
});
await render(hbs`{{#if show}}<div {{will-destroy this.notAFunction}}></div>{{/if}}`);
// trigger destroy
this.set('show', false);
});
});