respond
始終以相同的覆寫來回應。
用法
mock.respond(overwrites, { header, statusCode, fetchResponse })
參數
名稱 | 類型 | 詳細資訊 |
---|---|---|
overwrites | MockOverwrite | 用於覆寫回應的 payload |
params 選填 | MockResponseParams | 用於覆寫的其他回應參數 |
params.header 選填 | 物件 | 覆寫特定標頭 |
params.statusCode 選填 | 數字 | 覆寫回應狀態碼 |
params.fetchResponse 選填 | 布林值 | 在使用模擬資料回應之前,先取得真實的回應 |
範例
respond.js
it('should demonstrate response overwrite with static data', async () => {
const mock = await browser.mock('https://todo-backend-express-knex.herokuapp.com/', {
method: 'get'
})
mock.respond([{
title: 'Injected (non) completed Todo',
order: null,
completed: false
}, {
title: 'Injected completed Todo',
order: null,
completed: true
}], {
statusCode: 200,
fetchResponse: true // default
})
await browser.url('https://todobackend.com/client/index.html?https://todo-backend-express-knex.herokuapp.com/')
await $('#todo-list li').waitForExist()
console.log(await $$('#todo-list li').map(el => el.getText()))
// outputs: "[ 'Injected (non) completed Todo', 'Injected completed Todo' ]"
})
it('should demonstrate response overwrite with dynamic data', async () => {
const mock = await browser.mock('https://todo-backend-express-knex.herokuapp.com/')
mock.respond((request) => {
if (request.body.username === 'test') {
return { ...request.body, foo: 'bar' }
}
return request.body
}, {
statusCode: () => 200,
headers: () => ({ foo: 'bar }),
fetchResponse: false // do not fetch real response
})
})