Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Backtick after URL in error message linkified on GitHub Actions workflow logs #51

Closed
4 tasks done
karlhorky opened this issue Sep 27, 2024 · 9 comments
Closed
4 tasks done
Labels
🙅 no/wontfix This is not (enough of) an issue for this project 👎 phase/no Post cannot or will not be acted on

Comments

@karlhorky
Copy link
Contributor

karlhorky commented Sep 27, 2024

Initial checklist

Affected packages and versions

remark-lint-no-dead-urls@2.0.0

Link to runnable example

No response

Steps to reproduce

  1. Run remark-lint-no-dead-urls on GitHub Actions and click on a failing link in the output
  2. 💥 The link includes the backtick, encoded as %60, likely leading to confusion

You can see it here, the backtick is also underlined and has a gray color:

Screenshot 2024-09-27 at 19 13 57

Screenshot 2024-09-27 at 19 13 50

As text:

17:124-17:180    warning Unexpected dead URL `https://trekhleb.dev/js-image-carver/`, expected live URL                                                                                                                                                                                                                        no-dead-urls remark-lint
  [cause]:
                 error   Unexpected error fetching `https://trekhleb.dev/js-image-carver/`                                                                                                                                                                                                                                     fetch        dead-or-alive
  [cause]:
    TimeoutError: The operation was aborted due to timeout

Expected behavior

Links do not include extra suffix or prefix characters which will be linkified by GitHub

Actual behavior

Links include the extra suffix backtick character which will be linkified by GitHub

Runtime

No response

Package manager

No response

OS

No response

Build and bundle tools

No response

@github-actions github-actions bot added 👋 phase/new Post is being triaged automatically 🤞 phase/open Post is being triaged manually and removed 👋 phase/new Post is being triaged automatically labels Sep 27, 2024
@ChristianMurphy
Copy link
Member

Thanks for sharing @karlhorky!
Similar to #50 this feels more like a reporter than something that needs-to-be/should be fixed here.

@wooorm
Copy link
Member

wooorm commented Sep 30, 2024

It is intentional that markdown syntax is used in message reasons.

If GitHub Actions has a “linkifier” that doesn’t work, report it with them.

@wooorm wooorm closed this as not planned Won't fix, can't repro, duplicate, stale Sep 30, 2024
@wooorm wooorm added the 🙅 no/wontfix This is not (enough of) an issue for this project label Sep 30, 2024
@github-actions github-actions bot added 👎 phase/no Post cannot or will not be acted on and removed 🤞 phase/open Post is being triaged manually labels Sep 30, 2024
@karlhorky
Copy link
Contributor Author

karlhorky commented Sep 30, 2024

If GitHub Actions has a “linkifier” that doesn’t work, report it with them.

I would, but the likelihood of GitHub fixing bugs is... unlikely. There are many open bugs since years that are very publicly reported. After many 10s or 100s of hours of reporting bugs without any feedback, it's becoming clear that it's not worth reporting bugs to GitHub.

In my opinion, projects should instead work around the bugs in GitHub. But I don't think this opinion is shared by the MDX team.

I guess I'll have to come up with a way to fix the output of remark-lint-no-dead-urls using sed or something (or maybe it could be a Refined GitHub feature). The suggestion to build a custom reporter sounds like a lot of work + research + investment.

markdown syntax is used in message reasons

I can understand that. However, I guess I would argue that using a inline code block with backticks around a URL is unnecessary and error-prone. I usually try to avoid having any characters close to URLs that I write in any format, because of linkification problems like this, across lots of software, not only GitHub.

@wooorm
Copy link
Member

wooorm commented Sep 30, 2024

In my opinion, projects should instead work around the bugs in GitHub. But I don't think this opinion is shared by the MDX team.

You can make a GH reporter.

However, I guess I would argue that using a inline code block with backticks around a URL is unnecessary and error-prone

I disagree. URLs are not grammatical values. They are code.

@karlhorky
Copy link
Contributor Author

karlhorky commented Sep 30, 2024

What about a middle path - adding a space inside the backticks on both ends? Then the URL still stays as code, but the backtick character isn't directly next to the URL.

@remcohaszing
Copy link
Member

I don’t really mind whether or not the URL is surrounded by backticks, but I agree with Titus that this is a problem with GitHub’s link detection.

@wooorm
Copy link
Member

wooorm commented Sep 30, 2024

I do not think that is a middle path; I think that is ugly for everybody else.
If GH doesn’t work well for you, make a reporter to make it work well, or use a different tool that works well, such as your local editor.

@karlhorky
Copy link
Contributor Author

karlhorky commented Sep 30, 2024

Ok, I understand this will not be accepted, but one last thing:

If GH doesn't work well for you

This is actually not as much about me (I'll probably remember, for a few weeks / months at least). And I'll probably build some workaround, so that I and others on our team don't need to remember.

But it's more about confusing all users who click on remark-lint-no-dead-urls links in a very common tool / environment. (who would not have the workaround installed, so thus have broken links by default)

@ChristianMurphy
Copy link
Member

ChristianMurphy commented Sep 30, 2024

But it's more about confusing all users who click on remark-lint-no-dead-urls links in a very common tool / environment. (who would not have the workaround installed, so thus have broken links by default)

I hear you, understand you, and appreciate your viewpoint.
There can be (and are) bugs in common and popular tools that should be fixed right there at the origin.
Many are quickly fixed. 🎉

If any get stuck (case and point jestjs/jest#9430 still blocks usage of ESM) the recommendation for users who are frustrated is to move to another tool entirely.


Mandatory XKCD reference 😉

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
🙅 no/wontfix This is not (enough of) an issue for this project 👎 phase/no Post cannot or will not be acted on
Development

No branches or pull requests

4 participants