Typescript компилируется дважды с помощью karma-webpack - PullRequest
0 голосов
/ 24 октября 2018

У меня есть простой проект машинопись / React.Для тестирования я использую Karma и webpack для компиляции файлов .ts и .tsx.но в консоли я замечаю, что компиляция запускается дважды!

Интересно, что я могу с этим поделать?

Это то, что я вижу в консоли

enter image description here

Также, как вы можете видеть, в исходной папке находится только 1 .tsx файл.Если я начинаю добавлять больше файлов, это приводит к тому, что время моего проекта тестируется на небесной ракете, потому что каждая точка входа компилируется дважды.

enter image description here

карма.conf.js

module.exports = (config) => {
  config.set({
    // ... normal karma configuration
    files: [
      // all files ending in ".spec"
      {
        pattern: 'src/*.spec.ts', 
        watched: false, 
        included: false,
        served: true
      },
      {
        pattern: 'src/**/*.spec.tsx', 
        watched: false, 
        included: false,
        served: true
      }
      // each file acts as entry point for the webpack configuration
    ],

    preprocessors: {
      // add webpack as preprocessor
      'src/*.spec.ts': ['webpack'],
      'src/**/*.spec.tsx': ['webpack']
    },

    webpack: {
      // karma watches the test entry points
      // (you don't need to specify the entry option)
      // webpack watches dependencies

      // webpack configuration
    },

    webpackMiddleware: {
      // webpack-dev-middleware configuration
      // i. e.
      stats: 'errors-only'
    }
  })
}

webpack.conf.js

// For instructions about this file refer to
// webpack and webpack-hot-middleware documentation
var webpack = require('webpack');
const glob = require('glob');
const path = require('path');

var CopyWebpackPlugin = require('copy-webpack-plugin');
const ExtractTextPlugin = require("extract-text-webpack-plugin");
var HtmlWebpackPlugin = require('html-webpack-plugin');

const extractSass = new ExtractTextPlugin({
    // TODO: filename: "/assets/css/[name].css?v=[contenthash]"
    filename: "./assets/css/app.css"
});

module.exports = {
    entry: {
        app: './src/app.tsx',
    },
    output: {
        path: path.resolve(__dirname, 'dist'),
        publicPath: "/",
        filename: "[name].bundle.js"
    },
    resolve: {
        extensions: ['.ts', '.tsx', '.js', '.json', '.scss', '.css'],
        modules:['./src', './tests', './node_modules']
    },
    plugins: [
        extractSass,
        new HtmlWebpackPlugin({
            template: './src/index.html'
        }),
        new webpack.LoaderOptionsPlugin({
            debug: true
        }),
        new webpack.NoEmitOnErrorsPlugin(),
        new webpack.optimize.OccurrenceOrderPlugin(),
        new webpack.optimize.UglifyJsPlugin({
            compress: {
              warnings: false
            },
            mangle: true
        }),
        new CopyWebpackPlugin([
            {
                from: './src/assets',
                to: './assets'
            }
        ])
    ],
    devtool: "#eval-source-map",
    module: {
        rules: [
            {
                test: [/\.scss$/, /\.css$/],
                use: extractSass.extract({
                    fallback: 'style-loader',
                    //resolve-url-loader may be chained before sass-loader if necessary
                    use: [{
                        loader: "css-loader"
                    }, {
                        loader: "sass-loader",
                        options: {
                            includePaths: glob.sync('node_modules').map((d) => path.join(__dirname, d))
                        }
                    }]
                })
            },
            {
                enforce: 'pre',
                test: /\.tsx?$/,
                use: [{ loader: 'ts-loader' }, // "use" - multiple loaders
                {
                    loader: 'tslint-loader',
                    options: {
                        //                        emitErrors: true,
                        noRequireVar: false,
                        fix: true,
                        failOnHint: false
                    },
                }]
            },
            {
                test: /\.(jpe?g|png|gif|svg)$/i,
                use: [
                    { loader: 'file-loader?hash=sha512&digest=hex&name=[hash].[ext]' },
                    { loader: 'image-webpack-loader?bypassOnDebug&optimizationLevel=7&interlaced=false',
                    // REF: https://github.com/tcoopman/image-webpack-loader/issues/68#issuecomment-326210929
                      options: {
                        gifsicle: {
                            interlaced: true
                        }
                      }
                    }
                ]
            },
            {
                enforce: 'pre',
                test: /\.js$/,
                use: "source-map-loader"
            },
            {
                enforce: 'pre',
                test: /\.ts?$/,
                use: "source-map-loader"
            }
        ]
    }
};
...