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
Four Tips for More Testable UI
Search
Jim Holmes
March 17, 2019
Technology
0
37
Four Tips for More Testable UI
Quick talk given at the 2019 Microsoft MVP summit during the ALM group's MVP2MVP sessions.
Jim Holmes
March 17, 2019
Tweet
Share
More Decks by Jim Holmes
See All by Jim Holmes
Adapting to Change in Software Delivery
jimholmes
0
12
Public_Speaking.pdf
jimholmes
0
41
Trusted System Boundaries
jimholmes
0
59
What's Worse? Zombies or Brittle UI Tests?
jimholmes
0
79
Odd Parallels Between Weightlifting and Software Delivery
jimholmes
0
37
Is Quality The Bottleneck?
jimholmes
0
83
Don't Fear Leadership
jimholmes
0
43
Intro To TDD
jimholmes
1
42
Honor Flight #20 (Bay Area) Recap
jimholmes
0
97
Other Decks in Technology
See All in Technology
Hands-on / Kaname Frusawa / Cloud Compare Users Meetup 2024 at University of Tokyo on April 17
paraworld
2
470
Algyan イベント振り返り
linyixian
0
180
Data and AI Governance: Existing Challenges and Emerging Trends
scotthsieh825
0
140
Databricksを活用してDELISH KITCHENのレシピレコメンドを開発した話
furu8
0
250
レガシーをぶっ壊せ。AEONで始めるDevRelの話 / Qiita Night 2024-2-22
aeonpeople
3
100
Aurora MySQL v3(MySQL8.0互換)の オンラインDDLの罠挙動を全バージョンで検証した
yutakikai
0
150
次世代Web認証「パスキー」 / mo-zatsudan-passkey
nkzn
22
13k
コンテナセキュリティの基本と脅威への対策
kyohmizu
3
660
Databricks におけるデータエンジニアリング
databricksjapan
0
370
Apple Vision Pro trial session
akkeylab
0
120
インシデントレスポンスのライフサイクルを廻すポイントってなに / Pinpoints of Incidentresponse Lifecycle for Operation
sakaitakeshi
0
290
反実仮想機械学習とは何か
usaito
PRO
6
1.3k
Featured
See All Featured
Agile that works and the tools we love
rasmusluckow
323
20k
Building Flexible Design Systems
yeseniaperezcruz
318
37k
Web development in the modern age
philhawksworth
201
10k
How to train your dragon (web standard)
notwaldorf
71
5.1k
The Cost Of JavaScript in 2023
addyosmani
13
3.8k
Web Components: a chance to create the future
zenorocha
304
41k
Statistics for Hackers
jakevdp
789
220k
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
13
1.5k
Designing with Data
zakiwarfel
95
4.8k
Fantastic passwords and where to find them - at NoRuKo
philnash
36
2.5k
A Philosophy of Restraint
colly
195
16k
10 Git Anti Patterns You Should be Aware of
lemiorhan
645
57k
Transcript
Testable UIs
Or: How to help your test automation folks drink less
[email protected]
@aJimHolmes
Fortune 10 client Java 6 Enterprise-ready components HP build and
SCM tools “What’s a unit test?”
Thank you ET
Generalized Talk Ideas apply to all UI and automation tools
https://github.com/jimholmes/ Demo-Site
Two main problems in all UI testing
Finding Stuff
Async
Also SharePoint
Finding stuff == Locators
For Web, prefer: IDs CSS/JQuery-ish Name Custom Attributes
As a last resort: XPath
None
Create Good Locators
0) Own Your HTML
None
None
None
FindElement.ById(“grid”)
None
None
1) Understand your controls / frameworks
None
None
None
FindElement.ByCss( “some big stupid CSS string”)
Someone changes style
None
None
None
FindElement.ById( “update-btn”)
2) Tweak dynamic data
None
Find elements by text content. Might not be granular enough.
None
None
No useful attributes
None
None
None
ID is position-based. Data changes, IDs change.
None
We own the code!
Is there some useful data in your objects?
None
None
None
None
None
FindElement.ById( contains(“Cobb”) )
“Name” isn’t all that useful. Got contract numbers? Project IDs?
Other stuff? Find good metadata!
3) Make complex async less painful
None
SharePoint
wait until expected condition 1 wait until expected condition 2
IF SOMETHING wait until expected condition 3 IF SOMETHING ELSE wait until expected condition 4 FINALLY wait until expected condition 342
We own the code!
Create “flags” when async is complete
None
None
None
None
None
Wait until flags.div(responseType=create) exists
0) Add static IDs 1) Tweak controls 2) Use data
for locators 3) Build flags/latches for complex async
None
https://github.com/jimholmes/ Demo-Site