gpt4 book ai didi

typescript - 试图让 Jasmine 与 Webpack 一起工作

转载 作者:搜寻专家 更新时间:2023-10-30 21:10:36 24 4
gpt4 key购买 nike

我正在尝试将一个项目从 tsc 迁移到 webpack,这样我就可以捆绑所有脚本。现在,我遇到了 Jasmine 的问题:TS2304:找不到名称“describe”。这是我的 karma 配置:

module.exports = function(config) {

var appBase = 'app/'; // transpiled app JS and map files
var appSrcBase = 'app/'; // app source TS files
var appAssets = '/base/app/'; // component assets fetched by Angular's compiler

// Testing helpers (optional) are conventionally in a folder called `testing`
var testingBase = 'testing/'; // transpiled test JS and map files
var testingSrcBase = 'testing/'; // test source TS files

config.set({
basePath: '',
frameworks: ['jasmine'],

plugins: [
require('karma-jasmine'),
require('karma-chrome-launcher'),
require('karma-jasmine-html-reporter')
],

client: {
builtPaths: [appBase, testingBase], // add more spec base paths as needed
clearContext: false // leave Jasmine Spec Runner output visible in browser
},

customLaunchers: {
// From the CLI. Not used here but interesting
// chrome setup for travis CI using chromium
Chrome_travis_ci: {
base: 'Chrome',
flags: ['--no-sandbox']
}
},

files: [
// System.js for module loading
'node_modules/systemjs/dist/system.src.js',

// Polyfills
'node_modules/core-js/client/shim.js',

// zone.js
'node_modules/zone.js/dist/zone.js',
'node_modules/zone.js/dist/long-stack-trace-zone.js',
'node_modules/zone.js/dist/proxy.js',
'node_modules/zone.js/dist/sync-test.js',
'node_modules/zone.js/dist/jasmine-patch.js',
'node_modules/zone.js/dist/async-test.js',
'node_modules/zone.js/dist/fake-async-test.js',

// RxJs
{ pattern: 'node_modules/rxjs/**/*.js', included: false, watched: false },
{ pattern: 'node_modules/rxjs/**/*.js.map', included: false, watched: false },

// Paths loaded via module imports:
// Angular itself
{ pattern: 'node_modules/@angular/**/*.js', included: false, watched: false },
{ pattern: 'node_modules/@angular/**/*.js.map', included: false, watched: false },

{ pattern: 'systemjs.config.js', included: false, watched: false },
'karma-test-shim.js', // optionally extend SystemJS mapping e.g., with barrels

// transpiled application & spec code paths loaded via module imports
{ pattern: appBase + '**/*.js', included: false, watched: true },
{ pattern: testingBase + '**/*.js', included: false, watched: true },


// Asset (HTML & CSS) paths loaded via Angular's component compiler
// (these paths need to be rewritten, see proxies section)
{ pattern: appBase + '**/*.html', included: false, watched: true },
{ pattern: appBase + '**/*.css', included: false, watched: true },

// Paths for debugging with source maps in dev tools
{ pattern: appSrcBase + '**/*.ts', included: false, watched: false },
{ pattern: appBase + '**/*.js.map', included: false, watched: false },
{ pattern: testingSrcBase + '**/*.ts', included: false, watched: false },
{ pattern: testingBase + '**/*.js.map', included: false, watched: false}
],

// Proxied base paths for loading assets
proxies: {
// required for component assets fetched by Angular's compiler
"/app/": appAssets
},

exclude: [],
preprocessors: {},
reporters: ['progress', 'kjhtml'],
webpack: require('./webpack.config.js'),

port: 9876,
colors: true,
logLevel: config.LOG_INFO,
autoWatch: true,
browsers: ['Chrome'],
singleRun: false
})
}

这是我的 webpack 配置:

var ExtractTextPlugin = require('extract-text-webpack-plugin');

module.exports = {
entry: ["./src/ts/main.ts","./src/ts/css.ts"],
module: {
rules: [
{
test: /\.ts$/,
loaders: [
{
loader: 'awesome-typescript-loader',
options: { configFileName: 'tsconfig.json' }
} , 'angular2-template-loader'
]
},
{
test: /\.jsx$/,
use: "babel-loader"
},
{
test: /\.html$/,
use: "html-loader"
},
{
test: /\.css$/,
use: ExtractTextPlugin.extract({use: 'css-loader'})
},
{
test: /\.(jpe?g|png|gif|svg)$/i,
use: ['url-loader?limit=10000', 'img-loader']
},
{
test: /\.(eot|woff2?|ttf)$/i,
use: 'url-loader'
}
]
},
resolve: {
extensions: [".tsx", ".ts", ".js"]
},
plugins: [
new ExtractTextPlugin("public/styles.css"),
],
output: {
filename: "public/bundle.js"
}
}

我对此一无所知。到目前为止,我找到的帮助只是给我“找不到名称”或“找不到模块:错误:无法解析‘fs’”错误。

最佳答案

你需要为 jasmin 安装类型

npm i --save-dev @types/jasmine

然后在你的tsconfig文件中声明它

"types": ["jasmine"]

关于typescript - 试图让 Jasmine 与 Webpack 一起工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43543288/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com