Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Macインスタンスを活用したアプリE2Eテストの実現
Search
coconala_engineer
June 20, 2024
Technology
1k
1
Share
Macインスタンスを活用したアプリE2Eテストの実現
AWS Summit Japan 2024ミニステージの登壇資料。
https://aws.amazon.com/jp/summits/japan/
coconala_engineer
June 20, 2024
More Decks by coconala_engineer
See All by coconala_engineer
マルチロールEMが実践する「組織のレジリエンス」を高めるための組織構造と人材配置戦略
coconala_engineer
3
1.4k
『誰の責任?』で揉めるのをやめて、エラーバジェットで判断するようにした ~感情論をデータで終わらせる、PMとエンジニアの意思決定プロセス~
coconala_engineer
2
2.2k
SREのプラクティスを用いた3領域同時 マネジメントへの挑戦 〜SRE・情シス・セキュリティを統合した チーム運営術〜
coconala_engineer
2
1.8k
「守りのIT」から「攻めの基盤」へ!上場前後でやりきった情シス・モダナイゼーション
coconala_engineer
0
130
障害対応訓練、その前に
coconala_engineer
0
360
生成AI時代を勝ち抜くエンジニア組織マネジメント
coconala_engineer
0
50k
AI時代を生き抜く 新卒エンジニアの生きる道
coconala_engineer
1
890
SwiftTestingによる_モダンなiOSテスト手法とBDD.pdf
coconala_engineer
0
390
SRE × マネジメントレイヤーが挑戦した組織・会社のオブザーバビリティ改革 ― ビジネス価値と信頼性を両立するリアルな挑戦
coconala_engineer
0
1.2k
Other Decks in Technology
See All in Technology
データ分析基盤の信頼を支える視点と設計
yuki_saito
2
760
Claude code Orchestra
ozakiomumkj
2
310
人が担う「価値」とは?これからの「QA」とは / Human Value and the Future of Quality Assurance
bitkey
PRO
0
130
ITエンジニアを取り巻く環境とキャリアパス / A career path for Japanese IT engineers
takatama
4
1.8k
食べログのサーキットブレーカー導入を振り返って
atpons
1
150
GitHub Copilot CLI の Rubber Duck 機能を使ってコーディングの品質をあげよう #techbaton_findy
stefafafan
2
1.2k
TROCCOで始めるクラウドコストを民主化するためのFinOps
tk3fftk
1
280
Agentic AI時代における メルカリのAIガバナンスとガードレール実装
naoichihara
16
17k
RubyでRuby拡張を書いたらRubyより35倍速になったってどういうこと??
kazuho
3
920
テストコードのないプロジェクトにテストを根付かせる
tttol
0
220
速さだけじゃない! VoidZero ツールが移行先に選ばれる理由
mizdra
PRO
6
660
大規模災害時でも高い信頼性を維持するアプリケーション基盤の実現/nikkei-tech-talk46
nikkei_engineer_recruiting
0
110
Featured
See All Featured
The AI Revolution Will Not Be Monopolized: How open-source beats economies of scale, even for LLMs
inesmontani
PRO
3
3.5k
Producing Creativity
orderedlist
PRO
348
40k
30 Presentation Tips
portentint
PRO
1
300
Practical Orchestrator
shlominoach
191
11k
職位にかかわらず全員がリーダーシップを発揮するチーム作り / Building a team where everyone can demonstrate leadership regardless of position
madoxten
62
54k
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
254
22k
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
12
1.2k
Primal Persuasion: How to Engage the Brain for Learning That Lasts
tmiket
0
350
"I'm Feeling Lucky" - Building Great Search Experiences for Today's Users (#IAC19)
danielanewman
231
23k
SERP Conf. Vienna - Web Accessibility: Optimizing for Inclusivity and SEO
sarafernandez
2
1.5k
技術選定の審美眼(2025年版) / Understanding the Spiral of Technologies 2025 edition
twada
PRO
118
120k
Reality Check: Gamification 10 Years Later
codingconduct
0
2.2k
Transcript
Copyright coconala Inc. All Rights Reserved. Macインスタンスを活用した アプリE2Eテストの実現 株式会社ココナラ 川崎
雄太 2024/06/21 AWS Summit Japan 2024 ミニステージ
Copyright coconala Inc. All Rights Reserved. 自己紹介 2 川崎 雄太 Yuta
Kawasaki @yuta_k0911 株式会社ココナラ システムプラットフォーム部 部長 / Head of Information SRE / 情シス / セキュリティ領域のEM SRE NEXT 2024のコアメンバー 去年の自慢: PR TIMESに3回載った✨
Copyright coconala Inc. All Rights Reserved. 3 ココナラの事業内容
Copyright coconala Inc. All Rights Reserved. ココナラのエンジニア数の変遷 4 事業拡大に合わせて 3年で約3倍の組織規模に成長
2020年 2023年 フェーズ 上場前 上場後 エンジニア数 20人強 70人強 リポジトリ数 45 170以上
Copyright coconala Inc. All Rights Reserved. 5 Agenda アプリE2Eテスト導入の背景 ココナラ流アプリE2Eテスト
導入してみてどうだったか? 2 1 3
Copyright coconala Inc. All Rights Reserved. アプリE2Eテスト導入の背景 Chapter 01 6
Copyright coconala Inc. All Rights Reserved. もともとココナラでは、ある時期まで アプリのリグレッションテストを すべて手動 で行っていた。
アプリの機能数が少なかった頃は あまり問題になっていなかったが、 アプリの機能は増える一方🤔 7
Copyright coconala Inc. All Rights Reserved. プロダクトはどんどん成長していき、 アプリの機能がどんどん増え続け、 手動テストに要する時間も延びた 💦
さらには手動でテストしきれず、 品質面での問題が顕在化 する こともあった。 8
Copyright coconala Inc. All Rights Reserved. 今後はどうなっていく予測になるか? 9 自動化による範囲が大きくなればなるほど、効率化が大事 前述の通り、もともとは手動テストで何
とかなっていたものの、プロダクトの成 長により、手段としての自動テスト の効果が大きくなる構図となった。 このような状況をふまえて、ココナラで はアプリのE2Eテスト自動化に大き く舵を切っていくこととなった。
Copyright coconala Inc. All Rights Reserved. ココナラ流アプリ E2Eテスト Chapter 02
10
Copyright coconala Inc. All Rights Reserved. アプリE2Eテストの環境 11 Amazon EC2(Macインスタンス)などを組み合わせて構成
AWS Chatbot AWS Lambda Amazon EC2
Copyright coconala Inc. All Rights Reserved. アプリE2Eテストの処理の流れ 12 さまざまなものをインテグレートして、実現している 1.
Slack上でデバイス、テスト内容などを入力。入力後、AWS Chatbotが起動し、AWS Lambdaを呼び出す。 2. AWS LambdaがExpressにリクエストを送信。 3. Expressがテスト制御プロセスを起動し、メッセージを送信。 4. テスト制御プロセスがアプリをビルドし、デバイスやAppium を起動。テストランナーであるJestを実行。 5. テスト状況がSlack、ReportPortalにレポートされる。
Copyright coconala Inc. All Rights Reserved. 採用した技術 13 役割 採用したもの
採用理由 オートメーション Appium Detoxと比較し、アプリの対応度合い・相 性が良かった。 WebdriverIO Appiumのクライアントで使用。 テストランナー Jest 拡張性を重視。 テスト言語 TypeScript テストの書きやすさを重視。 テスト結果可視化 ReportPortal Allureと比較し、大量のテスト結果可視 化に優れていた。 テストサーバー Amazon EC2 mac2 各種CIサービスと比較し、コストパフォー マンスに優れていた。
Copyright coconala Inc. All Rights Reserved. アプリE2Eテストの内容 14 リリース前に手動で行っていたテストの約 85%を自動化
• たとえば、以下のテストを自動化。 ◦ メールで会員登録できること ◦ Googleで会員登録できること ◦ ログインできること ◦ サービスが出品できること ◦ サービスをクレジットカードで購入できること ◦ サービスをポイントで購入できること
Copyright coconala Inc. All Rights Reserved. アプリE2Eテストのコードサンプル 15
Copyright coconala Inc. All Rights Reserved. E2Eテストが実際に動いているところ 16 1. Slackのフォームを開き、テスト対
象のデバイス、ブランチ、テスト内 容などを入力します。
Copyright coconala Inc. All Rights Reserved. E2Eテストが実際に動いているところ 17 2. 入力をトリガーにテストが開始さ
れます。
Copyright coconala Inc. All Rights Reserved. E2Eテストが実際に動いているところ 18 3. テストの進行状況がリアルタイ
ムで表示されます。
Copyright coconala Inc. All Rights Reserved. E2Eテストが実際に動いているところ 19 4. テストが完了すると、結果のサ
マリとレポートのリンクが表示さ れます。
Copyright coconala Inc. All Rights Reserved. E2Eテストが実際に動いているところ 20 5. レポートのリンクを開くと、
ReportPortalで操作内容とスク リーンショットが確認できます。
Copyright coconala Inc. All Rights Reserved. E2Eテストが実際に動いているところ 21 6. 録画データをダウンロード、再
生することもできます。
Copyright coconala Inc. All Rights Reserved. E2Eテストが実際に動いているところ 22 7. さらに、過去のテスト結
果を含めた統計データ を確認することもできま す。
Copyright coconala Inc. All Rights Reserved. E2Eテストが実際に動いているところ 23 8. ReportPortalでは実施
したテストの属性の設定 や、FAILED内容の分類 もできます。
Copyright coconala Inc. All Rights Reserved. E2Eテストが実際に動いているところ 24 9. 設定した属性やFail内
容の分類を用いて、 E2Eテストの成功率や FAILED内容の割合な どのメトリクスを可視化 しています。
Copyright coconala Inc. All Rights Reserved. 導入してみてどうだったか? Chapter 03 25
Copyright coconala Inc. All Rights Reserved. 定量的に効果を得ることができた! 26 工数削減だけでなく、品質向上に寄与することができた •
リリース前にバグを検知できた回数:5回 ◦ サービス詳細画面が開けない ◦ サービス検索で絞り込みできない。 ◦ 見積もり相談に対して提案できない • リリース後、早期にバグを検知できた回数:3回
Copyright coconala Inc. All Rights Reserved. テックブログの記事もたくさんの方に見てもらえた! 27 「アプリ e2e」で検索すると
1位と4位に記事が載っている
Copyright coconala Inc. All Rights Reserved. Web E2Eテストにも同じ仕組みを展開した! 28 実は「web
e2e」で検索しても 1位に記事が載っている
Copyright coconala Inc. All Rights Reserved. アプリのE2Eテスト基盤に Amazon EC2(Macインスタンス)を 採用することで、費用対効果の高い
E2Eテストを実現できました!💡 ぜひ、参考になれば幸いです!😁 29
Fin
Copyright coconala Inc. All Rights Reserved. Appendix 31
Copyright coconala Inc. All Rights Reserved. 参考資料 32 • E2Eテストに関する記事
◦ Android / iOSアプリのE2Eテスト全部で250シナリオを 自動化しました! 第1回 全体像 ◦ Android / iOSアプリのE2Eテスト自動化の運用保守で 日々格闘しているお話 ◦ WebのE2Eテスト自動化〜ツール選定編〜 • E2Eテストに関する登壇資料 ◦ WebのE2Eテスト自動化 〜導入から運用・評価までの 道のり編〜 - Speaker Deck