2020-03-12 15:41:06 +00:00
|
|
|
import { module, test } from 'qunit';
|
|
|
|
import { setupRenderingTest } from 'ember-qunit';
|
|
|
|
import { render } from '@ember/test-helpers';
|
|
|
|
import { hbs } from 'ember-cli-htmlbars';
|
|
|
|
|
2022-09-15 10:43:17 +02:00
|
|
|
module('Integration | Component | ref', function (hooks) {
|
2020-03-12 15:41:06 +00:00
|
|
|
setupRenderingTest(hooks);
|
|
|
|
|
2022-09-15 10:43:17 +02:00
|
|
|
test('it renders', async function (assert) {
|
2020-03-12 15:41:06 +00:00
|
|
|
// Set any properties with this.set('myProperty', 'value');
|
|
|
|
// Handle any actions with this.set('myAction', function(val) { ... });
|
2022-09-15 10:43:17 +02:00
|
|
|
const componentAction = function () {};
|
2020-03-12 15:41:06 +00:00
|
|
|
// yield the action in the component, optionally changing the name
|
|
|
|
// {{ yield (hash
|
|
|
|
// publicAction=(action 'componentAction')
|
|
|
|
// )}}
|
|
|
|
const _yield = {
|
|
|
|
publicAction: componentAction,
|
|
|
|
};
|
|
|
|
this.set('api', _yield);
|
|
|
|
await render(hbs`<Ref @target={{this}} @name="api" @value={{api}} />`);
|
|
|
|
// the value is now available on the target
|
|
|
|
// in most cases `this` i.e. the scope of the template (component/controller)
|
|
|
|
assert.deepEqual(this.api, _yield);
|
|
|
|
|
|
|
|
assert.equal(this.element.textContent.trim(), '');
|
|
|
|
|
|
|
|
// // Template block usage:
|
|
|
|
// await render(hbs`
|
|
|
|
// <Ref></Ref>
|
|
|
|
// `);
|
|
|
|
|
|
|
|
// assert.equal(this.element.textContent.trim(), '');
|
|
|
|
});
|
|
|
|
});
|