Взгляните на модуль optimist от Substack и nconf от . Многие мои тесты зависят от внешних параметров, а модули optimist и nconf упрощают загрузку параметров конфигурации из файла json.
В вашей тестовой команде укажите путь к файлу config.json
тестовая команда
mocha test/api-test.js --config=/path/to/config.json --reporter spec
api-test.js
var path = require('path')
var fs = require('fs')
var assert = require('assert')
var argv = require('optimist').demand('config').argv
var configFilePath = argv.config
assert.ok(fs.existsSync(configFilePath), 'config file not found at path: ' + configFilePath)
var config = require('nconf').env().argv().file({file: configFilePath})
var apiConfig = config.get('api')
var apiKey = apiConfig.key
config.json
{
"api": {
"key": "fooKey",
"host": "example.com",
"port": 9000
}
}
Альтернатива
Еще один шаблон, который я недавно использовал, - это модуль конфигурации . Вы можете указать ./config/default.yml
файл для регулярного запуска и ./config/test.yml
файл для тестов.
При запуске вашего набора тестов экспортируйте NODE_ENV = test, и модуль конфигурации загрузится test.yml
В вашем коде легко получить доступ к объекту конфигурации
var config = require('config')
var apiKey = config.api.key
Простой способ установить NODE_ENV = test - запустить тесты с помощью make-файла. Запустите все свои тесты через make test
. Чтобы запустить один тест, выполнитеmake one NAME=test/unit/sample-test.js
Образец make-файла
MOCHA?=node_modules/.bin/mocha
REPORTER?=spec
GROWL?=--growl
FLAGS=$(GROWL) --reporter $(REPORTER) --colors --bail
test:
@NODE_ENV="test" \
$(MOCHA) $(shell find test -name "*-test.js") $(FLAGS)
one:
@NODE_ENV="test" \
$(MOCHA) $(NAME) $(FLAGS)
unit:
@NODE_ENV="test" \
$(MOCHA) $(shell find test/unit -name "*-test.js") $(FLAGS)
integration:
@NODE_ENV="test" \
$(MOCHA) $(shell find test/integration -name "*-test.js") $(FLAGS)
acceptance:
@NODE_ENV="test" \
$(MOCHA) $(shell find test/acceptance -name "*-test.js") $(FLAGS)
.PHONY: test
env KEY1=YOUR_KEY1 KEY2=YOUR_KEY2 mocha test