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');
});
}
}
);