import { moduleFor, ApplicationTestCase } from 'internal-test-helpers'; import Controller from '@ember/controller'; import Service, { inject as injectService } from '@ember/service'; import { Helper, helper } from '@ember/-internals/glimmer'; moduleFor( 'Application Lifecycle - Helper Registration', class extends ApplicationTestCase { ['@test Unbound dashed helpers registered on the container can be late-invoked'](assert) { this.addTemplate('application', `
{{x-borf}} {{x-borf 'YES'}}
`); let myHelper = helper(params => params[0] || 'BORF'); this.application.register('helper:x-borf', myHelper); return this.visit('/').then(() => { assert.equal( this.$('#wrapper').text(), 'BORF YES', 'The helper was invoked from the container' ); }); } ['@test Bound helpers registered on the container can be late-invoked'](assert) { this.addTemplate('application', `
{{x-reverse}} {{x-reverse foo}}
`); this.add( 'controller:application', Controller.extend({ foo: 'alex', }) ); this.application.register( 'helper:x-reverse', helper(function([value]) { return value ? value .split('') .reverse() .join('') : '--'; }) ); return this.visit('/').then(() => { assert.equal( this.$('#wrapper').text(), '-- xela', 'The bound helper was invoked from the container' ); }); } ['@test Undashed helpers registered on the container can be invoked'](assert) { this.addTemplate( 'application', `
{{omg}}|{{yorp 'boo'}}|{{yorp 'ya'}}
` ); this.application.register('helper:omg', helper(() => 'OMG')); this.application.register('helper:yorp', helper(([value]) => value)); return this.visit('/').then(() => { assert.equal( this.$('#wrapper').text(), 'OMG|boo|ya', 'The helper was invoked from the container' ); }); } ['@test Helpers can receive injections'](assert) { this.addTemplate('application', `
{{full-name}}
`); let serviceCalled = false; this.add( 'service:name-builder', Service.extend({ build() { serviceCalled = true; }, }) ); this.add( 'helper:full-name', Helper.extend({ nameBuilder: injectService('name-builder'), compute() { this.get('nameBuilder').build(); }, }) ); return this.visit('/').then(() => { assert.ok(serviceCalled, 'service was injected, method called'); }); } } );