// Karma configuration "use strict"; const path = require("path"); const VueLoaderPlugin = require("vue-loader/lib/plugin"); function resolve(dir) { return path.join(__dirname, dir); } 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: ["mocha", "sinon-chai"], // list of files / patterns to load in the browser files: [ "./karma.files.js", { pattern: 'node_modules/sql.js/dist/sql-wasm.wasm', watched: false, included: false, served: true, nocache: false }, { pattern: 'node_modules/sql.js/dist/worker.sql-wasm.js', watched: false, included: false, served: true, nocache: false } ], // list of files / patterns to exclude exclude: [], // preprocess matching files before serving them to the browser // available preprocessors: https://npmjs.org/browse/keyword/karma-preprocessor preprocessors: { "./karma.files.js": ["webpack"] }, // test results reporter to use // possible values: 'dots', 'progress' // available reporters: https://npmjs.org/browse/keyword/karma-reporter reporters: ["spec", "coverage"], coverageReporter: { dir: "coverage", reporters: [{ type: "lcov", subdir: "." }, { type: "text-summary" }] }, // !!DONOT delete this reporter, or vue-cli-addon-ui-karma doesnot work jsonResultReporter: { outputFile: "report/karma-result.json", isSynchronous: true }, junitReporter: { outputDir: "report", // results will be saved as $outputDir/$browserName.xml outputFile: undefined, // if included, results will be saved as $outputDir/$browserName/$outputFile suite: "", // suite will become the package name attribute in xml testsuite element useBrowserName: true, // add browser name to report and classes names nameFormatter: undefined, // function (browser, result) to customize the name attribute in xml testcase element classNameFormatter: undefined, // function (browser, result) to customize the classname attribute in xml testcase element properties: {} // key value pair of properties to add to the section of the report }, // 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: ["ChromiumHeadless"], // Continuous Integration mode // if true, Karma captures browsers, runs the tests and exits singleRun: true, // Concurrency level // how many browser should be started simultaneous concurrency: Infinity, client: { captureConsole: true }, browserConsoleLogOptions: { terminal: true, level: "" }, webpack: { mode: "development", entry: "./src/main.js", resolve: { extensions: [".js", ".vue", ".json"], alias: { vue$: "vue/dist/vue.esm.js", "@": resolve("src") } }, module: { rules: [ { test: /\.js$/, exclude: /(node_modules|bower_components)/, use: [ { loader: "babel-loader" } ] }, { test: /\.js$/, include: /src/, exclude: /(node_modules|bower_components|\.spec\.js$|\/file)/, use: [ { loader: "istanbul-instrumenter-loader", options: { esModules: true } } ] }, { test: /\.(png|jpe?g|gif|svg)(\?.*)?$/, loader: "url-loader" }, { test: /\.vue$/, loader: "vue-loader", options: { loaders: { js: "babel-loader" }, postLoaders: { js: "istanbul-instrumenter-loader?esModules=true" } } }, { test: /\.css$/, use: ["vue-style-loader", "css-loader"] }, { test: /\.scss$/, use: ["vue-style-loader", "css-loader", "sass-loader"] }, { test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/, loader: "url-loader", options: { limit: 10000, name: resolve("fonts/[name].[hash:7].[ext]") } } ] }, plugins: [new VueLoaderPlugin()], node: { fs: 'empty' } }, proxies: { "/js/": "/base/node_modules/sql.js/dist/" } }); };