2015-10-07 5 views
6

テストを実行しているときに、カルマは最後のテストを複数回複製しているようですが、テストが複製される時間は、テストの数と実行に使用されるブラウザによって異なります。テスト結果を複写するカルマ出力

1回のテストで1つのブラウザ(PhantomJSまたはChrome)を使用するだけであれば、テストは2回表示されます。両方のブラウザを使用すると同じテストが最大6回表示されます。

ログにログを追加しました。ログはブラウザごとに1回発生するため、テストは正しい回数だけ実行されていますが、結果を複製するだけです。

karma.conf.js

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: [ 
     '_test/test.js' 
    ], 


    // list of files to exclude 
    exclude: [ 
    ], 


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


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

test.js

describe('karma testing', function() { 
    it('tests karma is working', function() { 
     expect(true).toBe(true); 
     console.log('test1'); 
    }); 
}); 

出力1つのブラウザ(クロム)

07 10 2015 16:41:14.890:INFO [karma]: Karma v0.13.10 server started at http://localhost:9876/ 
07 10 2015 16:41:14.897:INFO [launcher]: Starting browser Chrome 
07 10 2015 16:41:16.364:INFO [Chrome 45.0.2454 (Windows 7 0.0.0)]: Connected on socket 0uvPocfSI0prGxwdAAAA with id 29520633 
LOG: 'test1' 
Chrome 45.0.2454 (Windows 7 0.0.0): Executed 1 of 1 SUCCESS (0 secs/0.003 secs 
Chrome 45.0.2454 (Windows 7 0.0.0): Executed 1 of 1 SUCCESS (0.011 secs/0.003 secs) 

出力2つのブラウザ(PhantomJS、クロム)

07 10 2015 16:27:31.399:INFO [karma]: Karma v0.13.10 server started at http://localhost:9876/ 
07 10 2015 16:27:31.407:INFO [launcher]: Starting browser PhantomJS 
07 10 2015 16:27:31.420:INFO [launcher]: Starting browser Chrome 
07 10 2015 16:27:32.886:INFO [PhantomJS 1.9.8 (Windows 7 0.0.0)]: Connected on socket P5focoe7004aPX1rAAAA with id 49258591 
07 10 2015 16:27:33.077:INFO [Chrome 45.0.2454 (Windows 7 0.0.0)]: Connected on socket BGtRdqevRGGXZTA-AAAB with id 42323971 
LOG: 'test1' 
PhantomJS 1.9.8 (Windows 7 0.0.0): Executed 1 of 1 SUCCESS (0 secs/0.003 secs) 
PhantomJS 1.9.8 (Windows 7 0.0.0): Executed 1 of 1 SUCCESS (0.007 secs/0.003 s 
PhantomJS 1.9.8 (Windows 7 0.0.0): Executed 1 of 1 SUCCESS (0.007 secs/0.003 s 
Chrome 45.0.2454 (Windows 7 0.0.0) LOG: 'test1' 
PhantomJS 1.9.8 (Windows 7 0.0.0): Executed 1 of 1 SUCCESS (0.007 secs/0.003 s 
PhantomJS 1.9.8 (Windows 7 0.0.0): Executed 1 of 1 SUCCESS (0.007 secs/0.003 secs) 
PhantomJS 1.9.8 (Windows 7 0.0.0): Executed 1 of 1 SUCCESS (0.007 secs/0.003 secs) 
Chrome 45.0.2454 (Windows 7 0.0.0): Executed 1 of 1 SUCCESS (0.028 secs/0.002 secs) 
TOTAL: 2 SUCCESS 

私はkarma-cliのインストールの有無にかかわらずこれをテストしましたが、結果は同じです。

私はスタックオーバーフローとGoogleの周りを見て、いくつかの人々は同様の問題に遭遇したようですが、意味のある回答はありません。

+0

これを考え出している運がありますか?私たちは同じ問題を抱えています。 –

+0

残念なことに、私はちょうど今のところそれと一緒に暮らしています、あなたは同じ設定を実行していますか? – ndonohoe

答えて

0

プリティファイヤーを動作させるときに同様の問題が発生しました。

karma.confには、autoWatch、ブラウザ、singleRunなどのいくつかのオプションがあります - そうですか?これらの中には、クライアントと呼ばれるプロパティがあります。

クライアントプロパティは、独自のプロパティがいくつかあるオブジェクトです。その目的は、たとえばChromeのようなテストクライアントに関連する設定を構成することです。

クライアントには、captureConsoleというプロパティがあります。これはデフォルトでtrueになります。つまり、ブラウザのコンソールログはすべてbashに返されます。だから、デフォルトでオンになっているので、私はChromeのコンソールロギングとprettifiedタップ出力を見ていました。

この設定をお試しください。

client: { 
    captureConsole: false 
}, 
0

私はこれが何年も前に尋ねられたことを知っていますが、あなたはWindowsのコマンドラインからカルマを実行していた可能性はありますか?私は同じ問題を抱えており、数時間のグーグル・グーグルを無駄にしてしまいました。そして、気まずい人はpowershellからそれを走らせました。またgit bashで作業しました。

関連する問題