-1

私はJS単体テストにAVAを使用するのが初めてで、すぐに岩にぶつかりました:

私の状況では、gulp タスクを実行して AVA テストを実行し、テスト ファイルを監視したいと考えています。作成したテスト ファイルには、テストするコードを含む js ファイルを含める必要があります。

問題は、テストするコードを含むファイルがすべてのグローバル関数を含む古い js ファイルであるため、何らかの方法で AMD モジュールにシムする必要があることですが、元のファイルを変更せずにこれを行うにはどうすればよいですか?

gulpfile.js

var gulp = require("gulp");
var ava = require("gulp-ava");

var srcUnitTestFiles = ["**/*.tests.js", "!node_modules/*.js"];

gulp.task("unit-tests-exec", () =>
    gulp.src(srcUnitTestFiles)
        // gulp-ava needs filepaths so you can't have any plugins before it
        .pipe(ava({ verbose: true }))
);

gulp.task("unit-tests-watch", () =>
    gulp.watch(srcUnitTestFiles, ["unit-tests-exec"])
);

パッケージ.json

{
  "name": "name",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "ava"
  },
  "author": "",
  "license": "ISC",
  "devDependencies": {
    "ava": "^0.16.0",
    "gulp": "^3.9.1",
    "gulp-ava": "^0.14.0",
    "jsdom": "^9.4.2"
  },
  "ava": {
    "require": [
      "./test/helpers/setup-browser-env.js"
    ]
  }
}

firstTest.tests.js

import test from "ava";

// I need to import the js file to test

test.before(t => {

});

test("foo", t => {
    t.pass();
});

test('bar', async t => {
    const bar = Promise.resolve('bar');

    t.is(await bar, 'bar');
});

ありがとう!

4

1 に答える 1

0

AMDではなくUMDのことだと思います。AMDは使えません。

を使用したブラウザー テストのレシピにjsdom従うことをお勧めします。

上部で次のことができます。

global.document = require('jsdom').jsdom('<body></body>');
global.window = document.defaultView;
require('./your-lib');

そして、windowグローバルでライブラリにアクセスできます。

window.yourLib();

ライブラリにyourLibアタッチしたメソッドであること。window

于 2016-08-20T21:11:37.570 に答える