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
API-整合測試
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Star Rocket
September 11, 2019
Programming
120
0
Share
API-整合測試
LaraGirls Meetup#4
Star Rocket
September 11, 2019
More Decks by Star Rocket
See All by Star Rocket
PHP 也有 Day #51:高效能框架的曙光 - 以 Laravel 經驗開發 Hyperf 應用
starrocket
1
350
PHP 也有 Day #50:處理前人的遺產—聊 legacy code
starrocket
0
94
PHP 也有 Day #49:邊緣人救星!用 Laravel 打造私人定製的聊天機器人
starrocket
0
420
PHP 也有 Day #48:我是誰?我在哪?
starrocket
0
75
PHP 也有 Day #48:我是誰?我在哪?
starrocket
0
79
How we talk about Engineering Culture at Phase
starrocket
0
45
PHP 也有 Day #47:打造好維護的 PHP 程式碼專案
starrocket
0
380
全端起手就用 Laravel+Vue.js 現場實作給你看
starrocket
0
210
PHP 也有 Day #45: VS Code 實戰料理 PHP 套件網站佐 Azure Pipelines
starrocket
0
120
Other Decks in Programming
See All in Programming
Oxlintはいかにしてtsgolintのlint ruleを呼び出しているのか
syumai
1
480
Spec-Driven Development with AI-Agents: From High-Level Requirements to Working Software
antonarhipov
2
330
不変条件と整合性境界—ビジネスが決める設計判断と実現パターン / Invariants and Consistency Boundaries
nrslib
6
640
Migrations : C'est une question d'hygiène !
vinceamstoutz
0
1.8k
要はバランスからの卒業 #yumemi_grow
kajitack
0
190
開発体験を左右するライブラリの API 設計 - GraphQL スキーマ構築ライブラリから考える #tskaigi
izumin5210
2
520
Cloudflare で始める Data Platform
ta93abe
0
300
TSKaigi2026-静的解析への投資がAI時代のコード品質を支える ── カスタムESLintルールの設計と運用
hayatokudou
6
1.1k
横断組織出身のQAEがインプロセスQAEでつまずいたこと・活かせたこと
ty89
0
180
密結合なバックエンドから TypeScript のコードを生成する
kemuridama
1
340
20260514 - build with ai 2026 - build LINE Bot with Gemini CLI
line_developers_tw
PRO
0
470
AI 時代のソフトウェア設計の学び方
masuda220
PRO
15
5.4k
Featured
See All Featured
Agile Actions for Facilitating Distributed Teams - ADO2019
mkilby
0
190
Raft: Consensus for Rubyists
vanstee
141
7.4k
Odyssey Design
rkendrick25
PRO
2
630
Building an army of robots
kneath
306
46k
Side Projects
sachag
455
43k
How To Speak Unicorn (iThemes Webinar)
marktimemedia
1
460
A Soul's Torment
seathinner
6
2.8k
Designing for humans not robots
tammielis
254
26k
Scaling GitHub
holman
464
140k
Data-driven link building: lessons from a $708K investment (BrightonSEO talk)
szymonslowik
1
1.1k
JavaScript: Past, Present, and Future - NDC Porto 2020
reverentgeek
52
5.9k
Dominate Local Search Results - an insider guide to GBP, reviews, and Local SEO
greggifford
PRO
0
170
Transcript
API 整合測試 Glossika Ray
About me
• Glossika Senior Backend Developer • 技能樹點的亂七八糟 • Php &
Laravel & DevOps
Glossika
Glossika Glossika 是由語言學專家和語言學習好手所組成的團隊,致力 於開發有科學根據的語言自學產品!我們利用演算法找出用戶 的語言水平落點,並進而提供有效精準的學習內容幫助學習者 精進語言能力,減少無效的學習時間和資源浪費。Glossika 平 台上線至今近兩年的時間,已開發 65 種語言及獲得超過八萬
名來自世界各地的註冊用戶。
Glossika 30 天免費試用
None
如何提交高品質且可靠的 API ?
寫單元測試!But ….
寫完後,先上線看有沒有問題,然後 如果有時間的話再來補單元測試!
高品質?可靠?
None
API 回應是否正常 API 之間的串接溝通是否也符合預期
對了,你有聽過整合測試嗎?
None
None
Pre Request script Send Request Get Response Tests Script
Postman Collection
Postman Collection • Request 的集合 • 可以分享給其他人 • 雲端儲存 •
可以做 API 之間的串接測試
None
Glossika 開發流程 訂定 API 格式 建立文件 Mock Server 後端 API
設計 前端頁面串接 Staging Production Postman Test
Glossika API 基本測試 • Response Schema Test ◦ Tiny Validator
4 • Http code and Require column Test ◦ Postman sandbox API
Glossika API 測試結構 Get Response Status Code test Schema Test
Tiny Validator 4 basic syntax "type": "array", "item" : {
// item here }, "type": "object", "properties" : { // properties }, "key" : { "type": "data type" }, Json Array Json Object Json Column
{ "article_id": 55 } { "object": { "properties": { "article_id":
{ "type": "integer" } } } } Response Tiny Validator
情境:測試使用者登入 API
Test case: User login • User story ◦ 使用者輸入帳號密碼登入,回傳該使用的的基本資訊 •
Input ◦ Email ◦ Password • Response ◦ User Id ◦ User name ◦ User email ◦ User Auth token
情境:使用者登入後,發表一篇文章,並取得文章資 料
Test case : Post Article • User story ◦ 使用者登入後,發表一篇文章,並取得文章資料
Login API Post Article API Get Article API token id
Environment / Global variable • Postman 中,不同 API 用來儲存需要傳遞的資料變數。
Postman Collection Runner
None
你這樣還是不靠譜啊,現在是自動化的時代了
Postman-CLI Newman
Postman-CLI Newman • 安裝 ◦ $ npm install -g newman
• 執行 ◦ $ newman run mycollection.json
總結
善用工具來協助工作
撰寫測試是提高程式碼品質的最佳方案 而且可以讓我們說話比較大聲
在有限的時間內,撰寫測試依舊可行 時間就像___,擠擠還是有的
Q/A