2015-11-26 13 views
7

Sto cercando di ottenere la copertura del codice per il mio codice dattiloscritto nel quadro di karma usando Istanbul in karma.conf i file dattiloscritti sono inclusi e con il preprocessore-dattilografo karma possiamo fare unità prova e copertura del codice del codice dattiloscritto ma il rapporto di copertura del codice viene fornito per codice JavaScript tranciatoCopertura del codice per dattiloscritto usando karma-jasmine e istanbul

Come posso ottenere il rapporto di copertura per il codice dattiloscritto?

Ecco il file karma.conf.

module.exports = function(config) { 
 
    config.set({ 
 

 
    // base path, that will be used to resolve files and exclude 
 
    basePath: '', 
 

 

 
    // frameworks to use 
 
    frameworks: ['jasmine'], 
 

 
    preprocessors: { 
 
     'src/**/*.ts': ['typescript', 'coverage'], 
 
     'test/**/*.ts': ['typescript'] 
 
    }, 
 
    typescriptPreprocessor: { 
 
     options: { 
 
      sourceMap: false, // (optional) Generates corresponding .map file. 
 
      target: 'ES5', // (optional) Specify ECMAScript target version: 'ES3' (default), or 'ES5' 
 
      module: 'amd', // (optional) Specify module code generation: 'commonjs' or 'amd' 
 
      noImplicitAny: true, // (optional) Warn on expressions and declarations with an implied 'any' type. 
 
      noResolve: false, // (optional) Skip resolution and preprocessing. 
 
      removeComments: true, // (optional) Do not emit comments to output. 
 
      concatenateOutput: false // (optional) Concatenate and emit output to single file. By default true if module option is omited, otherwise false. 
 
     }, 
 
     // extra typing definitions to pass to the compiler (globs allowed) 
 
     // transforming the filenames 
 
     transformPath: function (path) { 
 
      return path.replace(/\.ts$/, '.js'); 
 
     } 
 

 
     //options: { 
 
     // sourceMap: true, 
 
     //} 
 
    }, 
 

 
    // list of files/patterns to load in the browser 
 
    files: [ 
 

 
     'src/**/*.ts', 
 
     'test/**/*.ts' 
 
    ], 
 

 

 
    // list of files to exclude 
 
    exclude: [ 
 
     
 
    ], 
 
    // test results reporter to use 
 
    // possible values: 'dots', 'progress', 'junit', 'growl', 'coverage' 
 
    reporters: ['progress','coverage'], 
 

 

 
    // 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, currently available: 
 
    // - Chrome 
 
    // - ChromeCanary 
 
    // - Firefox 
 
    // - Opera (has to be installed with `npm install karma-opera-launcher`) 
 
    // - Safari (only Mac; has to be installed with `npm install karma-safari-launcher`) 
 
    // - PhantomJS 
 
    // - IE (only Windows; has to be installed with `npm install karma-ie-launcher`) 
 
    browsers: ['PhantomJS'], 
 

 

 
    // 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, 
 
    plugins: [ 
 
    'karma-jasmine', 
 
    'karma-chrome-launcher', 
 
    'karma-phantomjs-launcher', 
 
    'karma-typescript-preprocessor', 
 
    'karma-coverage' 
 
    //require('../../../node_modules/karma-typescript-preprocessor/index.js') 
 
    ] 
 

 
    }); 
 
};

+0

È possibile utilizzare remap-istanbul per questo: https://github.com/SitePen/remap-istanbul – elecash

+0

Non ho trovato un buon esempio di utilizzo di remap-istanbul con TypeScript. –

risposta

1

Stiamo utilizzando Instanbul-remap per il nostro progetto e funziona abbastanza bene. Per creare i nostri rapporti di copertura, si corre il seguente script di shell:

#!/bin/bash 

PROJECT_PATH="$(dirname $0)/../" 

cd $PROJECT_PATH 
echo Creating coverage reports for `pwd` 

if [ ! -d "target/dist" ]; then 
    echo 
    echo "target/dist directory not found. Must compile source with \`npm install\` before running tests." 
    echo 
    exit 1; 
fi 

COVERAGE_DIR=target/coverage-raw 
REMAP_DIR=target/coverage-ts 

mkdir -p $COVERAGE_DIR 
mkdir -p $REMAP_DIR 

# run coverage on unit tests only 
echo Creating coverage reports for unit tests 
node_modules/.bin/istanbul cover --dir $COVERAGE_DIR nodeunit `find target/dist/test/ -name *.test.js` > /dev/null 

# re-map the coverage report so that typescript sources are shown 
echo Remapping coverage reports for typescript 
node_modules/.bin/remap-istanbul -i $COVERAGE_DIR/coverage.json -o $REMAP_DIR -t html 

echo Coverage report located at $REMAP_DIR/index.html 

Il nostro progetto utilizza nodeunit come un test harness, come si tratta di un'applicazione nodo. Tuttavia, mi aspetto che un approccio simile possa funzionare per il karma.

+0

Funziona perfettamente anche per i test di esecuzione 'mocha' –

1

C'è karma-remap-istanbul che integra perfettamente remap-istanbul con karma. La documentazione è piuttosto auto-esplicativa, ma una cosa: avere un riepilogo sulla console è la text: undefined (altrimenti l'output del testo va al file).

Quindi è possibile avere una copertura sintesi direttamente dal karma tuttavia quando ts fonti non sono disponibili nella stessa directory karma.config.jskarma-remap-istanbul ha ancora bisogno di un po 'di sviluppo per quanto riguarda la configurazione di essere in grado di generare report HTML completo.

8

Installare karma-typescript:

npm install karma-typescript --save-dev 

Dieci in karma.conf.js:

frameworks: ["jasmine", "karma-typescript"], 

files: [ 
    { pattern: "src/**/*.ts" } 
], 

preprocessors: { 
    "**/*.ts": ["karma-typescript"] 
}, 

reporters: ["progress", "karma-typescript"], 

browsers: ["Chrome"] 

Questo verrà eseguito il test di unità tipografico al volo e generare Istanbul copertura html che assomigliano a questo :

Per eseguire l'esempio di cui sopra è necessario installare alcuni pacchetti:

npm install @types/jasmine jasmine-core karma karma-chrome-launcher karma-cli karma-jasmine karma-typescript typescript

Questa è la configurazione completa per i test delle unità di codice di vaniglia tipografico, non tsconfig.json necessaria in questo caso. Per configurazioni più complesse con Angular, React ecc., Puoi trovare esempi nello examples folder e nel integration tests.

+1

puoi pubblicare la configurazione completa? –

+0

@JuniBrosas, ho modificato la mia risposta, è questo il tipo di informazioni che stai cercando? –