gpt4 book ai didi

javascript - 在 Jest 中测试嵌套的 promise

转载 作者:行者123 更新时间:2023-11-29 18:54:22 24 4
gpt4 key购买 nike

我在 Jest 中测试以下函数时遇到问题。我有一个函数可以将数组或 promise 作为参数。无论哪种方式,我都会将该参数传递给 axios 调用,唯一的区别是如果该参数是一个 promise,我会在将其传递给调用之前调用 .then()

这一切都工作得很好而且花花公子,但我在编写单元测试来确认它是否工作时遇到了问题。

sendItems.js

import axios from 'axios'

export const saveItems = () => {
return axios({
url: '/stuff/graphql',
method: 'post',
credentials: 'same-origin',
data: {
whatever: 'yo'
}
})
.then(response => {
return response
})
.catch(err => {
return err
})
}
export const sendItems = items => {

if(items instanceof Promise){
items.then(result => {
return saveItems(result)
})
.catch(err => {
return err
})
}
else{
return saveItems(items)
}
}

export default { sendItems, saveItems }

测试看起来像这样:

/* global jest, describe, beforeAll, beforeEach, expect, test */
import axios from 'axios'
import MockAdapter from 'axios-mock-adapter'

describe('save items', () => {
let sendItems, mock, items

beforeAll(() => {
sendItems = require('../services/sendItems.js').sendItems
mock = new MockAdapter(axios)
items = [
{
pid: '1',
name: 'shoe'
}
]
})

test('returns 200 when the call to save items is successful', async () => {
const response = {
status: 200,
data: 'success'
}
mock.onPost('stuff/graphql').reply(200, response)
const sendItemsResp = await sendItems(items)
expect(sendItemsResp.data.status).toEqual(response.status)
})

test('correctly resolves the value of input passed to the service, if it is a Promise', async() => {
const response = {
status: 200,
data: 'success'
}

items = Promise.resolve([{"p": 1}, {"p": 2}])

mock.onPost('stuff/graphql').reply(200, response)

const sendItemsResp = await sendItems(items)
expect(sendItemsResp.response.status).toEqual(response.status)
// expect(saveItems).toHaveBeenCalledWith([{"p": 1}, {"p": 2}])
})
})

我将一个数组传递给 sendItems 的较早测试通过了,但是我将一个 Promise 传递给 sendItems 的后一个测试失败了,因为 sendItemsResp 未定义。如果我在运行后一个测试时将 console.log(saveItems(result) 放在 sendItems 函数中,我会得到一个未决的 promise ,所以我假设我需要一些如何在此测试中解决该 promise 。但是,我不知道该怎么做。有人可以帮忙吗?

最佳答案

items.then(result => {

中缺少 return 语句

此外,您还可以执行 const sendItems = items => Promise.resolve(items).then(saveItems)

.then.catch 也是多余的。

关于javascript - 在 Jest 中测试嵌套的 promise ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50028406/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com