Sascha Depold & Parinaz Roghany

Test Driven Development with JavaScript

First, write a test that fails. Then, write the code to make it pass. This simple rhythm is the key to building truly robust software.

Test Driven Development with JavaScript
#1about 5 minutes

The fundamentals of software testing

Learn the difference between manual and automated testing, the various types like unit and integration, and why testing is crucial for product health.

#2about 2 minutes

Understanding the Test-Driven Development (TDD) workflow

TDD involves converting feature specifications into machine-readable tests before writing any implementation code.

#3about 3 minutes

Choosing the right JavaScript testing tools

An overview of the JavaScript testing ecosystem compares the all-in-one Jest framework with the combination of Mocha and Chai.

#4about 10 minutes

Preparing to implement the Fibonacci sequence with TDD

The Fibonacci sequence is introduced as the coding challenge, and the Red-Green-Refactor strategy is outlined for its implementation.

#5about 17 minutes

Live coding: Writing the Fibonacci unit tests

A step-by-step guide to writing unit tests for the Fibonacci function using Mocha's `describe` and `it` blocks and Chai's `expect` assertions.

#6about 10 minutes

Live coding: Implementing the function to pass tests

The Fibonacci function is implemented incrementally, running the test suite after each change to watch the tests turn from red to green.

#7about 3 minutes

Addressing performance issues with large numbers

An explanation of why the recursive implementation is slow for large inputs and how to solve precision issues using JavaScript's `BigInt`.

#8about 10 minutes

Applying TDD principles to API testing

The workshop transitions from unit testing to integration testing by setting up an Express.js API and using SuperTest to define its behavior via tests.

#9about 14 minutes

Writing API tests and handling external dependencies

Learn to write API tests with SuperTest and discover why making real network requests to external services makes your test suite slow and unreliable.

#10about 14 minutes

Mocking dependencies with Sinon and Nock

Use Sinon.js to mock modules and Nock.js to mock HTTP requests, effectively isolating your tests and making them significantly faster.

#11about 13 minutes

Recap and practical advice for testing applications

A summary of key takeaways, including a discussion on what to test in frontend applications and how to introduce TDD to junior developers.

Related jobs
Jobs that call for the skills explored in this talk.
SabIna compys

SabIna compys
Vienna, Austria

Remote
€20-100K
Intermediate
JavaScript
.NET
+1

Featured Partners

Related Articles

View all articles
SD
Sabina Dapo
New Test
The basic purpose of narrative is to entertain, to gain and hold readers’ interest. However narratives can also be written to teach or inform, to change attitudes / social opinions e.g. soap operas and television dramas that are used to raise topical...
New Test
AP
Anto Pranjić
11 Tips to Make The Most Out of Your First World Congress 
The world’s most awesome event for developers is taking place in less than a month! It’s been far too long since the last time we met in person, but that’s only going to make this year’s WeAreDevelopers World Congress a truly special experience. Conf...
11 Tips to Make The Most Out of Your First World Congress 
CH
Chris Heilmann
Dev Digest 136 - No JS(on) of mine
News and ArticlesDouglas Crockford is our featured video, so let's talk about evolving JavaScript and all things JSON. Judicious JSON explains all the weird things in it, you can learn why it can be incredibly slow, people wonder what even is a JSON ...
Dev Digest 136 - No JS(on) of mine

From learning to earning

Jobs that call for the skills explored in this talk.

Senior QA Engineer

CheckYeti
Vienna, Austria

Senior
Selenium
JavaScript
Manual Testing
Automated Testing
Software Tester

Think-cell
Foster City, United States of America

Intermediate
Unit Testing
Manual Testing
Automated Testing
Frontend Developer

JO Media Software Solutions GmBh
Brunn am Gebirge, Austria

Senior
CSS
Angular
JavaScript
TypeScript