亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

為什么Jest中的rest參數未覆蓋branch?

為什么Jest中的rest參數未覆蓋branch?

呼啦一陣風 2021-04-27 13:17:23
我目前正在嘗試覆蓋100%的功能,但我正面臨一個未被覆蓋的分支,它不理解為什么未覆蓋它,甚至不知道如何修復和覆蓋它。它嘗試了許多不同的測試,但沒有改變任何東西。如果問題來自我還是Jest,我不是嗎?我的功能export const removeProductInList = (state: IItems, action: IBasketRemoveProductAction) => {    const {        payload: { uuid },    } = action;    const { [uuid]: itemToRemove, ...restOfItems } = state;    return restOfItems;};我的測試product1 = { id: 1 };product2 = { id: 2 };mockUuid1 = 'IdTest';mockUuid2 = 'IdTest2';mockItem1 = { product: product1, quantity: 1 };mockItem2 = { product: product2, quantity: 1 };mockListItems = {      [mockUuid1]: mockItem1,      [mockUuid2]: mockItem2,};it('should handle PRODUCT__REMOVE', () => {        expect(removeProductInList({ [mockUuid1]: mockItem1 }, removeProduct(mockUuid1))).toEqual({});        expect(removeProductInList(mockListItems, removeProduct(mockUuid1))).toEqual({ [mockUuid2]: mockItem2 });        expect(removeProductInList({}, removeProduct('acac'))).toEqual({});    });我希望在我的實際測試中涵蓋所有功能。我的笑話版本是23.4.1,以防萬一。
查看完整描述

2 回答

?
翻閱古今

TA貢獻1780條經驗 獲得超5個贊

您只需要在ts-jestesnext中的tsConfig文件中指定目標即可。


// jest.config.js


module.exports =  {

 ...

 'ts-jest': {

   ....

   tsConfig: './tsconfig.json'),

},


// tsconfig.json


{

  ...,

  "target": "esnext",

}


查看完整回答
反對 回復 2021-05-13
?
阿波羅的戰車

TA貢獻1862條經驗 獲得超6個贊

嘗試removeProductList用額外的屬性測試

expect(removeProductInList({ [mockUuid1]: mockItem1, extraProp: 'someValue' }, removeProduct(mockUuid1))).toEqual({});


查看完整回答
反對 回復 2021-05-13
  • 2 回答
  • 0 關注
  • 266 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號