3

https://github.com/stefanpenner/ember-cli/issues/2421

余烬-cli:1.2

我有一个样板插件项目,它有一个标题案例助手,如下所示:

我的助手app/helpers/title-case.js

import Ember from 'ember';

export default Ember.Handlebars.makeBoundHelper(function(string) {

    if (typeof string === 'string') {
        //replace dashes with spaces
        var str = string.dasherize().replace(/-/g, ' ');

        return str.replace(/\w\S*/g, function(word){
            return word.charAt(0).toUpperCase() + word.substr(1).toLowerCase();
        });
    } else {
        return string;
    }

});

我使用 ember-cli 为助手生成了测试

ember g helper-test title-case

这是输出:

import {
  titleCase
} from 'boilerplate/helpers/title-case';

module('TitleCaseHelper');

// Replace this with your real tests.
test('it works', function() {
  var result = titleCase(42);
  ok(result);
});

现在从 ember-cli 运行测试

ember test

收到以下错误:

Build failed.
File: dummy/tests/unit/helpers/title-case-test.js
ENOENT, no such file or directory '/home/me/git/ember/boilerplate/tmp/tree_merger-tmp_dest_dir-PL6HFkuw.tmp/boilerplate/helpers/title-case.js'
Error: ENOENT, no such file or directory '/home/me/git/ember/boilerplate/tmp/tree_merger-tmp_dest_dir-PL6HFkuw.tmp/boilerplate/helpers/title-case.js'

更新

我尝试将以下内容更改为“虚拟”而不是自动生成的“样板”并删除了大括号。

//import {
//  titleCase
//} from 'dummy/helpers/title-case';
import titleCase from 'dummy/helpers/title-case';

它现在进一步进入测试方法,但在调用时失败titleCase(42)

TypeError: Cannot read property 'isUnbound' of undefined

更新#2

我能够让它工作,但它很难看,我需要访问该._rawFunction属性并更改导入语句的格式。

import titleCaseHelper from 'dummy/helpers/title-case';

var titleCase = titleCaseHelper._rawFunction;
module('TitleCaseHelper');

test('Title case lower case letters', function() {
      var result = titleCase('hello world');
      equal(result, 'Hello World');
});

我仍然对为什么 ember-cli 生成的原始测试不起作用感到困惑。

4

1 回答 1

3

helper-test 生成器希望 helper 文件具有特定格式,如果您生成了 helper,您可以看到:

ember generate helper hello

这将生成文件 app/helpers/hello.js,其中包含

import Ember from 'ember';

export function hello(input) {
  return input;
};

export default Ember.Handlebars.makeBoundHelper(hello);

它还将在 tests/unit/helpers/hello-test.js 中为上述内容生成一个单元测试

import {
  hello
} from 'ember-empty/helpers/hello';

module('HelloHelper');

// Replace this with your real tests.
test('it works', function() {
  var result = hello(42);
  ok(result);
});

换句话说,helper-test 生成器希望您除了绑定 helper 之外还导出原始函数本身。

于 2015-02-01T13:49:04.663 回答