Bird
Raised Fist0
PyTesttesting~5 mins

Docker-based test execution in PyTest - Cheat Sheet & Quick Revision

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
Recall & Review
beginner
What is the main benefit of running tests inside a Docker container?
Running tests inside a Docker container ensures a consistent environment, so tests behave the same way on any machine.
Click to reveal answer
beginner
How do you specify the command to run pytest inside a Docker container?
You specify the command in the Dockerfile or docker-compose.yml using CMD ["pytest"] or by passing it in docker run.
Click to reveal answer
intermediate
Why is it important to mount your test code directory as a volume in Docker when running tests?
Mounting your test code as a volume lets Docker use the latest code without rebuilding the image every time you change tests.
Click to reveal answer
beginner
What is a common way to install pytest and dependencies inside a Docker container?
Use a requirements.txt file and add RUN pip install -r requirements.txt in the Dockerfile.
Click to reveal answer
beginner
How can you view test results when running pytest inside Docker?
Test results appear in the Docker container's output logs, which you can see by running docker logs [container_id] or directly in the terminal if you run interactively.
Click to reveal answer
What command runs pytest tests inside a Docker container?
Adocker run myimage pytest
Bdocker build pytest
Cdocker start pytest
Ddocker stop pytest
Why use Docker volumes when running tests?
ATo increase container memory
BTo speed up Docker image building
CTo share test code between host and container without rebuilding
DTo run tests faster on the host
Where should you install pytest in a Docker setup?
AInside the Dockerfile using pip
BOn the host machine only
CAfter running tests
DIn the docker-compose.yml file
How do you see test output when running pytest in Docker interactively?
AOutput is sent to Docker Hub
BOutput is saved in a file only
COutput is hidden by default
DOutput shows directly in the terminal
What is the purpose of a Dockerfile in test execution?
ATo store test results
BTo define the environment and commands to run tests
CTo write test cases
DTo manage test reports
Explain how Docker helps create a consistent test environment for pytest.
Think about how Docker packages everything needed for tests.
You got /4 concepts.
    Describe the steps to run pytest tests inside a Docker container using a Dockerfile.
    Consider what a Dockerfile needs to prepare and how to execute tests.
    You got /4 concepts.

      Practice

      (1/5)
      1. What is the main benefit of running pytest tests inside a Docker container?
      easy
      A. It ensures tests run in a clean, consistent environment every time.
      B. It makes tests run faster than on the host machine.
      C. It automatically fixes failing tests.
      D. It allows tests to run without writing any test code.

      Solution

      1. Step 1: Understand Docker container purpose

        Docker containers provide isolated environments that are the same every time they run.
      2. Step 2: Connect to pytest benefits

        Running pytest inside Docker avoids environment differences causing test failures.
      3. Final Answer:

        It ensures tests run in a clean, consistent environment every time. -> Option A
      4. Quick Check:

        Docker isolation = consistent test environment [OK]
      Hint: Docker isolates environment to avoid setup issues [OK]
      Common Mistakes:
      • Thinking Docker speeds up tests automatically
      • Believing Docker fixes test code errors
      • Assuming tests run without writing code
      2. Which of the following is the correct way to run pytest inside a Docker container with your current directory shared?
      easy
      A. docker run -p 8080:80 python:3.12 pytest
      B. docker run -v $(pwd):/app -w /app python:3.12 pytest
      C. docker build -t pytest-image . && docker run pytest-image
      D. docker run --rm python:3.12 pytest /app

      Solution

      1. Step 1: Identify volume sharing syntax

        The -v $(pwd):/app option shares the current directory to /app inside the container.
      2. Step 2: Check working directory and command

        -w /app sets the working directory, and pytest runs tests there.
      3. Final Answer:

        docker run -v $(pwd):/app -w /app python:3.12 pytest -> Option B
      4. Quick Check:

        Volume + workdir + pytest = correct run command [OK]
      Hint: Use -v for volume and -w for working directory [OK]
      Common Mistakes:
      • Using -p instead of -v for volume
      • Not setting working directory with -w
      • Running pytest without mounting code
      3. Given this Docker command:
      docker run --rm -v $(pwd):/tests -w /tests python:3.12 pytest test_sample.py

      What will happen if test_sample.py contains one passing and one failing test?
      medium
      A. Pytest will run only the passing test and ignore failures.
      B. Pytest will skip the failing test and exit with zero code.
      C. Docker will fail to start because of volume issues.
      D. Pytest will run both tests and exit with a non-zero code indicating failure.

      Solution

      1. Step 1: Understand pytest behavior on failures

        Pytest runs all tests and returns a non-zero exit code if any test fails.
      2. Step 2: Confirm Docker command mounts tests correctly

        The volume mounts current directory to /tests, so test_sample.py is accessible and runs.
      3. Final Answer:

        Pytest will run both tests and exit with a non-zero code indicating failure. -> Option D
      4. Quick Check:

        Failing test causes pytest exit code != 0 [OK]
      Hint: Pytest exit code shows if tests passed or failed [OK]
      Common Mistakes:
      • Assuming pytest skips failing tests
      • Thinking Docker volume mount fails here
      • Believing pytest ignores failures
      4. You run this command:
      docker run -v $(pwd):/app python:3.12 pytest

      But pytest does not find any tests. What is the most likely cause?
      medium
      A. You did not set the working directory inside the container.
      B. The Python image does not have pytest installed.
      C. Docker volume syntax is incorrect.
      D. Tests must be named test_docker.py to run.

      Solution

      1. Step 1: Check working directory usage

        Without -w /app, pytest runs in root, not where tests are mounted.
      2. Step 2: Understand pytest test discovery

        Pytest looks for tests in current directory; wrong directory means no tests found.
      3. Final Answer:

        You did not set the working directory inside the container. -> Option A
      4. Quick Check:

        Working directory missing = no tests found [OK]
      Hint: Always set -w to your mounted test folder [OK]
      Common Mistakes:
      • Assuming pytest is missing in python image by default
      • Blaming volume syntax without error
      • Thinking test file names must be exact
      5. You want to run pytest inside Docker and save the test report to your host machine. Which command correctly achieves this?
      hard
      A. docker run -v $(pwd):/app -w /app python:3.12 pytest --junitxml=/tmp/report.xml
      B. docker run python:3.12 pytest --junitxml=/app/report.xml
      C. docker run -v $(pwd):/app -w /app python:3.12 pytest --junitxml=/app/report.xml
      D. docker run -v $(pwd):/app python:3.12 pytest --junitxml=report.xml

      Solution

      1. Step 1: Ensure volume mount and working directory

        Mount current directory to /app and set working directory to /app so files are accessible.
      2. Step 2: Specify report path inside container

        Use --junitxml=/app/report.xml to save report inside mounted folder, making it visible on host.
      3. Final Answer:

        docker run -v $(pwd):/app -w /app python:3.12 pytest --junitxml=/app/report.xml -> Option C
      4. Quick Check:

        Volume + workdir + report path inside mount = correct [OK]
      Hint: Set -w and use full path for report inside mounted folder [OK]
      Common Mistakes:
      • Not setting working directory with -w
      • Using relative path without mount inside container
      • Omitting volume mount so report is lost