Итак, у меня есть проект с открытым исходным кодом (https://github.com/ahmednuaman/radian), и у меня есть несколько тестов e2e, которые запускаются отлично локально с помощью транспортира.
Я следил за документами Sauce Labs и настроил свой .travis.yml
соответственно. Тесты запускаются прямо до того момента, когда Protractor пытается подключиться к серверу selenium в Sauce Labs, это краткий снимок ошибки:
Running "exec:e2e" (exec) task
Using the selenium server at ahmednuaman-radian:06dd4e07-0f52-4fdf-be5e-389f2117bbf5@localhost:4445
>>
>> timers.js:103
>> if (!process.listeners('uncaughtException').length) throw e;
>> ^
>> TypeError: Cannot read property 'length' of undefined
>> at HttpClient.send (/home/travis/.nvm/v0.8.26/lib/node_modules/protractor/node_modules/selenium-webdriver/http/index.js:62:16)
Вот полный журнал вакансий: https://travis-ci.org/ahmednuaman/radian/jobs/16250460
Следующее, что я сделал, это попытался сымитировать это локально. Я прочитал документы Sauce Labs Connect и в конечном итоге запустил это в своем терминале:
java -jar ~/bin/Sauce-Connect.jar USERNAME PASSWORD
Все началось нормально, точно так же, как в Travis, но когда я затем выполнил свою grunt e2e
задачу (после обновление protractor.conf.coffee
для локального соответствия конфигурации Travis) и получил ту же ошибку, что и Трэвис, вот снимок:
Running "exec:e2e" (exec) task
Using the selenium server at ahmednuaman-radian:06dd4e07-0f52-4fdf-be5e-389f2117bbf5@localhost:4445
>>
>> /Users/ahmed/bin/node/lib/node_modules/protractor/node_modules/selenium-webdriver/lib/webdriver/promise.js:1542
>> throw error;
>> ^
>> TypeError: Cannot read property 'length' of null
>> at HttpClient.send (/Users/ahmed/bin/node/lib/node_modules/protractor/node_modules/selenium-webdriver/http/index.js:62:16)
У меня был Google, но я не мог найти никого с этой проблемой. Итак, это мой конфиг? Это проблема транспортира / веб-драйвера? Хотите пролить свет на это?