У меня возникла проблема после проблемы с получением Behat для работы с Zombie.js. Проблема, с которой я столкнулся сейчас, действительно находится в модуле Zombie.js (раньше, ошибки были в связи между ними).Zombie.js с Behat и Mink
Ошибка выглядит так.
[RuntimeException]
Server process has been terminated: (8) [
url.js:107
throw new TypeError("Parameter 'url' must be a string, not " + typeof url)
^
TypeError: Parameter 'url' must be a string, not undefined
at Url.parse (url.js:107:11)
at urlParse (url.js:101:5)
at Object.urlResolve [as resolve] (url.js:405:10)
at History._resolve (/Users/nathanielh/www/website/node_modules/zombie/lib/zombie/history.coffee:201:20)
at History._assign (/Users/nathanielh/www/website/node_modules/zombie/lib/zombie/history.coffee:209:18)
at /Users/nathanielh/www/website/node_modules/zombie/lib/zombie/browser.coffee:326:30
at Browser.withOptions (/Users/nathanielh/www/website/node_modules/zombie/lib/zombie/browser.coffee:105:14)
at Browser.visit (/Users/nathanielh/www/website/node_modules/zombie/lib/zombie/browser.coffee:320:12)
at Socket.eval (eval at <anonymous> (/private/var/folders/fv/fp4xrfnx7kzfq2bqzywq5p9w00010f/T/mink_nodejs_serverSZBH0W:43:10), <anonymous>:2:9)
at Socket.<anonymous> (/private/var/folders/fv/fp4xrfnx7kzfq2bqzywq5p9w00010f/T/mink_nodejs_serverSZBH0W:43:5)
]
Я обнаружил, что в history.coffee
, функция resolve
пытается использовать элемент массива, который не существует.
// history.coffee
_resolve: (url)->
if url
return URL.resolve(@_stack[@_index]?.url, url)
else # Yes, this could happen
return @_stack[@_index]?.url
, что ссылка на @_stack[@_index]
решает неопределен, который затем передается в URL.resolve
, который затем вызывает ошибку.
Любая идея, почему это произойдет?
Update
Я заметил, что @_stack
пуст, и @_index
является -1
. Это не возможно, не так ли?
Какую версию nodejs вы используете? –