ในการพัฒนาเว็บไซต์ด้วย React หลีกเลี่ยงไม่ได้ที่ในส่วนประกอบต่างๆ อาจจำเป็นต้องมีการพึ่งพา Package จากภายนอก เช่น context, props หรืออะไรก็ตามเพื่อให้ทำงานได้อย่างถูกต้อง และส่วนนี่เป็นปัญหาที่เกิดในทุกๆ การทำการสอบ ซึ่งใน cypress ก็มีวิธีการจัดการกับการทำงานในส่วนนี้ไว้ด้วยแล้วเหมือนกัน
เรามาดูตัวอย่างที่เข้าใจง่ายๆ กัน:
Dark & Light Mode
บทความนี้ผมจะยก Code ง่ายๆ ของการใช้งาน Context ใน React มากให้ดูเป็นตัวอย่าง โดยจะสร้างปุ่มง่ายๆ ที่จะมีการเรียกใช้งาน darkMode ผ่าน context ที่ถูกเขียนไว้ที่อื่นในเว็บแอปพลิเคชัน โดยจะเรียกไป hook useDarkMode ซึ่งกำหนดไว้ในโฟลเดอร์อื่นอีกทีนึง
Dark Mode Selector
เริ่มต้นจากการสร้างปุ่ม ที่ทำหน้าที่เปลี่ยน Mode สลับไปมาจาก dark mode เป็น light mode ซึ่งในนี้เป็นตัวอย่างอย่างง่าย เลยให้มันทำหน้าที่แค่เปลี่ยน Mode และข้อความบนปุ่มแทน
useDarkMode
ต่อมาเราจะสร้างส่วนของการใช้งาน Context โดย จะกำหนด DarkModeProvider ที่รับ Component เข้ามา เพื่อให้สามารถใช้งาน Context ได้
ซึ่งหาการเราลองสร้างไฟล์ทดสอบ แล้วลองเรียกใช้งาน DarkModeSelector โดยตรง เราจะพบว่า Cypress จะแสดง Error ขึ้นมา
Error: useDarkMode must be used within a DarkModeProvider
เนื่องจาก DarkModeSelector พยายามใช้ Context ที่ไม่ได้ถูกกำหนดไว้ก่อนที่จะทำการ mounting
วิธีที่ง่ายที่สุดและง่ายที่สุดในการแก้ไข คือ การสร้างตัว wrapper จากนั้นจึง wrap ส่วนของ Component ของเราไว้ในฟังก์ชัน mount
จากนั้นให้เรียกใช้งาน DarkModeWrapper ในจังหวะ mounting ได้เลย
เท่านี้เราก็สามารถทดสอบไฟล์ Component ที่มีการเรียกใช้งาน Context ได้แล้ว
การส่งค่าผ่าน Props
จากโค๊ดด้านบน สมมติว่า ถ้าหากเราต้องการส่งค่า initialValue ไปยัง DarkModeWarpper เพื่อกำหนดค่าเริ่มต้นของ mode ก็สามารถทำได้ง่าย
การใช้งานร่วมกับ Spy
จากสิ่งที่เราทำมาทั้งหมด เป็นเพียงแค่การทดสอบว่า context มีการทำงานที่ถูกต้องหรือไม่ แต่เราไม่สามารถรู้ได้เลยว่า ปุ่ม Button นั้น ได้เรียกใช้งาน setDartMode หรือเปล่า?
ในส่วนนี้เราจะประยุกต์การใช้งานระหว่างตัว warpper context และ การใช้งาน spy ใน cypress เพื่อให้สามารถเข้าไปทดสอบการเรียกใช้งานฟังก์ชั้น setDartMode ใน DarkModeSelector ได้
โดยไปที่ไฟล์ DarkModeWrapper.tsx เราจะทำการเพิ่มฟังก์ชั้น initDarkModeWrapper ขึ้นมา ซึ่งจะเอามันมาครอบฟังก์ชั่น DarkModeWrapper อีกทีนึง
จากนั้นก็จะสร้าง setDarkModeSpy และจัดการ Return ค่าฟังชั่น DarkModeWarpper และ setDarkModeSpy ออกไปใช้งาน ดังในตัวอย่าง
จากนั้นเราจะเข้าไปปรับไฟล์ทดสอบ DarkModeSelector.cy.tsx โดยจะเปลี่ยนมาเรียกใช้งาน DarkModeWarpper จากฟังก์ชั้น initDarkModeWrapper อีกทีนึง
เท่านี้เราก็สามารถทดสอบฟังก์ชั่น setDarkMode ได้แล้วว่า มีการเรียกใช้งานได้อย่างถูกต้องหรือไม่