JMESPath parser: catch exceptions to show which feed has an error

Created on 12 May 2024, over 1 year ago
Updated 25 May 2024, over 1 year ago

Problem/Motivation

This module's JMESPathParser class does not catch the exceptions of its dependency, so in a CI environment, when a feed fails, you can get an error message like this:

In Parser.php line 466:
                                                                                                                         
  Syntax error at character 0                                                                                            
                                                                                                                         
  ^                                                                                                                      
  Unexpected "eof" token (nud_eof). Expected one of the following tokens: "identifier", "quoted_identifier", "current",  
   "literal", "expref", "not", "lparen", "lbrace", "flatten", "filter", "star", "lbracket"  

However, it would be much more helpful to catch the exception and rethrow it with the feed name so it is immediately clear where the problem is.

Feature request
Status

Needs work

Version

1.0

Component

Code

Created by

🇯🇵Japan ptmkenny

Live updates comments and jobs are added and updated live.
  • Needs tests

    The change is currently missing an automated test that fails when run with the original code, and succeeds when the bug has been fixed.

Sign in to follow issues

Merge Requests

Comments & Activities

  • Issue created by @ptmkenny
  • Open in Jenkins → Open on Drupal.org →
    Core: 9.5.5 + Environment: PHP 7.4 & MySQL 5.7
    last update over 1 year ago
    113 pass
  • Status changed to Needs review over 1 year ago
  • 🇯🇵Japan ptmkenny

    The MR rethrows the exception like this:

    Syntax error for feed MyFeed in file private://yoyo/parsed/my-set.json: Syntax error at character 0 ^ Unexpected "eof" token (nud_eof). Expected one of the following tokens: "identifier", "quoted_identifier", "current", "literal", "expref", "not", "lparen", "lbrace", "flatten", "filter", "star", "lbracket"

    This is very helpful in CI environments where you are importing a bunch of feeds, because now you can immediately tell which import caused the problem just by looking at the error.

  • Pipeline finished with Success
    over 1 year ago
    Total: 393s
    #170762
  • First commit to issue fork.
  • Open in Jenkins → Open on Drupal.org →
    Core: 9.5.5 + Environment: PHP 7.4 & MySQL 5.7
    last update over 1 year ago
    116 pass
  • Status changed to Needs work over 1 year ago
  • 🇳🇱Netherlands megachriz

    It would be useful to see when this exactly fails. It looks like it doesn't occur when there is a syntax error in the JSON, because then there's a RuntimeException. (This error message now includes the JSON string, which was added in Add a feature to display JSON errors Fixed ).

    This needs test coverage. The test should check if the feed name and the file path are getting displayed. Perhaps it needs to be a Kernel test if it turns out to be hard to fit it in an Unit test.

  • Open in Jenkins → Open on Drupal.org →
    Core: 9.5.5 + Environment: PHP 7.4 & MySQL 5.7
    last update over 1 year ago
    116 pass
  • Pipeline finished with Success
    over 1 year ago
    Total: 428s
    #182344
Production build 0.71.5 2024