module.exports = function(config) { config.set({ "singleRun": true, "autoWatch": false, "basePath": "/home/jenkins/.jenkins/workspace/Door/build/js/packages/door-door-testdb-test", "files": [ "/home/jenkins/.jenkins/workspace/Door/build/js/packages_imported/kotlin-test-js-runner/0.0.1/kotlin-test-karma-runner.js", "/home/jenkins/.jenkins/workspace/Door/build/js/packages/door-door-testdb-test/kotlin/door-door-testdb-test.js" ], "frameworks": [ "mocha", "webpack" ], "client": { "args": [] }, "browsers": [ "ChromeHeadless" ], "customLaunchers": {}, "failOnFailingTestSuite": false, "failOnEmptyTestSuite": false, "reporters": [ "karma-kotlin-reporter" ], "preprocessors": { "/home/jenkins/.jenkins/workspace/Door/build/js/packages_imported/kotlin-test-js-runner/0.0.1/kotlin-test-karma-runner.js": [ "webpack", "sourcemap" ], "/home/jenkins/.jenkins/workspace/Door/build/js/packages/door-door-testdb-test/kotlin/door-door-testdb-test.js": [ "webpack", "sourcemap" ] }, "proxies": {} }); config.plugins = config.plugins || []; config.plugins.push('kotlin-test-js-runner/karma-kotlin-reporter.js'); config.loggers = [ { type: 'kotlin-test-js-runner/tc-log-appender.js', //default layout layout: { type: 'pattern', pattern: '%[%d{DATETIME}:%p [%c]: %]%m' } } ] // webpack config function createWebpackConfig() { let config = { mode: 'development', resolve: { modules: [ "node_modules" ] }, plugins: [], module: { rules: [] } }; // source maps config.module.rules.push({ test: /\.m?js$/, use: ["source-map-loader"], enforce: "pre" }); config.devtool = false; config.ignoreWarnings = [/Failed to parse source map/] // optimization config.optimization = config.optimization || { "splitChunks": false }; // Report progress to console // noinspection JSUnnecessarySemicolon ;(function(config) { const webpack = require('webpack'); const handler = (percentage, message, ...args) => { const p = percentage * 100; let msg = `${Math.trunc(p / 10)}${Math.trunc(p % 10)}% ${message} ${args.join(' ')}`; ; console.log(msg); }; config.plugins.push(new webpack.ProgressPlugin(handler)) })(config); // noinspection JSUnnecessarySemicolon ;(function(config) { const tcErrorPlugin = require('kotlin-test-js-runner/tc-log-error-webpack'); config.plugins.push(new tcErrorPlugin()) config.stats = config.stats || {} Object.assign(config.stats, config.stats, { warnings: false, errors: false }) })(config); config.experiments = { topLevelAwait: true, } // noinspection JSUnnecessarySemicolon ;(function(config) { const webpack = require('webpack'); // https://github.com/webpack/webpack/issues/12951 const PatchSourceMapSource = require('kotlin-test-js-runner/webpack-5-debug'); config.plugins.push(new PatchSourceMapSource()) config.plugins.push(new webpack.SourceMapDevToolPlugin({ moduleFilenameTemplate: "[absolute-resource-path]" })) })(config); return config; } config.set({webpack: createWebpackConfig()}); // karma.config.generated.js var PROJECT_PATH = '/home/jenkins/.jenkins/workspace/Door'; // karma.config.js //Workaround resource loader bug as per notes on build.gradle config.middleware = config.middleware || []; config.middleware.push('resource-loader'); function ResourceLoaderMiddleware() { const fs = require('fs'); return function (request, response, next) { try { console.log(PROJECT_PATH); const content = fs.readFileSync(PROJECT_PATH + '/door-runtime/build/processedResources/js/test' + decodeURI(request.originalUrl)); response.writeHead(200); response.end(content); } catch (ignored) { try { const content = fs.readFileSync(PROJECT_PATH + '/door-runtime/build/processedResources/js/main' + decodeURI(request.originalUrl)); response.writeHead(200); response.end(content); } catch (ignored) { next(); } } } } config.set({ logLevel: config.LOG_DEBUG, client: { mocha: { timeout: 30000 } } }) config.plugins.push({ 'middleware:resource-loader': ['factory', ResourceLoaderMiddleware] }); }