Skip to content

Using the Linked File feature and the line_code URL fragment with only a single file causes unresolvable errors

Problem

When using the Linked File feature, a defect with the addLineReferences method called from the ADD_CONTEXT_LINES mutation is exposed.

This call triggers an uncaught fatal error, which is displayed in the UI as multiple errors that can't be resolved as long as the URL contains both the ?file=[sha] search parameter and the #[sha]_n_n line code.

Expected Behavior

  1. There should not be visible errors
  2. The Linked file feature should continue to work

Replication

  1. Create an MR that modifies a single file
  2. Leave a comment on the Diff file
  3. Either:
    1. Enable the Linked File feature by adding the code from !181163 (merged) OR
    2. Get the file hash for the file
  4. Use the same step here depending on how you got the file hash in the URL in the previous step:
    1. Click the filename in the Diff file header above your comment on the Overview tab
    2. Click the filename in the Diff file header above your comment on the Overview tab and add the file hash to the URL before any # fragments like: ?file=[hash]#...

Possible fixes

Partial call stack

  1. fetchLinkedExpandedLine
  2. loadMoreLines
  3. ADD_CONTEXT_LINES
  4. addLineReferences 👈🏻 Fatal error is thrown here, as targetLine is undefined. The sought index is out of bounds in previous lines, resulting in no line being returned.

Context

The following discussion from !181163 (merged) should be addressed:

  • @thomasrandolph started a discussion:

    There is a known bug exposed by this change that shows multiple errors on the Changes tab when the line that is linked to does not refer to a valid line in the other version (old vs. new).

    For example, if the linked discussion points to new line 5, but the old file only had 3 lines, the Changes tab will show multiple errors. Everything will still work, but - in addition to multiple errors - there's a big button that says "Reload page", which results in the same error.

    • These errors are unrelated to these changes but are exposed by the overlap of the ?file=[sha] parameter enabling Linked Files and the #[sha]_n_n hash linking to a line directly.
    • Because the button simply reloads the page, the user is stuck in an unresolvable loop / invalid error condition.
Edited by Thomas Randolph