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
UIテストにおけるRxIdlerが便利だった話
Search
yu mitsuhori
July 26, 2018
Programming
0
520
UIテストにおけるRxIdlerが便利だった話
AndroidでUIテストをするときの悩みとしてアサーション前に非同期処理を待ってくれないことがあります。RxIdlerを使うとRxJavaにおける非同期処理もいい感じに待ってくれます。
yu mitsuhori
July 26, 2018
Tweet
Share
More Decks by yu mitsuhori
See All by yu mitsuhori
【DroidKaigi版】ReactNativeとKotlinで叶える夢のリアルタイム音声配信
youmitsu
1
3.2k
ReactNativeとKotlinで叶える夢のリアルタイム音声配信
youmitsu
1
880
stand.fm(Android)におけるreact-native-track-playerの改善
youmitsu
1
2.1k
TargetSdkVersion29で BottomNavigationが点滅する件
youmitsu
1
1.5k
リリース前のリグレッションテストをUIテストで自動化、1年間運用した話
youmitsu
2
390
New features in RemoteConfig, Analytics at Google I/O 2019
youmitsu
1
720
FirebaseNotification,RemoteConfigでユーザセグメントごとにプッシュ通知を実装する
youmitsu
8
1.5k
Report from Google I/O 2019
youmitsu
1
100
OSSにコントリビュートした話
youmitsu
1
94
Other Decks in Programming
See All in Programming
プロダクト開発をAI 1stに変革する〜SaaS is dead時代で生き残るために〜 / AI 1st Product Development
kobakei
0
490
なぜあの開発者はDevRelに伴走し続けるのか / Why Does That Developer Keep Running Alongside DevRel?
nrslib
3
370
株式会社 Sun terras カンパニーデック
sunterras
0
220
育てるアーキテクチャ:戦い抜くPythonマイクロサービスの設計と進化戦略
fujidomoe
1
150
AIで開発生産性を上げる個人とチームの取り組み
taniigo
0
130
クラシルを支える技術と組織
rakutek
0
190
AIエージェント時代における TypeScriptスキーマ駆動開発の新たな役割
bicstone
4
1.5k
詳しくない分野でのVibe Codingで困ったことと学び/vibe-coding-in-unfamiliar-area
shibayu36
3
4.4k
Serena MCPのすすめ
wadakatu
4
900
開発生産性を上げるための生成AI活用術
starfish719
1
170
GraphQL×Railsアプリのデータベース負荷分散 - 月間3,000万人利用サービスを無停止で
koxya
1
1.1k
Swift Concurrency - 状態監視の罠
objectiveaudio
2
450
Featured
See All Featured
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
132
19k
Stop Working from a Prison Cell
hatefulcrawdad
271
21k
The Cult of Friendly URLs
andyhume
79
6.6k
Designing Experiences People Love
moore
142
24k
Writing Fast Ruby
sferik
629
62k
Visualizing Your Data: Incorporating Mongo into Loggly Infrastructure
mongodb
48
9.7k
What’s in a name? Adding method to the madness
productmarketing
PRO
23
3.7k
Navigating Team Friction
lara
189
15k
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
26
3.1k
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
54
3k
Automating Front-end Workflow
addyosmani
1371
200k
Fireside Chat
paigeccino
40
3.7k
Transcript
UI テストにおけるRxIdler が便利だった話 @1013Youmeee
アジェンダ アジェンダ 1. UI テストとは 2. UI テストのつらみ 3. よくある解決策
4. RxIdler の紹介 5. まとめ
軽く自己紹介 軽く自己紹介 三堀 裕 株式会社エムティーアイ所属 社会人2 年目 Android アプリエンジニア 外部LT
初登壇( 汗) Twitter: @1013Youmeee Qiita: GitHub: https://qiita.com/youmeee https://github.com/youmitsu
話すこと 話すこと 前提 RxJava を使ってAPI コールなどの非同期処理をし ているAndroid アプリ UI テストで、いい感じに非同期処理を待たせる
「RxIdler 」というライブラリの紹介
誰得? 誰得? Android でUI テストをやってみたいと思っている方 RxJava を使っているアプリで、UI テストでの非同期 処理に困っている方
背景 背景 仕事で担当するアプリにおいてシナリオテストを自 動化 非同期処理をうまく同期的にテストする仕組みが欲 しい Android TestNight に参加した時、DeNA のSWET
の 方にRxIdler が良いというお話を聞いたので試して みたらいい感じだった
UI テストとは UI テストとは 画面内に特定のUI コンポーネントがあるかどうか このボタンを押した後にこの画面が表示されるか などの実際に実機で操作する時のアプリの挙動をテス トできるもの
ANDROID におけるUI テスト ANDROID におけるUI テスト Android でUI テストを行う上で、主に二つの仕組み InstrumentalTest
Espresso
UnitTest のようなJVM 上で動作するテストと違い、 Android の実機でテストをする仕組み。 導入方法は以下を参照 https://developer.android.com/training/testing/ui- testing/espresso-testing
Android のUI テスト用のフレームワーク。 リソースのid などを使用したUI の取得 UI に対するアクション(タップ、スクロールなど) アサーション( 表示されているか、文字が正しいか
など) https://developer.android.com/training/testing/espre
UI テストのつらみ UI テストのつらみ API リクエストなどの非同期処理後の画面反映を待た ずに、 次のリソースの取得、アサーションに映ってしまいテ ストが失敗してしまう ※AsyncTask
やMessageQueue などは待ってくれる
具体例 具体例 @Test fun testNotWaitFailed() { /** * API */
// onView(allOf(withId(R.id.data_str), isDisplayed())) .check(matches(withText("completed"))) }
主な解決策3 つ 主な解決策3 つ 1. sleep を使って待つパターン 2. 反映されるまでリトライするラッパークラスを作る パターン
3. UI の状態で判断するパターン(IdlingResources) Idling Resources についてはこちらを参照
どのパターンもそれぞれ辛い... 辛い理由はQiita に載せます
本題 本題 ~そこでRxIdler ~
の概要 の概要 Square 製のライブラリ(Jake) IdlingResources をラップしている RxJava の非同期処理をしている別スレッド上の処 理をしているとき、IdlingResource をincrement
及 びdecrement する 単純な宣言 https://github.com/square/RxIdler
インストール インストール に以下を記述 androidTestImplementation 'com.squareup.rx.idler:rx2-idler:0.9.0'
コード例 コード例 が付いているメソッド内でRxJavaPlugins を 使って、RxIdler のスケジューラを定義するだけ @Before fun setUp() {
// //RxJava Scheduler (Schedulers.io RxJavaPlugins.setInitIoSchedulerHandler( Rx2Idler.create("RxJava 2.x Io Scheduler") ) }
メリット・デメリット メリット・デメリット
メリット メリット テストがとても効率的に実行可能 とても簡単 TestRunner の初期化時に一行書くだけ RxJava での非同期処理にIdlingResources を適用 してくれる
プロダクトコードをいじらなくて済む
デメリット・注意点 デメリット・注意点 RxJava でしか使えない。 たまに待ってくれない箇所もある。(WebView にお いてフックするURL を待っている時など) サンプルを作ろうとしたが、RxIdler を使わなくて
も勝手に待ってくれることもあったりするので、も う少しRxIdler で対応できるところ、できないとこ ろを明確にしていきたい
まとめ まとめ RxIdler を使うとRxJava での非同期処理をよしなに して待ってくれるので便利 たまに待ってくれない箇所もあるため、一旦実行し てみて落ちるようなあればsleep するなどの対策が 必要かも?
参考 参考 こちらの資料などを参考にさせていただきました RxJava のアプリをEspresso でテストする簡単な方 法 Test apps on
Android -Android Developer- Espresso で アイドリング