2017-04-18 60 views
1

當我運行「npm run test」時,我用我的所有單元測試運行。現在,在爲我需要使用的庫(它被稱爲Wijmo)添加節點模塊後,我在控制檯中看到以下錯誤,這似乎阻止了我的所有單元測試的執行(相反,Karma瀏覽器出現綠色,沒有測試運行)。當運行Angular 2應用程序的Karma測試時,節點模塊中的「系統未定義」

應該注意的是,當使用「npm start」時,節點模塊在應用程序本身中加載並運行時沒有問題。

這裏的錯誤:

Chrome 57.0.2987 (Windows 7 0.0.0) ERROR 
    Uncaught ReferenceError: System is not defined 
    at node_modules/wijmo/wijmo.js:13 

Chrome 57.0.2987 (Windows 7 0.0.0) ERROR 
    Uncaught ReferenceError: System is not defined 
    at node_modules/wijmo/wijmo.js:13 

我忘記了要在配置某處添加此模塊?或者這可能是實際節點模塊的問題?

karma.config.js:

// #docregion 
module.exports = function(config) { 

    var appBase = 'app/';  // transpiled app JS and map files 
    var appSrcBase = 'app/';  // app source TS files 
    var appAssets = '/base/app/'; // component assets fetched by Angular's compiler 

    var testingBase = 'testing/';  // transpiled test JS and map files 
    var testingSrcBase = 'testing/';  // test source TS files 

    config.set({ 
     basePath: '', 
     frameworks: ['jasmine'], 
     plugins: [ 
      require('karma-jasmine'), 
      require('karma-chrome-launcher'), 
      require('karma-jasmine-html-reporter'), // click "Debug" in browser to see it 
      require('karma-htmlfile-reporter') // crashing w/ strange socket error 
     ], 

     client: { 
      builtPaths: [appBase, testingBase], // add more spec base paths as needed 
      clearContext: false // leave Jasmine Spec Runner output visible in browser 
     }, 

     customLaunchers: { 
      // From the CLI. Not used here but interesting 
      // chrome setup for travis CI using chromium 
      Chrome_travis_ci: { 
       base: 'Chrome', 
       flags: ['--no-sandbox'] 
      } 
     }, 
     files: [ 
      'node_modules/lodash/lodash.js', 
      'node_modules/wijmo/wijmo.js', 
      'node_modules/wijmo/wijmo.chart.js', 
      'node_modules/wijmo/wijmo.chart.interaction.js', 
      // System.js for module loading 
      'node_modules/systemjs/dist/system.src.js', 

      // Polyfills 
      'node_modules/core-js/client/shim.js', 
      'node_modules/reflect-metadata/Reflect.js', 

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

      // 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: false }, 
      { pattern: 'node_modules/@angular/**/*.js.map', included: false, watched: false }, 

      { pattern: 'systemjs.config.js', included: false, watched: false }, 
      { pattern: 'systemjs.config.extras.js', included: false, watched: false }, 
      'karma-test-shim.js', // optionally extend SystemJS mapping e.g., with barrels 

      // transpiled application & spec code paths loaded via module imports 
      { pattern: appBase + '**/*.js', included: false, watched: true }, 
      { pattern: testingBase + '**/*.js', included: false, watched: true }, 


      // Asset (HTML & CSS) paths loaded via Angular's component compiler 
      // (these paths need to be rewritten, see proxies section) 
      { pattern: appBase + '**/*.html', included: false, watched: true }, 
      { pattern: appBase + '**/*.css', included: false, watched: true }, 

      // Paths for debugging with source maps in dev tools 
      { pattern: appSrcBase + '**/*.ts', included: false, watched: false }, 
      { pattern: appBase + '**/*.js.map', included: false, watched: false }, 
      { pattern: testingSrcBase + '**/*.ts', included: false, watched: false }, 
      { pattern: testingBase + '**/*.js.map', included: false, watched: false} 
     ], 

     // Proxied base paths for loading assets 
     proxies: { 
      // required for component assets fetched by Angular's compiler 
      "/app/": appAssets 
     }, 

     exclude: [], 
     preprocessors: {}, 
     // disabled HtmlReporter; suddenly crashing w/ strange socket error 
     reporters: ['progress', 'kjhtml'],//'html'], 

     port: 9876, 
     colors: true, 
     logLevel: config.LOG_INFO, 
     autoWatch: true, 
     browsers: ['Chrome'], 
     singleRun: false 
    }) 
} 

卡瑪測試shim.js:

// /*global jasmine, __karma__, window*/ 
Error.stackTraceLimit = 0; // "No stacktrace"" is usually best for app testing. 

// Uncomment to get full stacktrace output. Sometimes helpful, usually not. 
// Error.stackTraceLimit = Infinity; // 

jasmine.DEFAULT_TIMEOUT_INTERVAL = 1000; 

// builtPaths: root paths for output ("built") files 
// get from karma.config.js, then prefix with '/base/' (default is 'app/') 
var builtPaths = (__karma__.config.builtPaths || ['app/']) 
    .map(function(p) { return '/base/'+p;}); 

