使TypeScript,Karma,RequireJS和Chai一起工作的问题 [英] Issue getting TypeScript, Karma, RequireJS and Chai to work together
问题描述
我正尝试使用TypeScript重写我的项目之一,因为我对TypeScript和RequireJS还是很陌生,所以我不确定自己缺少什么.
I'm trying to rewrite one of my projects using TypeScript and because I'm quite new to TypeScript and RequireJS I'm not sure what I'm missing.
我已遵循本指南业力-RequireJS ,并仔细检查了一切,但我还没有设法使其至少在RequireJS上不起作用.
I've followed this guide Karma - RequireJS and double checked everything, yet I haven't managed to get it working at least not RequireJS.
P.S.我收到的错误在帖子的结尾.
P.S. The error I'm getting is at the end of the post.
我为此项目使用的目录结构如下:
The directory structure I'm using for this project is as follow:
.
|-- WebEssentials-Settings.json
|-- build
|-- jake.sh
|-- jakefile.js
|-- node_modules
| |-- chai
| | |-- CONTRIBUTING.md
| | |-- History.md
| | |-- README.md
| | |-- ReleaseNotes.md
| | |-- bower.json
| | |-- chai.js
| | |-- index.js
| | |-- karma.conf.js
| | |-- karma.sauce.js
| | |-- lib
| | |-- node_modules
| | |-- package.json
| | `-- sauce.browsers.js
| |-- jake
| | |-- Jakefile
| | |-- Makefile
| | |-- README.md
| | |-- bin
| | |-- lib
| | |-- node_modules
| | |-- package.json
| | `-- test
| |-- karma
| | |-- CHANGELOG.md
| | |-- LICENSE
| | |-- README.md
| | |-- bin
| | |-- config.tpl.coffee
| | |-- config.tpl.js
| | |-- config.tpl.ls
| | |-- karma-completion.sh
| | |-- lib
| | |-- node_modules
| | |-- package.json
| | |-- requirejs.config.tpl.coffee
| | |-- requirejs.config.tpl.js
| | `-- static
| |-- karma-chai
| | |-- LICENSE
| | |-- README.md
| | |-- adapter.js
| | |-- index.js
| | `-- package.json
| |-- karma-mocha
| | |-- LICENSE
| | |-- README.md
| | |-- lib
| | `-- package.json
| |-- karma-requirejs
| | |-- LICENSE
| | |-- README.md
| | |-- lib
| | `-- package.json
| |-- mocha
| | |-- Readme.md
| | |-- bin
| | |-- images
| | |-- index.js
| | |-- lib
| | |-- mocha.css
| | |-- mocha.js
| | |-- node_modules
| | `-- package.json
| |-- requirejs
| | |-- README.md
| | |-- bin
| | |-- package.json
| | `-- require.js
| `-- shelljs
| |-- LICENSE
| |-- README.md
| |-- bin
| |-- global.js
| |-- make.js
| |-- package.json
| |-- scripts
| |-- shell.js
| `-- src
|-- scratchpad.txt
|-- src
| |-- app.main.js
| |-- app.main.js.map
| |-- app.main.ts
| |-- core
| | |-- exceptions.js
| | |-- exceptions.js.map
| | |-- exceptions.ts
| | |-- string.js
| | |-- string.js.map
| | |-- string.ts
| | |-- types.js
| | |-- types.js.map
| | `-- types.ts
| |-- css
| |-- index.html
| |-- libs
| | |-- jquery-2.1.0.js
| | |-- require.js
| | `-- typings
| |-- tests
| | |-- core
| | |-- test.main.js
| | |-- test.main.js.map
| | `-- test.main.ts
| |-- tsToolkit.csproj
| |-- tsToolkit.csproj.user
| |-- web.Debug.config
| |-- web.Release.config
| |-- web.config
| `-- widgets
|-- tools
| |-- karma
| | `-- karma.conf.js
| |-- lint
| | `-- lint_runner.js
| `-- mocha
| `-- mocha.ext.js
|-- tsToolkit.sln
|-- tsToolkit.sln.DotSettings.user
`-- tsToolkit.v12.suo
43 directories, 83 files
这是我用于Karma的配置文件. -karma.conf.js
Here is the configuration file I'm using for Karma. -- karma.conf.js
// Karma configuration
// Generated on Wed Sep 25 2013 00:47:38 GMT+0300 (Jerusalem Daylight Time)
module.exports = function(config) {
config.set({
// base path, that will be used to resolve files and exclude
basePath: '../../',
// frameworks to use
frameworks: ['requirejs', 'mocha', 'chai'],
// list of files / patterns to load in the browser
files: [
"tools/mocha/mocha.ext.js",
"src/libs/*.js",
"src/tests/*/*.js",
"src/tests/test.main.js"
],
// list of files to exclude
exclude: [
'src/main.js'
],
// test results reporter to use
// possible values: 'dots', 'progress', 'junit', 'growl', 'coverage'
reporters: ['progress'],
// web server port
port: 8380,
// enable / disable colors in the output (reporters and logs)
colors: true,
// level of logging
// possible values: config.LOG_DISABLE || config.LOG_ERROR || config.LOG_WARN || config.LOG_INFO || config.LOG_DEBUG
logLevel: config.LOG_INFO,
// enable / disable watching file and executing tests whenever any file changes
autoWatch: true,
// Start these browsers, currently available:
// - Chrome
// - ChromeCanary
// - Firefox
// - Opera
// - Safari (only Mac)
// - PhantomJS
// - IE (only Windows)
browsers: [],
// If browser does not capture in given timeout [ms], kill it
captureTimeout: 60000,
// Continuous Integration mode
// if true, it capture browsers, run tests and exit
singleRun: false
});
};
这是我对RequireJS的配置-tests.main.js
Here is the configuration I have for RequireJS - tests.main.js
interface Window {
// ReSharper disable InconsistentNaming
__karma__: any;
// ReSharper restore InconsistentNaming
}
var tests = [];
for (var file in window.__karma__.files) {
if (window.__karma__.files.hasOwnProperty(file)) {
if (/\.tests\.js$/.test(file))
{
tests.push(file);
}
}
}
declare var requirejs: any;
requirejs.config({
baseUrl: '/base/src',
deps: tests,
callback: window.__karma__.start
});
这是测试文件-types.tests.ts
Here is the test file -- types.tests.ts
import Types = require("./../../core/types");
describe("isUndefined", () =>
{
it("should return true when the object is undefined", () =>
{
});
});
这是我要测试的东西.
class Types {
public static isNull(value: any) : boolean
{
return false;
}
public static isUndefined(value: any) : boolean
{
return false;
}
public static isString(value: any) : boolean
{
return false;
}
public static isElement(value: any) : boolean
{
return false;
}
public static isNumber(value: any) : boolean
{
return false;
}
}
export = Types;
最后,这是我遇到的错误.
INFO [IE 9.0.0 (Windows 7)]: Connected on socket H-LT4D3cwsrYq1V01VdY with id manual-4093
IE 9.0.0 (Windows 7) ERROR
Mismatched anonymous define() module: function(require, exports) {
describe("isUndefined", function () {
it("should return true when the object is undefined", function () {
});
});
}
http://requirejs.org/docs/errors.html#mismatch
at D:/Projects/Code/Development/Visual Studio/tsToolkit/node_modules/requirejs/require.js:141
注释:
我试图编辑生成的测试的.js文件,并使用命名模块只是为了确保一切正常且可以!但是我想通过每个测试并在产生的.js文件中添加一个名称没有多大意义,不是吗?
I tried to edit the produced .js file of the test and use named modules just to make sure everything works and it does! but I guess that it doesn't make a lot of sense to go through each test and add a name to the produced .js file, isn't?
define("core/types", ["require", "exports"], function(require, exports) {
describe("isUndefined", function () {
it("should return true when the object is undefined", function () {
});
});
});
//# sourceMappingURL=types.tests.js.map
我相信,在TypeScript上进行了如此多的迭代之后,我希望他们不会错过它. :p
I'm sure that after so many iterations on TypeScript they haven't missed it, I hope. :p
我想我可以编写一些可以自动正确命名这些模块的代码,因为无论如何我都在使用构建文件,但是我真的不想添加可能可以保存的额外工作,希望如此.
I guess that I can write some code that automatically name these modules properly because I'm using a build file anyway but I really don't want to add extra work that can probably be saved, again, I hope.
推荐答案
我花了几天时间才弄清楚,在我的Karma配置文件和requirejs'tests.main.js中,路径到处都是错误的'文件.
It tooks me few days to figure it out, the paths were incorrect all over the place both in my Karma configuration files and the requirejs 'tests.main.js' file.
我还更改了项目结构,所以这里是我为使其工作而进行的所有更改.
I also changed the project structure so here is everything that I changed to make it work.
该解决方案现在可以在 GitHub 上获得.
The solution is now available at GitHub.
项目的目录结构.
.
|-- node_modules
| |-- jake
| | |-- bin
| | |-- lib
| | |-- node_modules
| | |-- test
| | |-- Jakefile
| | |-- Makefile
| | |-- README.md
| | `-- package.json
| |-- jasmine-node
| | |-- bin
| | |-- lib
| | |-- node_modules
| | |-- scripts
| | |-- spec
| | |-- src
| | |-- Gruntfile.coffee
| | |-- LICENSE
| | |-- README.md
| | |-- bower.json
| | |-- index.js
| | `-- package.json
| |-- karma
| | |-- bin
| | |-- lib
| | |-- node_modules
| | |-- static
| | |-- CHANGELOG.md
| | |-- LICENSE
| | |-- README.md
| | |-- config.tpl.coffee
| | |-- config.tpl.js
| | |-- config.tpl.ls
| | |-- karma-completion.sh
| | |-- package.json
| | |-- requirejs.config.tpl.coffee
| | `-- requirejs.config.tpl.js
| |-- karma-jasmine
| | |-- lib
| | |-- LICENSE
| | |-- README.md
| | `-- package.json
| |-- karma-requirejs
| | |-- lib
| | |-- LICENSE
| | |-- README.md
| | `-- package.json
| |-- karma-requirejs-preprocessor
| | `-- index.js
| |-- requirejs
| | |-- bin
| | |-- README.md
| | |-- package.json
| | `-- require.js
| `-- shelljs
| |-- bin
| |-- scripts
| |-- src
| |-- LICENSE
| |-- README.md
| |-- global.js
| |-- make.js
| |-- package.json
| `-- shell.js
|-- src
| |-- css
| |-- framework
| | |-- core
| | `-- widgets
| |-- libs
| | |-- typings
| | |-- jquery-2.1.0.js
| | `-- require.js
| |-- tests
| | |-- core
| | `-- test.main.js
| |-- app.main.js
| |-- app.main.js.map
| |-- app.main.ts
| |-- index.html
| |-- tsToolkit.csproj
| |-- tsToolkit.csproj.user
| |-- web.Debug.config
| |-- web.Release.config
| `-- web.config
|-- tools
| `-- karma
| `-- karma.conf.js
|-- WebEssentials-Settings.json
|-- jake.sh
|-- jakefile.js
|-- karma.sh
|-- scratchpad.txt
|-- tsToolkit.sln
|-- tsToolkit.sln.DotSettings.user
`-- tsToolkit.v12.suo
40 directories, 57 files
业力配置文件.
// Karma configuration
// Generated on Fri May 16 2014 08:27:07 GMT+0300 (Jerusalem Daylight Time)
module.exports = function(config) {
config.set({
// base path that will be used to resolve all patterns (eg. files, exclude)
basePath: '../../',
// frameworks to use
// available frameworks: https://npmjs.org/browse/keyword/karma-adapter
frameworks: ['jasmine', 'requirejs'],
// list of files / patterns to load in the browser
files: [
{pattern: 'src/libs/*.js', included: false},
{pattern: 'src/framework/**/*.js', included: false},
{pattern: 'src/tests/**/*.tests.js', included: false},
'src/tests/test.main.js'
],
// list of files to exclude
exclude: [
'src/app.main.js'
],
// preprocess matching files before serving them to the browser
// available preprocessors: https://npmjs.org/browse/keyword/karma-preprocessor
preprocessors: {
},
// test results reporter to use
// possible values: 'dots', 'progress'
// available reporters: https://npmjs.org/browse/keyword/karma-reporter
reporters: ['progress'],
// web server port
port: 8380,
// enable / disable colors in the output (reporters and logs)
colors: true,
// level of logging
// possible values: config.LOG_DISABLE || config.LOG_ERROR || config.LOG_WARN || config.LOG_INFO || config.LOG_DEBUG
logLevel: config.LOG_INFO,
// enable / disable watching file and executing tests whenever any file changes
autoWatch: true,
// start these browsers
// available browser launchers: https://npmjs.org/browse/keyword/karma-launcher
browsers: [],
// Continuous Integration mode
// if true, Karma captures browsers, runs the tests and exits
singleRun: false
});
};
这是requirejs文件-types.tests.js
var tests = [];
for (var file in window.__karma__.files) {
if (/\.tests\.js$/.test(file)) {
tests.push(file);
}
}
requirejs.config({
baseUrl: '/base/src',
deps: tests,
callback: window.__karma__.start
});
我要测试的以TypeScript编写的类的示例-types.ts
An example of a class that I wanted to test which is written in TypeScript -- types.ts
class Types {
public static isNull(value: any) : boolean
{
return false;
}
public static isUndefined(value: any) : boolean
{
return false;
}
public static isString(value: any) : boolean
{
return false;
}
public static isElement(value: any) : boolean
{
return false;
}
public static isNumber(value: any) : boolean
{
return false;
}
}
export = Types;
最后是我为'isUndefined'函数编写的测试-types.tests.ts
and finally, a test that I wrote for the function 'isUndefined' -- types.tests.ts
import Types = require("framework/core/types");
describe("isUndefined", () => {
it("should return true when the object is undefined", () => {
// Arrange
var obj;
// Act
var value = Types.isUndefined(obj);
// Assert
expect(value).toBe(true);
});
});
我希望它已经足够清楚了,它将对其他遇到相同问题的人有所帮助.
I hope that it's clear enough and that it will help others that are struggling with the same problem.
P.S.即使我为Karma编写了requirejs预处理器来命名模块,但在进行这些更改后,我不再需要它,它就可以了.
这篇关于使TypeScript,Karma,RequireJS和Chai一起工作的问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!