Edit

Share via


Troubleshoot event-based and spam-reporting add-ins

As you develop your event-based or spam-reporting add-in, you may encounter issues, such as your add-in not loading or an event not occurring. The following sections provide guidance on how to troubleshoot your add-in.

Review feature prerequisites

Check manifest and JavaScript requirements

  • Ensure that the following conditions are met in your add-in's manifest.

    • Verify that your add-in's source file location URL is publicly available and isn't blocked by a firewall. This URL is specified in the SourceLocation element of the add-in only manifest or the "extensions.runtimes.code.page" property of the unified manifest for Microsoft 365.

    • Verify that the <Runtimes> element (add-in only manifest) or "extensions.runtimes.code" property (unified manifest) correctly references the HTML or JavaScript file containing the event handlers. Classic Outlook on Windows and other Windows-based Office applications use the JavaScript file during runtime, while Office on the web, the new Outlook Mac UI, and new Outlook on Windows use the HTML file. For an example of how this is configured in the manifest, see the "Configure the manifest" section of Automatically set the subject of a new message or appointment.

      For Windows clients (except for new Outlook on Windows), you must bundle all your event-handling JavaScript code into this JavaScript file referenced in the manifest. Note that a large JavaScript bundle may cause issues with the performance of your add-in. We recommend preprocessing heavy operations, so that they're not included in your event-handling code.

  • For Windows clients (except for new Outlook on Windows), when the JavaScript function specified in the manifest to handle an event runs, code in Office.onReady() and Office.initialize isn't run. We recommend adding any startup logic needed by event handlers, such as checking the user's client version, to the event handlers instead.

  • Verify that your event-handling JavaScript file calls Office.actions.associate. This ensures that the event handler name specified in the manifest is mapped to its JavaScript counterpart. The following code is an example.

    Office.actions.associate("onNewMessageComposeHandler", onNewMessageComposeHandler);
    
  • In classic Outlook on Windows versions prior to Version 2403 (Build 17425.20000), the JavaScript code of event-based and spam-reporting add-ins only supports ECMAScript 2016 and earlier specifications. Some examples of programming syntax to avoid are as follows.

    • Avoid using async and await statements in your code. Including these in your JavaScript code will cause the add-in to time out.
    • Avoid using the conditional (ternary) operator as it will prevent your add-in from loading.

    If your add-in has only one JavaScript file referenced by Outlook on the web, on Windows (new and classic), and on Mac, you must limit your code to ECMAScript 2016 to ensure that your add-in runs in earlier versions of classic Outlook on Windows. However, if you have a separate JavaScript file referenced by Outlook on the web, on Mac, recent versions of classic Outlook on Windows, and the new Outlook on Windows, you can implement a later ECMAScript specification in that file.

Check your webpack configuration

On Windows clients (except for the new Outlook on Windows), if your event-based add-in uses webpack to bundle files and the event handlers never run, configure your add-in's webpack dev server to serve static files. This approach prevents webpack from adding code to your add-in's files that may be incompatible with the JavaScript runtime. Configure your add-in to use static files as follows:

  1. In the webpack.config.js file of your add-in, import the Node.js path module.

    const path = require("path");
    
  2. In the same file, configure the webpack dev server to serve static files from the dist folder.

    ...
    devServer: {
      static: {
        directory: path.join(__dirname, "dist"),
        publicPath: "/public",
      },
      ...
    }
    ...
    
  3. Run npm run build.

  4. In your add-in's manifest, update the path to the event-handling JavaScript file to reference the built file served from the static directory. For example, https://localhost:3000/public/launchevent.js.

Debug your add-in

  • As you make changes to your add-in, be aware that:

    • If you update the manifest, remove the add-in, then sideload it again. For information on how to remove a sideloaded add-in from Outlook, see Sideload Outlook add-ins for testing. If you're using Outlook on Windows, you must also close and reopen Outlook.
    • If you make changes to files other than the manifest, close and reopen the Office client on Windows or on Mac, or refresh the browser tab running Office on the web.
    • If you're still unable to see your changes after performing these steps, clear your Office cache.
  • As you test your add-in in Office on Windows (excluding the new Outlook on Windows):

    • For event-based add-ins, check Event Viewer for any reported add-in errors.

      1. In Event Viewer, select Windows Logs > Application.
      2. From the Actions panel, select Filter Current Log.
      3. From the Logged dropdown, select your preferred log time frame.
      4. Select the Error checkbox.
      5. In the Event IDs field, enter 63.
      6. Select OK to apply your filters.

      A sample of Event Viewer's Filter Current Log settings configured to only show Outlook errors with event ID 63 that occurred in the last hour.

    • Verify that the bundle.js file is downloaded to the following folder in File Explorer. The text enclosed in [] represents your applicable Office and add-in information.

      %LOCALAPPDATA%\Microsoft\Office\16.0\Wef\{[Office profile GUID]}\[Office account encoding]\Javascript\[Add-in ID]_[Add-in Version]_[locale]
      

      Tip

      • For readability, this article refers to the file name as bundle.js, but exact name depends on the Office application.
        • Excel: bundle_excel.js
        • Outlook: bundle.js.
        • PowerPoint: bundle_powerpoint.js
        • Word: bundle_word.js
      • There's no direct method to determine the Office profile GUID and account encoding used in the bundle.js file path. The most effective approach to locate your add-in's bundle.js file is to manually inspect each folder until you locate the Javascript folder that contains your add-in's ID.
      • The bundle.js file is downloaded to the local Wef folder when the add-in is first installed. It's refreshed every time the Office application starts or is restarted. If the bundle.js file doesn't appear in the Wef folder and your add-in is installed or sideloaded, restart Office. For Outlook, you may need to remove your add-in, then sideload it again.
  • As you test your add-in on desktop clients (excluding new Outlook on Windows) enable runtime logging to identify possible manifest and add-in installation issues. For guidance on how to use runtime logging, see Debug your add-in with runtime logging.

  • Set breakpoints in your code to debug your add-in. For platform-specific instructions, see Debug event-based and spam-reporting add-ins.

Seek additional help

If you still need help after performing the recommended troubleshooting steps, open a GitHub issue. Include screenshots, video recordings, or runtime logs to supplement your report.

See also