Testing Fundamentals [EpicWeb]

5h 16m 16s
English
Paid

In this workshop, Artem Zakharchenko, testing expert and creator of the Mock Service Worker API mocking library, will guide you through creating your own version of the Vitest testing framework.

Building a testing framework from scratch will give you a deep understanding of how the pieces fit together, and change the way you think about testing for the better.

Read more about the course

What You'll Learn

The workshop is broken out into four parts, each with its own challenges and exercises that build upon the last:

Principles

First, you'll explore the principles and mental models that underlie testing strategies. This is where you will begin to distinguish between the intention of your code and its implementation details. When you focus the intention of what your code should accomplish, you can write tests that are more resilient to change.

Test Structure

Next, you'll do a deep dive into the structure of the testing framework. You'll create your own expect and test functions, configure your test environment, and use hooks to manage side effects in your tests.

Testing Asynchronous Code

Testing asynchronous code requires a slightly different approach when compared to testing synchronous code. Here you'll practice with testing promises and async functions, as well as handling errors and rejections.

Moving to Vitest

Once you've learned the fundamentals of testing and built your own mini-framework, you will migrate your tests to the Vitest framework. This process will cement your understanding of not just the "hows", but also the "whys" of testing.

Who This Workshop Is For

This workshop is for developers who have some testing experience, but feel like they're missing the bigger picture. If you're tired of writing tests that feel like a chore, and want to understand how to write tests that are actually useful, this workshop is for you.

Watch Online Testing Fundamentals [EpicWeb]

Join premium to watch
Go to premium
# Title Duration
1 Testing Fundamentals Workshop Introduction 01:44
2 Overview of Testing Principles 01:11
3 Write an Intentional Test - PROBLEM 01:06
4 -----Ignore this video------- 27:31
5 Implement the Automated Greeting Test - SOLUTION 01:15
6 Debugging Intent vs. Implementation - PROBLEM 00:41
7 -----Ignore this video------- 27:31
8 Trusting Your Test - SOLUTION 00:28
9 Testing Principles Outro 00:15
10 Structure Your Tests 00:56
11 Imperative vs. Declarative Assertions - PROBLEM 01:08
12 -----Ignore this video------- 27:31
13 Implement a Declarative API - SOLUTION 02:01
14 Isolating Tests with Test Blocks - PROBLEM 00:59
15 -----Ignore this video------- 27:31
16 Create Test Blocks for Better Organization - SOLUTION 01:27
17 Move Tests into Modules - PROBLEM 00:55
18 -----Ignore this video------- 27:31
19 Modular Tests and Global Helpers - SOLUTION 03:23
20 Handle Test Side Effects - PROBLEM 01:26
21 -----Ignore this video------- 27:31
22 Implement Hooks for Test Setup & Cleanup - SOLUTION 03:52
23 Test Structure Recap 00:23
24 Overview of Testing Async Code 00:48
25 Handling Promises in Tests - PROBLEM 01:24
26 -----Ignore this video------- 27:31
27 Awaiting Async Tests - SOLUTION 01:55
28 Error Assertions for Rejected Promises - PROBLEM 00:43
29 -----Ignore this video------- 27:31
30 Handling Promise Rejections - SOLUTION 03:21
31 Testing with Async Side Effects - PROBLEM 01:53
32 -----Ignore this video------- 27:31
33 Reliably Wait for Async Operations - SOLUTION 03:19
34 Recap of Testing Asynchronous Code 00:22
35 Overview of Vitest 00:34
36 Migrate Tests to Vitest - PROBLEM 00:24
37 -----Ignore this video------- 27:31
38 Installing, Configuring, and Testing in Vitest - SOLUTION 02:28
39 Vitest Review 00:19
40 Testing Fundamentals Workshop Outro 00:26

Similar courses to Testing Fundamentals [EpicWeb]

SolidJS: The Complete Guide

SolidJS: The Complete GuideSinan Polat

Category: Other (Frontend)
Duration
Build Responsive Real World Websites with HTML5 and CSS3

Build Responsive Real World Websites with HTML5 and CSS3udemy

Category: Other (Frontend)
Duration 37 hours 28 minutes 39 seconds
Build & Test Accessible Web Apps | Testing Accessibility (PRO)

Build & Test Accessible Web Apps | Testing Accessibility (PRO)Marcy Sutton

Category: Other (Frontend)
Duration 16 hours 30 minutes 59 seconds
The Complete Junior to Senior Web Developer Roadmap (2023)

The Complete Junior to Senior Web Developer Roadmap (2023)udemy

Category: Other (Frontend)
Duration 37 hours 7 minutes 57 seconds
Mocking Techniques in Vitest

Mocking Techniques in VitestArtem Zakharchenko

Category: Other (Frontend)
Duration 1 hour 30 minutes 36 seconds
Web Components Demystified

Web Components DemystifiedScott Jehl

Category: Other (Frontend)
Duration 7 hours 51 minutes 36 seconds