ในการทดสอบ component นั่น หากใน component มีฟังก์ชั่น หรือ logic อะไรบางอย่างอยู่ใน component นั้นด้วย มันทำให้การทดสอบ component นั่นๆ จะไปเรียกฟังก์ชั่นเหล่านั้น
จากบทความก่อนหน้านี้ https://nutshell.work/how-to-testing-custom-hooks-in-testing-components-with-cypress/
หากเราไม่ต้องการให้มีการทำงานภายในฟังก์ชั่นที่มีการเรียกใช้งาน เราสามารถ Mock ตัว stub/spy ของฟังก์ชั่นเหล่านี้ได้
ปรับวิธีการเรียกใช้งาน Custom Hook
ก่อนอื่นต้องบอกก่อนว่า ถ้าหากเราต้องการที่จะ stub ฟังก์ชั่นใน hook เราไม่สามารถเข้าไป stub มันผ่านทาง component ได้ตรงๆ มันต้องมีการปรับวิธีการเรียกใช้งาน hook ใหม่สักหน่อย ซึ่งต้องบอกก่อนว่า ผมใช้วิธีนี้อยู่ ในอนาคตหากมีวิธีที่ดีกว่า ค่อยว่ากัน
เริ่มต้นที่ เรามี component และ hook ของเราจากบทความที่แล้ว คือ component สำหรับเพิ่มค่าบวก ลบ ซึ่งมีโค๊ดดังนี้
สิ่งที่ต้องทำเลยคือ เราจะต้องทำยังไงก็ได้ ให้ตัว component ไปเรียกใช้งาน useCount ที่เราได้ทำการ Mock ตัว stub/spy มันเอาไว้
สร้าง Stub ของ Hook
เริ่มต้นจากเราต้องสร้างตัว Mock ตัว stub/spy ของ hook ขึ้นมาก่อน ซึ่งเราจะสร้างไว้ที่ counter.cy.tsx
จากนั้นก็มาถึงขึ้นตอนที่จะต้องมีการปรับการเรียกใช้งาน hook ใน component แล้ว โดยจากเดิมเป็นการเรียกใช้งานตรงๆ ผ่านการ import ไฟล์แล้วใช้งานเลย
เราจะเปลี่ยนเป็น ส่งค่า hook ผ่านทาง component props แทน แบบนี้
ใส่ใน component ก็จะต้องเพิ่ม props ที่ใช้รับค่า useCounter ที่ส่งมาด้วย
เท่านี้เรา ก็สามารถที่จะ Mock ตัว stub/spy ฟังก์ชั่นต่างๆ ภายใน hooks ได้โดยที่ไม่จำเป็นต้องไปเรียกใช้งานคำสั่งต่างๆ ภายในฟังก์ชันเลย
กำหนดค่า Default
ถึงแม้ว่า เราจะสามารถ Mock ตัว stub/spy ค่าต่างๆ ภายใน hook ได้แล้ว แต่ว่า ยังมีส่วนที่ต้องเพิ่มเติมเข้าไปอีกหน่อย
นั่นคือ สังเกตุว่า ถ้าหากเราต้องการเรียกใช้งาน component เราจะต้อง ส่ง hook ไปด้วยเสมอ ซึ่งอาจจะเพิ่มความยุ่งยากได้
วิธีแก้คือ ให้กำหนดค่า default ของ parameter ของ useCounter ใน component props ให้ไปให้ useCounter จริงๆ ที่ไม่ใช้ ตัว Mock stub/spy
รวม code ทั้งหมด ก็จะได้แบบนี้
เท่านี้เราก็สามารถเรียกใช้งาน component แบบเดิมได้แล้ว และสามารถสร้าง Mock ตัว stub/spy ได้โดยไม่กระทบการทำงานของ component