Edit in GitHubLog an issue

Overview

During your development, it's important to be able to debug your code and troubleshoot any issues that may arise. Fortunately, most modern browsers come with built-in developer tools that can help you do just that.

Introduction

Check out this short video below on how to test and debug your add-on to help you get started more quickly, then read on for more details.

Browser Developer Tools

Some of the key debugging features available in the browser developer tools include:

  • Console - The console allows you to log messages and errors from your code, as well as execute JavaScript code and interact with the page or add-on.
  • Debugger - The debugger allows you to set breakpoints in your code and step through it line by line, so you can see exactly what's happening at each stage of execution.
  • Network Monitor - The network monitor allows you to monitor the network requests made by your add-on, so you can see how it's interacting with other resources and services.
  • Profiler - The profiler allows you to analyze the performance of your add-on and identify areas where it may be slow or inefficient.

Debugging Steps

To get started with debugging your add-on:

Access the developer tools by right-clicking on the browser window where Adobe Express is running, and selecting Inspect Element or Inspect from the context menu.

inspect

Next, navigate to the Sources tab, and from there you can locate and select the JavaScript file that contains the code you want to debug. You can locate it in the filesystem list or by using the Search tab. If the Search tab isn't displayed, clicking the 3 vertical dots will reveal it as shown below:

locate source

Once you've selected your file, you can set breakpoints by clicking on the line number where you want the breakpoint to be set. This will pause the execution of your code at that breakpoint, allowing you to inspect variables and step through your code one line at a time.

By leveraging these tools, you will develop a deeper understanding of how your add-on is working, be able to identify and fix bugs more quickly, and benefit from a high-performing add-on.

Console

When logging messages in your code, use the appropriate severity level that best describes the message. For example, an Info message might be used to provide general information about the application's state, while a Warning message might be used to alert developers about potential issues that could cause problems with the add-on. Similarly, an Error message might be used to indicate that an unexpected error has occurred, and a Verbose message might be used to see more descriptive information about the internal workings of the processing occurring in your add-on.

Use the console.* methods as shown below to represent the severity level you would like to see for debugging:

Copied to your clipboard
console.log('Info level)
console.warn('Warning level')
console.error('Error level)
console.debug(Verbose level)

You can specifically filter which levels you want to view in the developer tools with the Custom levels drop-down as well to help you find your specific messages more quickly:

custom levels

To make it easier to filter and identify relevant messages in the console, it's also a good practice to include an obvious identifier as a prefix. This identifier could be a unique string or tag that is specific to your add-on, making it easier to distinguish your messages from other messages in the console. For example: console.log([MyAddOn] - Initialization complete);. Then you can filter on MyAddOn in the devtools and easily see what is relevant to your add-on.

Using appropriate severity levels and including identifiers in your console messages can greatly help improve the efficiency and effectiveness of your debugging, making it easier to identify and resolve issues.

Printing JSON Data

Another helpful console method is .dir(), which displays a JSON representation of an object. For example, running console.dir(document.head) would generate the following output:

console.dir method

Add-on SDK Developer Tools

The Add-on Development tools panel provides useful logging details and action buttons to allow for refreshing and clearing the data associated with your add-on, which are also useful for debugging and troubleshooting your add-on.

add-ons tools screenshot

Status messages

The Add-on Development panel also provides useful information via status messages like below to indicate when and where an error is occurring to help you target specific issues in your add-on. For instance, if an invalid value is found in the manifest, you will see something like the following:

manifest error screenshot

Refreshing and clearing data

The Refresh and Clear data buttons in the add-on developer tools can also be helpful when you want to manually force refresh your code (or when you update the manifest), or clear data you no longer want to persist. For instance, in the case of the ToDo list sample add-on (aka: use-client-storage), if you had added some items previously they will still be displayed when you open it again unless you actually clear the data. See the demo workflow video at the bottom of the boilerplate section for an example of this in action.

add-ons tools clear data screenshot

application tab indexed db screenshot

  • Privacy
  • Terms of Use
  • Do not sell or share my personal information
  • AdChoices
Copyright © 2025 Adobe. All rights reserved.