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
SpecFlow 實務經驗分享
Search
LittleLin
April 20, 2017
Programming
1
1.3k
SpecFlow 實務經驗分享
LittleLin
April 20, 2017
Tweet
Share
More Decks by LittleLin
See All by LittleLin
如何使用 OData 來加速測試效率
kobayashi
0
1.2k
Other Decks in Programming
See All in Programming
開発チーム・開発組織の設計改善スキルの向上
masuda220
PRO
20
11k
個人軟體時代
ethanhuang13
0
320
AIコーディングAgentとの向き合い方
eycjur
0
270
rage against annotate_predecessor
junk0612
0
170
Deep Dive into Kotlin Flow
jmatsu
1
330
請來的 AI Agent 同事們在寫程式時,怎麼用 pytest 去除各種幻想與盲點
keitheis
0
120
Laravel Boost 超入門
fire_arlo
3
210
詳解!defer panic recover のしくみ / Understanding defer, panic, and recover
convto
0
240
ソフトウェアテスト徹底指南書の紹介
goyoki
1
150
「手軽で便利」に潜む罠。 Popover API を WCAG 2.2の視点で安全に使うには
taitotnk
0
850
AIを活用し、今後に備えるための技術知識 / Basic Knowledge to Utilize AI
kishida
22
5.7k
機能追加とリーダー業務の類似性
rinchoku
2
1.3k
Featured
See All Featured
Fireside Chat
paigeccino
39
3.6k
Done Done
chrislema
185
16k
Facilitating Awesome Meetings
lara
55
6.5k
Improving Core Web Vitals using Speculation Rules API
sergeychernyshev
18
1.1k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
34
3.1k
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
29
2.9k
Measuring & Analyzing Core Web Vitals
bluesmoon
9
580
Put a Button on it: Removing Barriers to Going Fast.
kastner
60
4k
Bash Introduction
62gerente
615
210k
Stop Working from a Prison Cell
hatefulcrawdad
271
21k
How STYLIGHT went responsive
nonsquared
100
5.8k
A designer walks into a library…
pauljervisheath
207
24k
Transcript
SpecFlow 在 Yahoo! 的應⽤用實踐分享 Jonathan (⼩小林林)
關於我 ‒ Engineer @ Y! BackOffice Team ‒
[email protected]
守備範圍 ‒ 就只是個 NPC ERP ‒ .NET Tech Stack ‒
EC 訂單成立前後的⾦金金、物流
系統架構 ERP
什什麼是 SpecFlow? ‒ Cucumber(⼩小黃瓜) for .NET platform
什什麼是 Cucumber? ‒ 可執⾏行行的規格 ‒ 規格 = 測試案例例
長得像這樣
為什什麼我們使⽤用 SpecFlow?
複雜的商業邏輯
舉例例?
我們家的訂購流程 (可視部份)
簡單流程 下單 包裝 付款 完成 出貨 送達
簡單流程 下單 包裝 付款 完成 出貨 送達 付款 失敗
簡單流程 下單 包裝 付款 完成 出貨 送達 付款 失敗 缺貨
取消
簡單流程 下單 包裝 付款 完成 出貨 送達 付款 失敗 缺貨
取消 客⼾戶 拒收
想想上述情境再複雜 5~10 倍?
如何確保不會做錯 ⼤大家認知⼀一致?
將⼝口語轉為可執⾏行行規格
像這樣...
“如果徵信通過,把訂單 狀狀態更更新為 1 (付款完成)”
具體做法 撰寫 規格
撰寫規格
具體做法 撰寫 規格 讓規格 ⾃自動化 執⾏行行
⾃自動測試程式碼 (Test Code)
具體做法 撰寫 規格 撰寫程 式碼 讓規格 ⾃自動化 執⾏行行
真正運⾏行行程式碼 (Prod Code)
具體做法 撰寫 規格 撰寫程 式碼 讓規格 ⾃自動化 執⾏行行 滿⾜足 規格
規格滿⾜足
上述是 典型的 BDD 開發流程
有時候我們會這樣使⽤用 SpecFlow 現有 程式碼 讓規格 ⾃自動化 執⾏行行 整理理 規格 調整
程式
Demo
Demo - Table Schema
⽬目前看來來很不錯?
理理想是豐滿的, 現實是骨感的......
實務上我們踩過哪些 坑 & 怎麼解決?
坑 No.1 - 共⽤用開發資 料庫
共⽤用開發資料庫
這樣做有什什麼問題?
“你蓋到了了我的測試資料!”
“你測試資料沒清!”
“你測試資料清錯了了......”
解決⽅方式 ‒ 讓每個⼈人有⾃自⼰己專屬的測試庫 ‒ 使⽤用 SQL Server LocalDB (File- based
DB)
幫測試專案裝上測試 DB
調整測試專案的 Connection String
具體做法 啓動 Local DB 關閉 LocalDB 執⾏行行 測試
額外好處 ‒ Test Failed 時,LocalDB 可以⽅方便便做 為後續除錯使⽤用
Demo
坑 No.2 - 如何表達 DB 表格間的關聯聯性?
回憶我們的 Table Schema
當我們想要表達表格間 的資料關聯聯性
我們的第⼀一個測試案例例
我們的第⼀一個測試案例例
缺點 ‒ ⾁肉眼對照表格關聯聯性 ‒ 複雜度隨著表格數量量提升,等比上升
再想像我們測試案例例不 只⼀一個...
第⼆二個測試案例例
缺點 ‒ SupplierId 雖然都是 1,但真實值不 會是 1 ‒ Foreign Key
欄欄位的值,不會是真實 表格的 P.K. 值
之前的解法 ‒ 在 Feature 檔中,⼿手動做好編號 ‒ 在測試程式中,把 F.K. 欄欄位的值做替 換
‒ 表格關聯聯越多,⼯工越⼤大
後來來我們開了了個腦洞洞...
幫 Gherkin 加了了個表達 關聯聯的語法糖...
表格關聯聯語法
表格關聯聯語法
原理理︰ 新增 DB 資料時,記錄 SpecFlow Key <-> DB Key 之間的關聯聯
好處 ‒ 提⾼高表達的精確性 ‒ 減少撰寫測試程式的⼯工
Demo
Any Question?
Thank You!