CasperJS+PhantomJS で Github Organization 移行
概要
Github Enterprise の Organization 移行を実施した際に CasperJS と PhantomJS でヘッドレスブラウザより操作し移行しました。
Github 上で API がない(はず?)為、この様な対応をしました。
どちらかというと CasperJS+PhantomJS でブラウザ上の試験作りを楽しんでいたこともあり
試してみてすんなりできたので採用した経緯になります。
ヘッドレスブラウザとは?
GUI なしのブラウザを CLI で利用するというもの。
ページ描画や画像ロード、ログインしたりとフロントの試験で期待される機能を持っています。
三行まとめ
- CasperJS + PhantomJS でログイン認証はじめブラウザ操作で Transfer する工程を実行
- 移行後、元の URL が移行先にリダイレクトされるか確認
- 期待する要素が時間内に取得できないときはページをキャプチャ
やってみる
Get Started ご参照ください。
以下にも手順まとめてます。
Clone
1 | macOS%$ git clone https://github.com/kenzo0107/ghe-org-transfer |
scripts/ghe-org-transfer.js の <your ****> 編集
1 | var config = { |
移行イメージ
- ex) hoge/mywonderfulrepo —> moge/mywonderfulrepo
1 | paths: [ |
paths は複数指定しても問題ありません。
移行実施
1 | macOS%$ make run |
- 実行結果
※ 移行後に元の URL でリダイレクトされるか試験しています。
1 | [url] https://github.aiueo.com/hoge/mywonderfulrepo/settings |
総評
以前 Grafana のグラフのスナップショットを撮る Grafana API がうまく動作しなかったのも
CasperJS+PhantomJS で取得する様にできました。
いやはや便利 ♪
全然別件ですが、サイトの認証に利用される reCAPTCHA の突破など挑戦してましたがうまく行かず…
うまくいったぜ!という方、是非教えてください m(_ _)m