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
E2Eの過去・現在・未来 そしてE2Eにおいて重要なこと
Search
takayuki-hayashi
April 27, 2021
Technology
1
460
E2Eの過去・現在・未来 そしてE2Eにおいて重要なこと
Qiita × Uzabase Tech Meetup#1での発表資料です。
https://connpass.com/event/210103/
takayuki-hayashi
April 27, 2021
Tweet
Share
More Decks by takayuki-hayashi
See All by takayuki-hayashi
いかにしてテスト文化を醸成させたか.pdf
takayukihayashi
3
1.5k
リーダー、マネージャーが存在しない開発組織のつくり方
takayukihayashi
0
28k
AngularDartでDart入門
takayukihayashi
1
880
E2Eテスト駆動開発実践記_-_Web用.pdf
takayukihayashi
2
3.4k
KubernetesとGaugeを活用したTDD開発事例
takayukihayashi
0
890
FlutterとAngularDartを DIとClean Architectureで いい感じにする
takayukihayashi
3
2.2k
Gaugeによるe2eテスト
takayukihayashi
5
28k
Dartエコシステムの紹介
takayukihayashi
2
610
Other Decks in Technology
See All in Technology
Global Azure2025(GitHub Copilot ハンズオン)
tomokusaba
2
750
クラウドネイティブ環境の脅威モデリング
kyohmizu
2
410
猫でもわかるS3 Tables【Apache Iceberg編】
kentapapa
2
190
自動化の第一歩 -インフラ環境構築の自動化について-
smt7174
1
130
Google Cloud Next 2025 Recap 生成AIモデルとマーケティングでのコンテンツ生成 / Generative AI models and content creation in marketing
kyou3
0
170
Sleep-time Compute: LLM推論コスト削減のための事前推論
sergicalsix
1
120
試作とデモンストレーション / Prototyping and Demonstrations
ks91
PRO
0
110
ソフトウェアテスト 最初の一歩 〜テスト設計技法をワークで体験しながら学ぶ〜 #JaSSTTokyo / SoftwareTestingFirstStep
nihonbuson
PRO
1
150
問 1:以下のコンパイラを証明せよ(予告編) #kernelvm / Kernel VM Study Kansai 11th
ytaka23
3
510
さくらのクラウド開発の裏側
metakoma
PRO
2
1.2k
地に足の付いた現実的な技術選定から魔力のある体験を得る『AIレシート読み取り機能』のケーススタディ / From Grounded Tech Choices to Magical UX: A Case Study of AI Receipt Scanning
moznion
3
1.3k
genspark_presentation.pdf
haruki_uiru
1
250
Featured
See All Featured
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
32
2.3k
Producing Creativity
orderedlist
PRO
344
40k
Intergalactic Javascript Robots from Outer Space
tanoku
271
27k
BBQ
matthewcrist
88
9.6k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
34
2.9k
jQuery: Nuts, Bolts and Bling
dougneiner
63
7.7k
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
656
60k
ReactJS: Keep Simple. Everything can be a component!
pedronauck
667
120k
Embracing the Ebb and Flow
colly
85
4.7k
The Illustrated Children's Guide to Kubernetes
chrisshort
48
49k
Music & Morning Musume
bryan
47
6.5k
How to Think Like a Performance Engineer
csswizardry
23
1.6k
Transcript
1 E2Eの過去・現在・未来 そしてE2Eにおいて重要なこと
2 自己紹介 • プログラマー • 好きなもの ◦ XP(Extreme programming) ◦
TDD ◦ DDD • ユーザベースとの関わり ◦ 2013年にフリーランスとしてジョイン ◦ 2017年に正社員 ◦ 2018年 SPEEDA事業 執行役員CTO ◦ 2020年 BtoB SaaS事業 執行役員CTO • E2Eの取り組み歴は15年くらい • Twitter ◦ @t_hyssh 林 尚之 Takayuki Hayashi 株式会社ユーザベース BtoB SaaS事業 執行役員CTO
前提 3 E2Eテスト、自動テスト、UAT、受け入れテスト、インテグレーション テスト等いろいろな表現と意図がありますが、一旦今日はこれらを総称 して「E2Eテスト」という表現を使わせて頂きます。
2000年代〜 (E2E関連) 4 Selenium(2004年)、DBUnit(2002年)等の登場により特にWebア プリケーションにおいてE2Eテストの技術が登場しはじめる。 SeleniumにはSelenium IDEというFirefox用アドオンもあり、UI 上の操作をレコーディング&実行が出来た。 ※ただし当時のSelenium IDEだけだとリグレッションテストとして実行するのは難しかっ
た。一時期Selenium IDEの開発は停滞していたがここ数年開発が活発に。
5 しかしWebとDBのアサーションを含めたE2Eの技術 には技術習得コストとメンテナンスコストという課題が 存在。
課題 6 • Ajaxなどの非同期処理に対する画面テストの難しさ • 時間経過によるシステムの状態変化に対するテストの難しさ • DBのアサーションに関する難しさ ◦ 外部キー制約によるデータ作成
◦ Timestamp、日付のアサーション ◦ Sequence、Auto Incrementのアサーション ◦ 大量データのアサーション • テスト実行時間の長さ • テスト環境準備 このあたりの解決方法については別途何処かで話せれば・・・
2010年前後〜現在 (プロダクト関連) 7 RedisやMongoDBに代表されるNoSQLの利用、Elasticsearch等の全文検索 エンジン、デバイスの多様化(スマホのネイティブアプリ、スマホのWeb 及びデスクトップWeb)、マイクロサービス化等でシステム(プロダク ト)における内部構造の複雑性が増している。 RDB
2010年前後〜現在 (E2E関連) 8 • Web DriverがW3C勧告になる(2018年) • 機械学習を取り入れたE2Eの試み • Selenium関連の継続的な開発
◦ selenium-docker、selenide、etc... • Selenium以外のUIテストフレームワークやE2Eテストフレームワーク の登場&普及 ◦ cypress、Serenity、Gauge、WebdriverIO、Appium、etc...
9 プロダクト側での技術の多様化は進むなか、E2Eテス ト関係の技術も少しずつ変化してきている
10 また、ビジネスのスピードが速くなる中でいかに速く継 続的にリリースするかが重要視されるようになり、そ のためにいかにテストを自動化するかという点におい て関心が高まっている
Cypress io の例 11 cypressというWeb E2Eテストフレームワークを開発している会社 • 2015年設立 • 2018年に約4億円
• 2019年に約10億円 • 2020年末には約43億円を調達
12 投資家目線でもそこ(E2E)に大きなニーズがあり、ビ ジネスチャンスがあると捉えられている
Googleの例 13 「Googleでは全て(UI含む)のテストを自動化している」 JaSTT’18 Tokyoにて当時GoogleのCI/CD責 任者であった John Micco氏の発言
未来 14 ビジネスの変化への対応(迅速なリリース)のための重要性は増 していくはず。 ただし、E2Eの根本的な難易度の高さ、複雑さは今後も変わらな いしむしろ増していく可能性が高い。 ソフトウェア業界全体として急激にE2Eが浸透していくという可 能性は低いが、ゆっくりと確実に広がっていくはず。
未来 15 TDDも2000年代は 「Unitテストなんか必要ない」 という人も少なくなかったが、先にテストを書くかどうかは別と して「Unitテストは必要だよね」という考えが浸透してきてい る。例えばOSSにおいてもUnitTestが書かれてあるケースが2000 年代に比べて圧倒的に増えている。 E2Eは感覚としてUnitTestに比べて10年くらい後ろを走っている イメージ。UnitTestの浸透と同じようにE2Eもゆっくり、確実に
浸透していくのでは。
16 E2Eテストにおいて重要なこと
17 10数年E2Eテストと向き合ってきて最も重要だと思うこ と。それは・・・
18 「TDD」の考え
E2Eにおいて重要なこと 19 E2Eであったとしても最も重要なのはTDDの考え方。 • テストの独立性 • アサートファースト • アサーションの数 •
テストダブル これらをきちんと理解し、実践できなければすぐにフラジャイル なE2Eになってしまう。良いE2Eを書くにはまずは良いUnit Test を書けるようにスキルを磨くこと。 そして小さく始める事。小さく始めて常にGreenな状態を保つと いう強い意思を持つこと。
まとめ 20 • プロダクトの複雑性は増している • E2E技術も進化してきている • E2Eに対する関心、興味も増してきている • TDDの考え大事
21 ご清聴ありがとうございました