Notice: This page requires JavaScript to function properly.
Please enable JavaScript in your browser settings or update your browser.
Aprende Introduction to Unittest in Python: Writing Structured Unit Tests | Mastering Unittest Framework
Advanced Python

bookIntroduction to Unittest in Python: Writing Structured Unit Tests

Unittest is part of Python's standard library, which means no additional installations are needed to get started. It is designed around the concept of test cases, which are Python classes derived from the framework’s TestCase class. Unittest is an excellent tool for anyone beginning their testing journey because it structures tests in a way that reflects the principles of object-oriented programming.

The Structure of Unittest

In Unittest, each test is a method within a subclass of unittest.TestCase. This design encourages grouping related tests together, which can help organize testing code logically and make it more readable.

Writing a Test with Unittest

Let’s test a simple function that calculates the average of two numbers. Here’s the function we want to test:

def calculate_average(num1, num2):
    return (num1 + num2) / 2

Creating a Test Case

To create a test case, you will define a class that inherits from unittest.TestCase. Within this class, you can then define methods to test the calculate_average function.

import unittest

class TestCalculateAverage(unittest.TestCase):
    
    def test_integers(self):
        self.assertEqual(calculate_average(10, 20), 15)
    
    def test_floats(self):
        self.assertAlmostEqual(calculate_average(10.5, 20.5), 15.5)
  • First, you import the Unittest module, which is part of Python's standard library;
  • class TestCalculateAverage(unittest.TestCase) creates a new test case. It inherits from unittest.TestCase, which provides the testing functionality;
  • Each method in the class should start with test_;
  • The methods uses specific assert statement for checking whether condition is true.

Example of a Successful Test Output

When all tests pass in Unittest, the output is straightforward and indicates that all tests ran successfully without any failures. Here's an example of a successful test run:

...
----------------------------------------------------------------------
Ran 3 tests in 0.002s

OK

Example of a Failed Test Output

If one or more tests fail, the output will provide details about the failures, including which tests failed and why. Here’s an example of what it might look like when a test fails:

..F
----------------------------------------------------------------------
Ran 3 tests in 0.003s

FAILED (failures=1)

======================================================================
FAIL: test_average_floats (test_module.TestCalculateAverage)
----------------------------------------------------------------------
Traceback (most recent call last):
  File "/path/to/test_module.py", line 10, in test_average_floats
    self.assertAlmostEqual(calculate_average(10.0, 20.0), 15.1)
AssertionError: 15.0 != 15.1 within 7 places (0.10000000000000142 difference)

----------------------------------------------------------------------

This output includes:

  • ..F indicates that three tests were run; the first two passed (represented by ..), and the third failed (F);
  • FAILED (failures=1) shows that there was one failure among the tests run;
  • The detailed error report starts with the test identifier (test_average_floats) and the class (TestCalculateAverage). It provides a traceback to the line in your test code that caused the failure and explains the nature of the assertion error, including the expected value, the actual value, and the acceptable margin of error.

¿Todo estuvo claro?

¿Cómo podemos mejorarlo?

¡Gracias por tus comentarios!

Sección 5. Capítulo 1

Pregunte a AI

expand

Pregunte a AI

ChatGPT

Pregunte lo que quiera o pruebe una de las preguntas sugeridas para comenzar nuestra charla

Suggested prompts:

Can you explain what the different assert methods in Unittest do?

How do I run these tests from the command line?

What should I do if a test fails?

Awesome!

Completion rate improved to 3.13

bookIntroduction to Unittest in Python: Writing Structured Unit Tests

Desliza para mostrar el menú

Unittest is part of Python's standard library, which means no additional installations are needed to get started. It is designed around the concept of test cases, which are Python classes derived from the framework’s TestCase class. Unittest is an excellent tool for anyone beginning their testing journey because it structures tests in a way that reflects the principles of object-oriented programming.

The Structure of Unittest

In Unittest, each test is a method within a subclass of unittest.TestCase. This design encourages grouping related tests together, which can help organize testing code logically and make it more readable.

Writing a Test with Unittest

Let’s test a simple function that calculates the average of two numbers. Here’s the function we want to test:

def calculate_average(num1, num2):
    return (num1 + num2) / 2

Creating a Test Case

To create a test case, you will define a class that inherits from unittest.TestCase. Within this class, you can then define methods to test the calculate_average function.

import unittest

class TestCalculateAverage(unittest.TestCase):
    
    def test_integers(self):
        self.assertEqual(calculate_average(10, 20), 15)
    
    def test_floats(self):
        self.assertAlmostEqual(calculate_average(10.5, 20.5), 15.5)
  • First, you import the Unittest module, which is part of Python's standard library;
  • class TestCalculateAverage(unittest.TestCase) creates a new test case. It inherits from unittest.TestCase, which provides the testing functionality;
  • Each method in the class should start with test_;
  • The methods uses specific assert statement for checking whether condition is true.

Example of a Successful Test Output

When all tests pass in Unittest, the output is straightforward and indicates that all tests ran successfully without any failures. Here's an example of a successful test run:

...
----------------------------------------------------------------------
Ran 3 tests in 0.002s

OK

Example of a Failed Test Output

If one or more tests fail, the output will provide details about the failures, including which tests failed and why. Here’s an example of what it might look like when a test fails:

..F
----------------------------------------------------------------------
Ran 3 tests in 0.003s

FAILED (failures=1)

======================================================================
FAIL: test_average_floats (test_module.TestCalculateAverage)
----------------------------------------------------------------------
Traceback (most recent call last):
  File "/path/to/test_module.py", line 10, in test_average_floats
    self.assertAlmostEqual(calculate_average(10.0, 20.0), 15.1)
AssertionError: 15.0 != 15.1 within 7 places (0.10000000000000142 difference)

----------------------------------------------------------------------

This output includes:

  • ..F indicates that three tests were run; the first two passed (represented by ..), and the third failed (F);
  • FAILED (failures=1) shows that there was one failure among the tests run;
  • The detailed error report starts with the test identifier (test_average_floats) and the class (TestCalculateAverage). It provides a traceback to the line in your test code that caused the failure and explains the nature of the assertion error, including the expected value, the actual value, and the acceptable margin of error.

¿Todo estuvo claro?

¿Cómo podemos mejorarlo?

¡Gracias por tus comentarios!

Sección 5. Capítulo 1
some-alt