UNPKG

1.73 kBJavaScriptView Raw
1var fs = require('graceful-fs')
2var path = require('path')
3
4var helper = require('./helper')
5var log = require('./logger').create('plugin')
6
7var IGNORED_PACKAGES = ['karma-cli', 'karma-runner.github.com']
8
9exports.resolve = function (plugins, emitter) {
10 var modules = []
11
12 var requirePlugin = function (name) {
13 log.debug('Loading plugin %s.', name)
14 try {
15 modules.push(require(name))
16 } catch (e) {
17 if (e.code === 'MODULE_NOT_FOUND' && e.message.indexOf(name) !== -1) {
18 log.error('Cannot find plugin "%s".\n Did you forget to install it?\n' +
19 ' npm install %s --save-dev', name, name)
20 } else {
21 log.error('Error during loading "%s" plugin:\n %s', name, e.message)
22 }
23 emitter.emit('load_error', 'plug_in', name)
24 }
25 }
26
27 plugins.forEach(function (plugin) {
28 if (helper.isString(plugin)) {
29 if (plugin.indexOf('*') === -1) {
30 requirePlugin(plugin)
31 return
32 }
33 var pluginDirectory = path.normalize(path.join(__dirname, '/../..'))
34 var regexp = new RegExp('^' + plugin.replace('*', '.*'))
35
36 log.debug('Loading %s from %s', plugin, pluginDirectory)
37 fs.readdirSync(pluginDirectory).filter(function (pluginName) {
38 return IGNORED_PACKAGES.indexOf(pluginName) === -1 && regexp.test(pluginName)
39 }).forEach(function (pluginName) {
40 requirePlugin(pluginDirectory + '/' + pluginName)
41 })
42 return
43 }
44 if (helper.isObject(plugin)) {
45 log.debug('Loading inlined plugin (defining %s).', Object.keys(plugin).join(', '))
46 modules.push(plugin)
47 return
48 }
49 log.error('Invalid plugin %s', plugin)
50 emitter.emit('load_error', 'plug_in', plugin)
51 })
52
53 return modules
54}