Bird
Raised Fist0
PyTesttesting~10 mins

Why integration tests verify components together in PyTest - Test Execution Impact

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Test Overview

This test checks that two components, a calculator and a logger, work correctly when used together. It verifies that the calculator adds numbers and the logger records the operation.

Test Code - pytest
PyTest
import pytest

class Calculator:
    def __init__(self, logger):
        self.logger = logger

    def add(self, a, b):
        result = a + b
        self.logger.log(f"Added {a} and {b} to get {result}")
        return result

class Logger:
    def __init__(self):
        self.messages = []

    def log(self, message):
        self.messages.append(message)

@pytest.fixture
def logger():
    return Logger()

@pytest.fixture
def calculator(logger):
    return Calculator(logger)


def test_calculator_add_logs_operation(calculator, logger):
    result = calculator.add(3, 4)
    assert result == 7
    assert logger.messages[-1] == "Added 3 and 4 to get 7"
Execution Trace - 7 Steps
StepActionSystem StateAssertionResult
1Test startspytest test runner initializedPASS
2Fixtures create Logger and Calculator instancesLogger with empty messages list, Calculator linked to LoggerPASS
3Calculator.add(3, 4) is calledCalculator computes sum 7PASS
4Logger.log records message 'Added 3 and 4 to get 7'Logger messages list contains one entryLogger messages list last entry is 'Added 3 and 4 to get 7'PASS
5Assert result == 7Result is 77 == 7PASS
6Assert logger message is correctLogger messages list last entry is 'Added 3 and 4 to get 7'Message matches expected stringPASS
7Test endsAll assertions passedPASS
Failure Scenario
Failing Condition: Logger does not record the addition message or Calculator returns wrong sum
Execution Trace Quiz - 3 Questions
Test your understanding
What does the integration test verify?
AThat Calculator and Logger work correctly together
BThat Calculator adds numbers correctly alone
CThat Logger stores messages correctly alone
DThat Calculator subtracts numbers correctly
Key Result
Integration tests check that separate parts work together correctly, catching problems that unit tests alone might miss.

Practice

(1/5)
1. Why do integration tests verify components together in pytest?
easy
A. To check if different parts of the program work well together
B. To test a single function in isolation
C. To measure the speed of the program
D. To check the spelling in the code comments

Solution

  1. Step 1: Understand the purpose of integration tests

    Integration tests focus on testing how different parts or components of a program work together as a group.
  2. Step 2: Compare with other test types

    Unit tests check single functions alone, while integration tests check combined parts to find issues missed by unit tests.
  3. Final Answer:

    To check if different parts of the program work well together -> Option A
  4. Quick Check:

    Integration tests verify combined components = A [OK]
Hint: Integration tests check combined parts, not single functions [OK]
Common Mistakes:
  • Confusing integration tests with unit tests
  • Thinking integration tests check performance
  • Assuming integration tests check code comments
2. Which pytest code snippet correctly shows an integration test combining two components?
easy
A. def test_multiply(): assert multiply(2, 3) == 6
B. def test_add(): assert add(2, 3) == 5
C. def test_subtract(): assert subtract(5, 3) == 2
D. def test_add_and_multiply(): assert multiply(add(2, 3), 4) == 20

Solution

  1. Step 1: Identify integration test code

    Integration tests combine multiple components; here, add and multiply are used together in one test.
  2. Step 2: Check other options

    Options A, B, and D test single functions alone, so they are unit tests, not integration tests.
  3. Final Answer:

    def test_add_and_multiply(): assert multiply(add(2, 3), 4) == 20 -> Option D
  4. Quick Check:

    Integration test combines functions = C [OK]
Hint: Integration test calls multiple functions together [OK]
Common Mistakes:
  • Choosing unit tests as integration tests
  • Ignoring combined function calls
  • Not checking the assertion logic
3. Given the pytest integration test below, what will be the test result?
def test_process_order():
    order = create_order(5)
    result = process_payment(order)
    assert result == 'Success'
medium
A. Test fails because create_order is not defined
B. Test passes if process_payment returns 'Success' for order 5
C. Test passes regardless of process_payment output
D. Test fails due to syntax error

Solution

  1. Step 1: Analyze the test logic

    The test calls create_order and then process_payment with the order. It asserts the result equals 'Success'.
  2. Step 2: Understand test pass condition

    If process_payment(order) returns 'Success', the assertion passes and the test passes. Otherwise, it fails.
  3. Final Answer:

    Test passes if process_payment returns 'Success' for order 5 -> Option B
  4. Quick Check:

    Assertion matches output = B [OK]
Hint: Test passes only if assertion matches actual output [OK]
Common Mistakes:
  • Assuming test passes without matching assertion
  • Confusing undefined functions with test result
  • Thinking syntax error exists without checking code
4. Identify the error in this pytest integration test code:
def test_user_login():
    user = create_user('alice')
    assert login(user) == True
    assert logout(user) = True
medium
A. No error, code is correct
B. Missing parentheses in function calls
C. Using single equals (=) instead of double equals (==) in last assertion
D. Using wrong function names for login and logout

Solution

  1. Step 1: Check assertion syntax

    The last assertion uses single equals (=) which is assignment, not comparison. It should be double equals (==).
  2. Step 2: Verify other code parts

    Function calls have parentheses and function names look consistent. So no other syntax errors.
  3. Final Answer:

    Using single equals (=) instead of double equals (==) in last assertion -> Option C
  4. Quick Check:

    Use '==' for comparison in assertions = D [OK]
Hint: Assertions need '==' not '=' for comparisons [OK]
Common Mistakes:
  • Confusing assignment (=) with comparison (==)
  • Ignoring syntax errors in assertions
  • Assuming function names cause error without evidence
5. You have two components: fetch_data() returns data list, and process_data(data) filters it. Why is an integration test combining both important?
hard
A. To verify process_data works correctly with actual fetched data
B. To check if fetch_data returns correct data format alone
C. To test process_data independently with mock data
D. To measure how fast fetch_data runs

Solution

  1. Step 1: Understand component roles

    fetch_data() gets data, process_data(data) filters it. Testing them together checks real interaction.
  2. Step 2: Why integration test matters here

    Integration test ensures process_data handles actual data from fetch_data, catching issues missed by isolated tests.
  3. Final Answer:

    To verify process_data works correctly with actual fetched data -> Option A
  4. Quick Check:

    Integration test checks real data flow = A [OK]
Hint: Integration tests check real data flow between components [OK]
Common Mistakes:
  • Testing components only in isolation
  • Ignoring real data format in integration
  • Confusing performance test with integration test