您好,登錄后才能下訂單哦!
在Jest測試中,當你需要對復雜數據結構進行斷言時,可以使用toMatchObject()
或toEqual()
方法
toMatchObject()
:這個方法允許你只匹配對象的一部分屬性。如果你只關心對象的某些屬性,而不關心其他屬性,那么這個方法非常有用。例子:
test('toMatchObject', () => {
const user = {
name: 'John',
age: 30,
address: {
city: 'New York',
country: 'USA',
},
};
expect(user).toMatchObject({
name: 'John',
address: {
city: 'New York',
},
});
});
toEqual()
:這個方法會嚴格比較兩個對象的所有屬性和值。如果你需要確保兩個對象完全相同,那么可以使用這個方法。例子:
test('toEqual', () => {
const user1 = {
name: 'John',
age: 30,
address: {
city: 'New York',
country: 'USA',
},
};
const user2 = {
name: 'John',
age: 30,
address: {
city: 'New York',
country: 'USA',
},
};
expect(user1).toEqual(user2);
});
在處理復雜數據結構時,還可以使用Jest的expect.objectContaining()
和expect.arrayContaining()
方法來進行更精確的斷言。
例子:
test('expect.objectContaining() and expect.arrayContaining()', () => {
const user = {
name: 'John',
age: 30,
hobbies: ['reading', 'traveling'],
address: {
city: 'New York',
country: 'USA',
},
};
expect(user).toEqual(
expect.objectContaining({
name: 'John',
age: 30,
hobbies: expect.arrayContaining(['reading']),
address: expect.objectContaining({
city: 'New York',
}),
})
);
});
這樣,你就可以根據需要對復雜數據結構進行精確的斷言。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。