__karma__.loaded = function() { }; 

function isJsFile(path) { 
    return path.slice(-3) == '.js'; 
} 

function isSpecFile(path) { 
    return /\.spec\.(.*\.)?js$/.test(path); 
} 

// Is a "built" file if is JavaScript file in one of the "built" folders 
function isBuiltFile(path) { 
    return isJsFile(path) && 
     builtPaths.reduce(function(keep, bp) { 
      return keep || (path.substr(0, bp.length) === bp); 
     }, false); 
} 

var allSpecFiles = Object.keys(window.__karma__.files) 
    .filter(isSpecFile) 
    .filter(isBuiltFile); 

System.config({ 
    baseURL: 'base', // was originally /base... if ng2-translate messes up, try going back to that 
    // Extend usual application package list with test folder 
    packages: { 'testing': { main: 'index.js', defaultExtension: 'js' } }, 

    // Assume npm: is set in `paths` in systemjs.config 
    // Map the angular testing umd bundles 
    map: { 
     '@angular/core/testing': 'npm:@angular/core/bundles/core-testing.umd.js', 
     '@angular/common/testing': 'npm:@angular/common/bundles/common-testing.umd.js', 
     '@angular/compiler/testing': 'npm:@angular/compiler/bundles/compiler-testing.umd.js', 
     '@angular/platform-browser/testing': 'npm:@angular/platform-browser/bundles/platform-browser-testing.umd.js', 
     '@angular/platform-browser-dynamic/testing': 'npm:@angular/platform-browser-dynamic/bundles/platform-browser-dynamic-testing.umd.js', 
     '@angular/http/testing': 'npm:@angular/http/bundles/http-testing.umd.js', 
     '@angular/router/testing': 'npm:@angular/router/bundles/router-testing.umd.js', 
     '@angular/forms/testing': 'npm:@angular/forms/bundles/forms-testing.umd.js', 
     'ng2-translate': '/base/node_modules/ng2-translate' 
    } 
}); 

System.import('systemjs.config.js') 
    .then(importSystemJsExtras) 
    .then(initTestBed) 
    .then(initTesting); 

/** Optional SystemJS configuration extras. Keep going w/o it */ 
function importSystemJsExtras(){ 
    return System.import('systemjs.config.extras.js') 
     .catch(function(reason) { 
      console.log(
       'Warning: System.import could not load the optional "systemjs.config.extras.js". Did you omit it by accident? Continuing without it.' 
      ); 
      console.log(reason); 
     }); 
} 

function initTestBed(){ 
    return Promise.all([ 
     System.import('@angular/core/testing'), 
     System.import('@angular/platform-browser-dynamic/testing') 
    ]) 

     .then(function (providers) { 
      var coreTesting = providers[0]; 
      var browserTesting = providers[1]; 

      coreTesting.TestBed.initTestEnvironment(
       browserTesting.BrowserDynamicTestingModule, 
       browserTesting.platformBrowserDynamicTesting()); 
     }) 
} 

// Import all spec files and start karma 
function initTesting() { 
    return Promise.all(
     allSpecFiles.map(function (moduleName) { 
      return System.import(moduleName); 
     }) 
    ) 
     .then(__karma__.start, __karma__.error); 
} 

的package.json,以防萬一:

{ 
    "name": "app", 
    "version": "1.0.1", 
    "scripts": { 
    "start": "tsc && concurrently \"tsc -w\" \"lite-server\" \"npm run generate-css\" \"npm run watch-css\" ", 
    "pree2e": "npm run webdriver:update", 
    "e2e": "tsc && concurrently \"http-server -s\" \"protractor protractor.config.js\" --kill-others --success first", 
    "lint": "tslint ./app/**/*.ts -t verbose", 
    "generate-css": "node-sass -r app --output ./generated-css", 
    "watch-css": "node-sass -w -r app --output ./generated-css", 
    "lite": "lite-server", 
    "test": "tsc && concurrently \"tsc -w\" \"karma start karma.conf.js\"", 
    "test-once": "tsc && karma start karma.conf.js --single-run", 
    "tsc": "tsc", 
    "tsc:w": "tsc -w" 
    }, 
    "license": "", 
    "author": "me", 
    "dependencies": { 
    "@angular/animations": "4.0.2", 
    "@angular/common": "4.0.2", 
    "@angular/compiler": "4.0.2", 
    "@angular/compiler-cli": "4.0.2", 
    "@angular/core": "4.0.2", 
    "@angular/forms": "4.0.2", 
    "@angular/material": "^2.0.0-beta.3", 
    "@angular/http": "4.0.2", 
    "@angular/platform-browser": "4.0.2", 
    "@angular/platform-browser-dynamic": "4.0.2", 
    "@angular/platform-server": "4.0.2", 
    "@angular/router": "4.0.2", 
    "angular-in-memory-web-api": "0.2.4", 
    "angular2-ui-switch": "1.2.0", 
    "bootstrap": "3.3.7", 
    "core-js": "2.4.1", 
    "mydatepicker":"1.2.9", 
    "ng2-translate": "5.0.0", 
    "reflect-metadata": "0.1.9", 
    "rxjs": "5.0.1", 
    "socket.io": "1.7.2", 
    "lodash": "4.17.4", 
    "socket.io-client": "1.7.2", 
    "systemjs": "0.19.40", 
    "wijmo": "wijmo-system-min", 
    "zone.js": "0.8.5", 
    "typescript": "2.2.2" 
    }, 
    "devDependencies": { 
    "@types/core-js": "0.9.35", 
    "@types/jasmine": "2.5.40", 
    "@types/node": "6.0.58", 
    "@types/selenium-webdriver": "2.53.39", 
    "@types/lodash": "4.14.62", 
    "canonical-path":"0.0.2", 
    "codelyzer": "0.0.25", 
    "concurrently": "3.1.0", 
    "http-server": "0.9.0", 
    "jasmine-core": "2.5.2", 
    "karma": "1.3.0", 
    "karma-chrome-launcher": "2.0.0", 
    "karma-cli": "1.0.1", 
    "karma-htmlfile-reporter": "0.3.4", 
    "karma-jasmine": "1.1.0", 
    "karma-jasmine-html-reporter": "0.2.2", 
    "lite-server": "2.2.2", 
    "live-server": "1.1.0", 
    "lodash": "4.17.4", 
    "node-sass": "3.13.1", 
    "nodemon": "1.11.0", 
    "protractor": "3.3.0", 
    "rimraf": "2.5.4", 
    "tslint": "3.15.1" 
    } 
} 

