2017-07-26 12 views
0

私は、カルマとジャスミンを使ってAngular 4アプリケーションにテストを書いています。私は一貫してこのようになり、エラーを取得しています:カルマ/ジャスミンテストスイートのフェッチエラー

Error: Fetch error: 404 Not Found 
    at http://localhost:9876/base/node_modules/systemjs/dist/system.src.js?bf790cd9754a0743ba99db88ebac7a7c840dafaa:1500:13 
    at ZoneDelegate.invoke (http://localhost:9876/base/node_modules/zone.js/dist/zone.js?082dc1d83c7a42ddda9b652319d281eef1d450d5:391:26) 
    at Zone.run (http://localhost:9876/base/node_modules/zone.js/dist/zone.js?082dc1d83c7a42ddda9b652319d281eef1d450d5:141:43) 
    at http://localhost:9876/base/node_modules/zone.js/dist/zone.js?082dc1d83c7a42ddda9b652319d281eef1d450d5:818:57 
    at ZoneDelegate.invokeTask (http://localhost:9876/base/node_modules/zone.js/dist/zone.js?082dc1d83c7a42ddda9b652319d281eef1d450d5:424:31) 
    at Zone.runTask (http://localhost:9876/base/node_modules/zone.js/dist/zone.js?082dc1d83c7a42ddda9b652319d281eef1d450d5:191:47) 
    at drainMicroTaskQueue (http://localhost:9876/base/node_modules/zone.js/dist/zone.js?082dc1d83c7a42ddda9b652319d281eef1d450d5:584:35) 
    at <anonymous>' 

私は私には、しようとしたライブラリ/モジュールを見て撮影した、と彼らはすべてXMLHTTPRequest()(またはそれを抽象化)を使用するように見えます。これらは、mockBackendkarma-read-jsonです。

karma.conf.jsファイルは以下の通りです:

// Karma configuration 
// Used for Angular app unit testing 

'use strict'; 

var argv = require('yargs').argv; 
var minimatch = require("minimatch"); 


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'], 


    // list of files/patterns to load in the browser 
    files: [ 
     // Polyfills. 
     'node_modules/core-js/client/shim.min.js', 
     'node_modules/intl/dist/Intl.min.js', 

     'node_modules/traceur/bin/traceur.js', 

     // System.js for module loading 
     'node_modules/systemjs/dist/system.src.js', 

     // Zone.js dependencies 
     'node_modules/zone.js/dist/zone.js', 
     'node_modules/zone.js/dist/long-stack-trace-zone.js', 
     'node_modules/zone.js/dist/async-test.js', 
     'node_modules/zone.js/dist/fake-async-test.js', 
     'node_modules/zone.js/dist/sync-test.js', 
     'node_modules/zone.js/dist/proxy.js', 
     'node_modules/zone.js/dist/jasmine-patch.js', 

     // karma-read-json 
     { pattern: 'node_modules/karma-read-json/karma-read-json.js', included: false }, 

     // RxJs. 
     { pattern: 'node_modules/rxjs/**/*.js', included: false, watched: false }, 
     { pattern: 'node_modules/rxjs/**/*.js.map', included: false, watched: false }, 

     // paths loaded via module imports 
     // Angular itself 
     { pattern: 'node_modules/@angular/**/*.js', included: false, watched: true }, 
     { pattern: 'node_modules/@angular/**/*.js.map', included: false, watched: false }, 

     { pattern: 'dist/client/dev/**/*.js', included: false, watched: true }, 
     { pattern: 'dist/client/dev/**/*.html', included: false, watched: true, served: true }, 
     { pattern: 'dist/client/dev/**/*.css', included: false, watched: true, served: true }, 
     { pattern: 'node_modules/systemjs/dist/system-polyfills.js', included: false, watched: false }, // PhantomJS2 (and possibly others) might require it 

     // Dependencies for translation 
     { pattern: 'node_modules/@ngx-translate/core/bundles/*.js', included:false, watched: false }, 
     { pattern: 'node_modules/@ngx-translate/http-loader/bundles/*.js', included:false, watched: false }, 

     // Other libraries 
     { pattern: 'node_modules/lodash/*.js', included:false, watched: false }, 
     { pattern: 'node_modules/cron-converter/*.js', included:false, watched: false }, 
     { pattern: 'node_modules/cron-converter/src/*.js', included:false, watched: false }, 
     { pattern: 'node_modules/sprintf-js/src/*.js', included:false, watched: false }, 
     { pattern: 'node_modules/moment-timezone/*.js', included:false, watched: false }, 
     { pattern: 'node_modules/moment/*.js', included:false, watched: false }, 

     // suppress annoying 404 warnings for resources, images, etc. 
     { pattern: 'dist/dev/assets/**/*', watched: false, included: false, served: true }, 

     // i18n files to be included for translate to work 
     { pattern: 'src/client/assets/i18n/*.json', included: false}, 

     'test-config.js', 
     'dist/client/dev/app/system-config.js', 
     'test-main.js' 
    ], 

    // must go along with above, suppress annoying 404 warnings. 
    proxies: { 
     '/assets/': '/base/dist/dev/assets/' 
    }, 

    // list of files to exclude 
    exclude: [ 
     'node_modules/**/*spec.js' 
    ], 

    systemjs: { 
     serveFiles: [ 
     'node_modules/**/*.js', 
     'src/client/app/**/*.js', 
     'src/client/assets/i18n/*.json' 
     ] 
    }, 

    // preprocess matching files before serving them to the browser 
    // available preprocessors: https://npmjs.org/browse/keyword/karma-preprocessor 

    // test results reporter to use 
    // possible values: 'dots', 'progress' 
    // available reporters: https://npmjs.org/browse/keyword/karma-reporter 
    reporters: ['mocha'], 


    // web server port 
    port: 9876, 


    // 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: [ 
     'Chrome' 
    ], 


    customLaunchers: { 
     Chrome_travis_ci: { 
     base: 'Chrome', 
     flags: ['--no-sandbox'] 
     } 
    }, 

    // Continuous Integration mode 
    // if true, Karma captures browsers, runs the tests and exits 
    singleRun: false, 

    // Passing command line arguments to tests 
    client: { 
     files: argv.files ? minimatch.makeRe(argv.files).source : null 
    } 
    }); 

    if (process.env.APPVEYOR) { 
    config.browsers = ['IE']; 
    config.singleRun = true; 
    config.browserNoActivityTimeout = 90000; // Note: default value (10000) is not enough 
    } 

    if (process.env.TRAVIS || process.env.CIRCLECI) { 
    config.browsers = ['Chrome_travis_ci']; 
    config.singleRun = true; 
    config.browserNoActivityTimeout = 90000; 
    } 
}; 

私が働いているアプリケーションもバンドル用SystemJSを使用して、必要であれば、私は、そのための設定を提供することができます。

私はカルマがXMLHTTPRequestを使用できるようにするためにポリフィルまたは何かを含めることができますか?

+0

jasmine-queryもこの問題の原因と思われます。 –

+0

'rxjs/Observable'から 'rxjs'から 'Observable'を' import {Observable} 'に変更するだけでも、同じエラーで失敗します。 –

答えて

-1

私は同じ問題を抱えていました。私が作業していた別のブランチをマージした後、いくつかのファイルが場所を変更し、カルマが古いパスでそれらを探していたことがわかりました。私はカルマタスクを再開しなければなりませんでした(そして、私の場合もIDEを再起動します)。問題は解決されました。それが役に立てば幸い! ;-P

関連する問題