Skip to content

Debug end to end tests

Jayam Patel edited this page Jul 24, 2024 · 7 revisions

Table of contents

Introduction

Whenever you are debugging tests, you should create a debugging doc to document your work. This helps future contributors if they run into a similar bug in the future. If other people come in later to help you, they can also use the debugging doc to get up to speed on what you've already figured out. You can make a copy of this template debugging doc to get started. Also check out the debugging docs wiki page.

There are many ways to go about debugging an E2E test, but here is one approach:

  1. Create a debugging doc.

  2. Look through the logs from the failed test to try and understand what went wrong. In particular:

    • Look for a line that says just Killed. This line indicates that some process was killed by the operating system for consuming too much memory. It's fairly safe to assume that the test failure was because of that process being killed.
    • Look for the stack trace and error message of the first error. The trace might point you to where the error was thrown in the test code, and the message may help explain what went wrong.
  3. If you don't understand what the error message means, search for it online. Also look through the test code, and core/test/webdriverio_utils/action.js to see if the error message (or something like it) is in our test code.

  4. Enable video recordings and rerun the test until you reproduce the error. Then watch the video recordings and follow along in the test code. Try and understand why the error was thrown.

  5. Try and reproduce the error locally. If you succeed, you can use your local debugger to investigate.

Using the debugger

  1. Add a break-point in the code you want the control to stop at by adding the line await browser.debug();. For example:

    ...
    await adminPage.get();
    await adminPage.updateRole('moderator1', 'moderator');
    await browser.debug();
    await adminPage.viewRolesbyUsername('moderator1');
    ...
  2. Run the e2e script with arg DEBUG=true (or with the flag --debug_mode in python setup). For example,

    Python:

    python -m scripts.run_e2e_tests --debug_mode --suite="topicAndStoryEditor"

    Docker:

    make run_tests.e2e suite=topicAndStoryEditor DEBUG=true
  3. Wait for the script to show the following log:

    The execution has stopped!
    You can now go into the browser or use the command line as REPL
    (To exit, press ^C again or type .exit)
    
  4. The control will stop at the point where the browser.debug() statement was added. You can now choose to inspect elements, log variables in the test, or add more break-points. For logging variable names, just type the name of the variable in the terminal.

  5. To continue the tests you need to enter .exit in the terminal and press enter. The test will continue running in the same browser instance.

Downloading screenshots

We capture screenshots of failing tests. On GitHub Actions, look for an Artifacts link in the upper right where you can download a zip file of the screenshots:

Screenshot of E2E test run on GitHub Actions with artifacts link in upper right

Screenshots, have a filename that follows the name of the test from which the screenshot was captured. For example, Topic-editor-functionality-should-publish-and-unpublish-a-story-correctly.png.

Downloading screen recordings

When screen recordings are enabled, we capture video of the test running on GitHub Actions. This helps developers solve problems in E2E tests that only occur on CI or are difficult to replicate locally.

To enable screen recordings on GitHub Actions, you need to set the VIDEO_RECORDING_IS_ENABLED environment variable to 1 in your GitHub Actions workflow file, and for enabling it locally, you need to set the LOCAL_VIDEO_RECORDING_IS_ENABLED variable to 1 in 'wdio.conf.js' file. Note that screen recordings are still not saved if the test passes (though you can change this behavior by setting saveAllVideos to true in wdio.conf.js).

Each individual test within each suite gets its own video. The video of each test gets a randomly assigned name, and this gets printed out above the suite, like this:

Name of video for test gets printed out above test

To download a zip file of the videos, look for the Artifacts link in the top-right of your test run.

Artifacts Tab at the top-right

If you don’t see the Artifacts link, go to the summary of the failing workflow, you will see the artifacts at the bottom of that page too.

Artifacts section in summary of e2e run

Note for macOS: Quicktime doesn’t seem to like the videos we generate, so you might need to use VLC media player to view the videos.

Core documentation


Developing Oppia


Developer Reference

Clone this wiki locally