systemjs.config .js

(function (global) { 
    System.config({ 
     paths: { 
      // paths serve as alias 
      'npm:': 'node_modules/' 
     }, 
     // map tells the System loader where to look for things 
     map: { 
      // our app is within the app folder 
      app: 'app', 
      // angular bundles 
      '@angular/core': 'npm:@angular/core/bundles/core.umd.js', 
      '@angular/common': 'npm:@angular/common/bundles/common.umd.js', 
      '@angular/compiler': 'npm:@angular/compiler/bundles/compiler.umd.js', 
      '@angular/platform-browser': 'npm:@angular/platform-browser/bundles/platform-browser.umd.js', 
      '@angular/platform-browser-dynamic': 'npm:@angular/platform-browser-dynamic/bundles/platform-browser-dynamic.umd.js', 
      '@angular/http': 'npm:@angular/http/bundles/http.umd.js', 
      '@angular/router': 'npm:@angular/router/bundles/router.umd.js', 
      '@angular/forms': 'npm:@angular/forms/bundles/forms.umd.js', 

      // other libraries 
      'rxjs':      'npm:rxjs', 
      'angular-in-memory-web-api': 'npm:angular-in-memory-web-api/bundles/in-memory-web-api.umd.js', 
      'ng2-translate':    'npm:ng2-translate/bundles', 
      'lodash':     'npm:lodash', 
      'socket.io-client':   'npm:socket.io-client/socket.io.js', 
      'mydatepicker':    'npm:mydatepicker', 
      'wijmo':      'npm:wijmo', 
      'angular2-ui-switch':  'npm:angular2-ui-switch' 
     }, 
     // packages tells the System loader how to load when no filename and/or no extension 
     packages: { 
      app: { 
       main: './main.js', 
       defaultExtension: 'js' 
      }, 
      rxjs: { 
       defaultExtension: 'js' 
      }, 
      'ng2-translate': { 
       main: 'ng2-translate', 
       defaultExtension: 'umd.js' 
      }, 
      'socket.io-client': { 
       defaultExtension: 'js' 
      }, 
      'mydatepicker': { 
       main: './dist/index.js', 
       defaultExtension: 'js' 
      }, 
      'angular2-ui-switch': { 
       main: './dist/index.js', 
       defaultExtension: 'js' 
      }, 
      lodash: { 
       main: './lodash.js', 
       defaultExtension: 'js' 
      }, 
      wijmo: { 
       main: './wijmo.js', 
       defaultExtension: 'js' 
      } 
     } 
    }); 
})(this); 
+0

我認爲測試所有應用程序與所有第三方(第三方應該有自己的測試)是錯誤的,相反,我認爲你應該更換所有第三方模擬引導 – happyZZR1400

+0

問題不在於注入構造函數,它是wijmo功能本身的輸入。需要定義那些「wijmo」對象,這就是爲什麼我將它們列入它們在karma配置文件數組中定義的節點模塊中的原因。 – David

回答

0

我最終通過更新.html文件來解決這個問題,在那裏我定義了哪些測試顯示在業力報告中。我很確定問題只是我沒有引用這個文檔中的spec文件。由於spec文件通過正則表達式被karma檢測到,所以它試圖運行測試,但是當它沒有在.html中定義時,它會拋出錯誤。

+0

你能提供更多的信息嗎?你做了什麼改變?我有同樣的問題,但不認爲它來自報告! –

+1

對不起,但我根本不記得 - 這是大約5個月前在這一點上。但從我的回答來看,我認爲我所要做的就是進入該應用程序的index.html並添加一個額外的

相關問題