jenkinsから起動する
jenkinsでnightwatchによる打鍵を定期実行したい。
chromeを使用したnightwatchはそのままでも上手く動作するけど、firefoxは全然上手くいかなかった。
がしかし、二つの設定でfirefoxでもnightwatchを動作させることが出来たので記す。
ちなみにstackOverFlowの解決策にあるような、
「headlessモードで動かせば解決するよ!」は真っ赤な嘘です。
・firefox.profile not found
・socket hang up
と出てJenkinsが動かない問題は解決します。
Jenkins Job
カスタムワークスペースにtestケースがあるディレクトリを指定し、
Node.jsが入っていればbatコマンド叩くことで動きます。
Jenkins setting
Jenkinsの実行ユーザを変更する
問題
windowsの場合、
Jenkinsをmsiからインストールした場合でも、tomcat上でwarを使用して動かした場合でも
デフォルトの状態では実行ユーザーは「authority\system」というユーザになっています。
自分でコマンドプロンプトからnightwatchを実行する時と同じように、「whoami」と入力してみてください。
自分がPCにログインした時のユーザで実行していると思います。
C:\Users\hoge>whoami desktop-puge6oe\hogeUser C:\Users\hoge>
一方で、Jenkinsのジョブでbatコマンドから「whoami」を実行させてみてください。
Jenkinsのコンソール出力に「authority\system」が表示されるはずです。
以上のことより、自分でnightwatchのコマンドを叩く場合と、Jenkinsによって実行してもらう場合とでは
ユーザが異なるため上手く実行されません。(firefoxのprofileが読み込めない)
対処
windowsのサービスを開き、
jenkinsをmsiを使用してインストールした方は「Jenkins」を、
jenkinsをtomcatを使用してwarから起動している方は「Apatch Tomcat」を、
右クリック→プロパティでプロパティ画面を開きます。
「ログオン」タブを選択して移動し、
ログオンの「ローカルシステムアカウント」についているラジオボタンを「アカウント」に変更します。
アカウント名は、先ほど自分でコマンドプロンプトから実行した「whoami」で表示されたユーザ名を使用します。
「確認」を押下して表示された「ユーザの選択」画面の「選択するオブジェクト名を入力してください」の枠に入力し、
「名前の解決」で正確なユーザ名を表示させてOKを押します。
パスワードは普段PCにログインしているときのパスワードになります。
「適用」を押下し、パスワードの認証に成功したら再起動を促されるので、
サービス画面に戻って「サービスの再起動」を行います。
ちなみに、アカウントを変更して再起動をした場合、Jenkinsのユーザ作成も最初からになります。
(そのアカウントに紐づくJenkins設定を行うので)
もう一度「ローカルシステムアカウント」に戻すと前の設定の状態に戻ります。
C:\Users\USERNAME\.jenkins
「ローカルシステムアカウント」で設定されたJenkins情報
C:\Windows\System32\config\systemprofile\.jenkins
Jenkinsで再度「whoami」と実行させてみてください。実行ユーザが変更されているはずです。
解決すること
profileが読み込めずエラーとなることが解決します。
※日本語が文字化けしていますが、問題はないです。
ユーザーadminが実行 ビルドします。 ワークスペース: C:\nightwatch\nightwatch_windows_firefox [nightwatch_windows_firefox] $ cmd /c call C:\opt\jenkins\temp\jenkins3321322892247792250.bat C:\nightwatch\nightwatch_windows_firefox>node nightwatch [0;36m[Google] Test Suite[0m [0;35m===================[0m [1;31m Response 500 POST /wd/hub/session (201ms)[0m { state: [32m'unknown error'[39m, sessionId: [1mnull[22m, value: { systemInformation: [32m'System info: host: \'DESKTOP-JIOS6OE\', ip: \'192.168.1.9\', os.name: \'Windows 10\', os.arch: \'amd64\', os.version: \'10.0\', java.version: \'1.8.0_181\''[39m, screen: [1mnull[22m, message: [32m'Firefox profile \'nightwatch\' named in system property \'webdriver.firefox.profile\' not found'[39m, error: [ [32m'Build info: version: \'3.4.0\', revision: \'unknown\', time: \'unknown\''[39m, [32m'System info: host: \'DESKTOP-JIOS6OE\', ip: \'192.168.1.9\', os.name: \'Windows 10\', os.arch: \'amd64\', os.version: \'10.0\', java.version: \'1.8.0_181\''[39m, [32m'Driver info: driver.version: FirefoxDriver'[39m ] }, status: [33m13[39m } [1;31m[0;31m An error occurred while retrieving a new session: "Firefox profile 'nightwatch' named in system property 'webdriver.firefox.profile' not found"[0m [0;90m at endReadableNT (_stream_readable.js:1103:12) at process._tickCallback (internal/process/next_tick.js:63:19)[0m[0m [1;31m_________________________________________________[0m [1;31mTEST FAILURE:[0m [0;31m1[0m error during execution [0;31m0[0m tests failed, [0;32m0[0m passed. 1.596s [0;31m テ� google[0m [0;31m An error occurred while retrieving a new session: "Firefox profile 'nightwatch' named in system property 'webdriver.firefox.profile' not found"[0m [0;90m at endReadableNT (_stream_readable.js:1103:12) at process._tickCallback (internal/process/next_tick.js:63:19)[0m [0;36m SKIPPED:[0m - Demo test Google C:\nightwatch\nightwatch_windows_firefox>exit 5 Build step 'Windowsバッチコマンドの実行' marked build as failure Finished: FAILURE
firefox setting
socket hang up問題
こっちが結構難問でした。
nightwatchというよりfirefoxの問題でした。
問題
コマンドプロンプトから手動実行だと正常にブラウザの自動打鍵がされるのに、
Jenkinsから実行しようとすると「socket hang up」エラーとなる。
対処
「security.sandbox.content.level」をデフォルトの3から4に変更する。
この設定で、firefoxの実行できる動作が制限されているようです。
nightwatchで使用するprofileでブラウザを起動し、
URL入力個所に「about:config」と入力して「→」を押します。
すると、firefoxについての触っちゃいけないような設定がずらっと並んでいるところに移動します。
検索窓に「security.sandbox.content.level」と入力すると、フィルターが掛けられて該当の設定が表示されます。
初期設定値として「3」となっています。
ダブルクリックして値を「4」に変更します。
ブラウザを閉じます。
解決すること
nightwatch実行時の「socket hang up」が解決します。
ユーザーadminが実行 ビルドします。 ワークスペース: C:\nightwatch\nightwatch_windows_firefox [nightwatch_windows_firefox] $ cmd /c call C:\opt\jenkins\temp\jenkins5634969097704804633.bat C:\nightwatch\nightwatch_windows_firefox>node nightwatch [0;36m[Google] Test Suite[0m [0;35m===================[0m Running: [0;32mDemo test Google[0m [1;31m POST /wd/hub/session/b5820d37-faad-405a-b49f-746576950a4d/url - ECONNRESET Error: socket hang up at createHangUpError (_http_client.js:323:15) at Socket.socketCloseListener (_http_client.js:364:25)[0m [1;31m[0;31m Cannot read property 'status' of undefined[0m [0;90m at Socket.socketCloseListener (_http_client.js:364:11)[0m[0m [1;31m[0;31m Cannot read property 'status' of undefined[0m [0;90m at Socket.socketCloseListener (_http_client.js:364:11)[0m[0m [0;31mFAILED:[0m [0;31m1[0m errors (1m 0s / 60020ms) [1;31m[0;31m Cannot read property 'status' of undefined[0m [0;90m at Socket.socketCloseListener (_http_client.js:364:11)[0m[0m [1;31m DELETE /wd/hub/session/b5820d37-faad-405a-b49f-746576950a4d - ECONNRESET Error: socket hang up at createHangUpError (_http_client.js:323:15) at Socket.socketCloseListener (_http_client.js:364:25)[0m [1;31m[0;31m Cannot read property 'status' of undefined[0m [0;90m at Socket.socketCloseListener (_http_client.js:364:11)[0m[0m [1;31m DELETE /wd/hub/session/b5820d37-faad-405a-b49f-746576950a4d - ECONNRESET Error: socket hang up at createHangUpError (_http_client.js:323:15) at Socket.socketCloseListener (_http_client.js:364:25)[0m [1;31m[0;31m Cannot read property 'status' of undefined[0m [0;90m at Socket.socketCloseListener (_http_client.js:364:11)[0m[0m [1;31m DELETE /wd/hub/session/b5820d37-faad-405a-b49f-746576950a4d - ECONNRESET Error: socket hang up at createHangUpError (_http_client.js:323:15) at Socket.socketCloseListener (_http_client.js:364:25)[0m [1;31m[0;31m Cannot read property 'status' of undefined[0m [0;90m at Socket.socketCloseListener (_http_client.js:364:11)[0m[0m [1;31m DELETE /wd/hub/session/b5820d37-faad-405a-b49f-746576950a4d - ECONNRESET Error: socket hang up at createHangUpError (_http_client.js:323:15) at Socket.socketCloseListener (_http_client.js:364:25)[0m [1;31m[0;31m Cannot read property 'status' of undefined[0m [0;90m at Socket.socketCloseListener (_http_client.js:364:11)[0m[0m [1;31m_________________________________________________[0m [1;31mTEST FAILURE:[0m [0;31m1[0m error during execution [0;31m0[0m tests failed, [0;32m0[0m passed. 5m 8s [0;31m Cannot read property 'status' of undefined[0m [0;90m at Socket.socketCloseListener (_http_client.js:364:11)[0m C:\nightwatch\nightwatch_windows_firefox>exit 1 Build step 'Windowsバッチコマンドの実行' marked build as failure Finished: FAILURE
まとめ
自分の場合はこれで無事にJenkinsからfirefoxを用いたnightwatchを実行させることが出来ました。
ノーマルとheadlessどちらも実行しましたが、どちらも上手くいきました。
ノーマルで実行した場合でもブラウザは画面上に表示されず、裏でやっているみたいです。
処理を軽くするならheadlessにした方がいいですね。
ユーザーadminが実行 ビルドします。 ワークスペース: C:\nightwatch\nightwatch_windows_firefox [nightwatch_windows_firefox] $ cmd /c call C:\opt\tomcat\apache-tomcat-9.0.11-windows-x64\apache-tomcat-9.0.11\temp\jenkins6247224014386976112.bat C:\nightwatch\nightwatch_windows_firefox>node nightwatch [0;36m[Google] Test Suite[0m [0;35m===================[0m Running: [0;32mDemo test Google[0m [0;32m竏�[0m Element <body> was visible after 68 milliseconds. [0;32m竏�[0m Testing if the page title equals "Google" - 12 ms. [0;32m竏�[0m Testing if element <input[type=text]> is visible - 40 ms. [0;32m Warning: More than one element (2) found for <input[name=btnK]> with selector: "input[name=btnK]". Only the first one will be used.[0m [0;32m竏�[0m Element <input[name=btnK]> was visible after 600 milliseconds. [0;32mOK.[0m [0;32m4[0m assertions passed. (3.811s) C:\nightwatch\nightwatch_windows_firefox>exit 0 Finished: SUCCESS
参考
Windows上のJenkinsを特定のユーザーで実行する
「security.sandbox.content.level」について公式の説明
Not able to Execute Selenium scripts using Jenkins with latest Firefox browser V59 & Gecko Driver
Not able to run Firefox with geckodriver and jenkins slave machine as windows service