Jest - mock read-only data


Posted by tsungtingdu on 2021-07-16

情境:在使用 @ViewChild 引入其他 component

@ViewChild(ChildComponent) childComponent: ChildComponent;

然後進行測試的情況下,需要 mock 這個 ChildComponent。

但是如果想要 mock 那些 read-only 的 attributes 的話,可以用 Object.defineProperty 來處理:

component.childComponent = {} as any;
Object.defineProperty(component.childComponent, 'isChild', { value: true });

當然這個方法也可以用在 mock 其他的 class, object 上


#Angular #Jest







Related Posts

Web開發學習筆記06 — Function Scope vs. Block Scope、IIFE

Web開發學習筆記06 — Function Scope vs. Block Scope、IIFE

Express 實作留言板:新增會員、登入、留言、編輯及刪除

Express 實作留言板:新增會員、登入、留言、編輯及刪除

[JavaScript] 用 Jest 做單元測試

[JavaScript] 用 Jest 做單元測試


Comments