Тест Ng выдает ошибку Не удается найти модуль 'angular -cli/plugins/karma'
С помощью angular -cli пытается записать тест для службы после выполнения ng test. Я получаю эту ошибку:
02 03 2017 14:51:09.486:ERROR [config]: Error in config file!
{ Error: Cannot find module 'angular-cli/plugins/karma'
at Function.Module._resolveFilename (module.js:469:15)
at Function.Module._load (module.js:417:25)
at Module.require (module.js:497:17)
at require (internal/module.js:20:19)
at module.exports (/Desktop/e2-frontend/karma.conf.js:12:7)
at Object.parseConfig (/Desktop/e2-frontend/node_modules/karma/lib/config.js:342:5)
at new Server (/Desktop/e2-frontend/node_modules/karma/lib/server.js:56:20)
at Promise (/Desktop/e2-frontend/node_modules/@angular/cli/tasks/test.js:34:33)
at Class.run (/Desktop/e2-frontend/node_modules/@angular/cli/tasks/test.js:15:16)
at Class.run (/Desktop/e2-frontend/node_modules/@angular/cli/commands/test.js:106:25)
at Class.<anonymous> (/Desktop/e2-frontend/node_modules/@angular/cli/ember-cli/lib/models/command.js:134:17)
at process._tickCallback (internal/process/next_tick.js:103:7) code: 'MODULE_NOT_FOUND' }
karma.config.js
// Karma configuration file, see link for more information
// https://karma-runner.github.io/0.13/config/configuration-file.html
module.exports = function (config) {
config.set({
basePath: '',
frameworks: ['jasmine', 'angular-cli'],
plugins: [
require('karma-jasmine'),
require('karma-chrome-launcher'),
require('karma-remap-istanbul'),
require('angular-cli/plugins/karma')
],
files: [
{ pattern: './src/test.ts', watched: false }
],
preprocessors: {
'./src/test.ts': ['angular-cli']
},
mime: {
'text/x-typescript': ['ts','tsx']
},
remapIstanbulReporter: {
reports: {
html: 'coverage',
lcovonly: './coverage/coverage.lcov'
}
},
angularCli: {
config: './angular-cli.json',
environment: 'dev'
},
reporters: config.angularCli && config.angularCli.codeCoverage
? ['progress', 'karma-remap-istanbul']
: ['progress'],
port: 9876,
colors: true,
logLevel: config.LOG_INFO,
autoWatch: true,
browsers: ['Chrome'],
singleRun: false
});
};
Похоже, что он почему-то не может найти карму. для этого должно быть другое место.
Как я могу исправить эту ошибку?
Ответы
Ответ 1
Заменить эту строку
frameworks: ['jasmine', 'angular-cli'],
с этим frameworks: ['jasmine', '@angular/cli'],
Эта строка
require('angular-cli/plugins/karma')
к этому require('@angular/cli/plugins/karma')
Это - preprocessors: {
'./src/test.ts': ['angular-cli']
},
для этого
preprocessors: {
'./src/test.ts': ['@angular/cli']
},
в файле karma.config.js. Надеюсь, что это поможет вам.
Ответ 2
Рабочее решение
Откройте файл karma.conf.js
и замените каждый angular-cli/plugins/karma
на:
@angular/cli/plugins/karma
Указанные свойства для замены находятся внутри следующих клавиш:
-
рамки,
-
плагинов,
- препроцессоры
.
Затем модифицированные свойства должны выглядеть так:
frameworks: ['jasmine', '@angular/cli'],
plugins: [
require('karma-jasmine'),
require('karma-chrome-launcher'),
require('karma-remap-istanbul'),
require('@angular/cli/plugins/karma')
],
preprocessors: {
'./src/test.ts': ['@angular/cli']
}
Ответ 3
Сначала убедитесь, что вы установили последний angular CLI (npm install --save-dev @angular/cli: последний) и удалите 'angular -cli' в пакете .json
Второй, перейдите в karma.conf.js, чтобы изменить следующее:
от
рамки: ['jasmine', 'angular -cli']
до
рамки: ['jasmine', @angular/cli ']
от
require('angular-cli/plugins/karma')
до
require('@angular/cli/plugins/karma')
от
preprocessors: {
'./src/test.ts': ['angular-cli']
},
до
preprocessors: {
'./src/test.ts': ['@angular/cli']
},
Затем отредактируйте angular -cli.json
от
"environments": {
"source": "environments/environment.ts",
"dev": "environments/environment.ts",
"prod": "environments/environment.prod.ts"
}
до
"environmentSource": "environments/environments.ts",
"environments": {
"dev": "environments/environments.ts",
"prod": "environments/environments.prod.ts"
}
Ответ 4
Проверьте свой пакет .json и убедитесь, что у вас нет строки для "angular -cli". Если вы это сделаете, удалите его и запустите: npm install. Это прояснилось для меня. Для ссылок в зависимостях была ссылка на "@ angular/cli". "@angular/cli" - новое местоположение для angular cli.