-
Notifications
You must be signed in to change notification settings - Fork 538
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
chore(lint): refactor Markdown linting to use markdownlint-cli2 #2234
Conversation
This switches from `markdownlint-cli` to `markdownlint-cli2` and drops usage of the https://github.com/avto-dev/markdown-lint GitHub action in CI. - The `avto-dev/markdown-lint` action was using a 4y old version of `markdownlint`. AFAICT that action is not being maintained. - There is a new `npm run lint:markdown` and the `lint.yml` CI workflow uses it. - The switch from `markdownlint-cli` to `markdownlint-cli2` and `.markdownlint-cli2.jsonc` as the config allows using the https://marketplace.visualstudio.com/items?itemName=DavidAnson.vscode-markdownlint VSCode plugin for in-editor Markdown lint warnings and intellisense in the config file. Refs: open-telemetry/opentelemetry-js#4713
This updated markdown linting actually catches the errant |
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## main #2234 +/- ##
==========================================
- Coverage 90.97% 90.38% -0.60%
==========================================
Files 146 147 +1
Lines 7492 7506 +14
Branches 1502 1573 +71
==========================================
- Hits 6816 6784 -32
- Misses 676 722 +46 |
.markdownlint-cli2.jsonc
Outdated
// XXX Rules to discuss: | ||
"MD012": false // no-multiple-blanks, common in CHANGELOG.md files, ~1700 hits in changelog files | ||
// "MD004": { "style": "dash" } // ul-style, ~3800 hits in 63 changelog files, XXX discuss just using "consistent" new default for dash |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@blumamir I'd like to discuss these two rules.
"MD012": false
This is not disabled in the core repo. If re-enabled in the contrib repo here, there are approximately 1700 hits (a) in most of the 63 CHANGELOG.md files and (b) a few hits in these files:
1 plugins/node/opentelemetry-instrumentation-mysql/README.md
3 .github/ISSUE_TEMPLATE/plugin_request.md
4 .github/ISSUE_TEMPLATE/feature_request.md
6 .github/ISSUE_TEMPLATE/bug_report.md
I think the cases in the CHANGELOG.md files will just keep happening because they are generated by release-please, we do not want this rule enabled for them. There are two options:
- globally disable the rule in this config file
- locally disable the rule for each CHANGELOG.md file. This is slightly burdensome (just a onetime edit) because there are 63 changelog files.
Thoughts?
MD004
Earlier we changed to style: "dash"
to prefer dashes for bullets. In the core repo we disabled this rule locally in the 2 changelog files. Options:
- Disable it locally in the 63 changelog files -- similar to how we did in the core repo.
- Use the newer default of
"consistent"
, which ensures that each file is consistent in the bullets it uses. That means the rule could apply to CHANGELOG.md files as well, but would enforce consistent*
usage.
Thoughts?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think the cases in the CHANGELOG.md files will just keep happening because they are generated by release-please, we do not want this rule enabled for them. There are two options:
- globally disable the rule in this config file
- locally disable the rule for each CHANGELOG.md file. This is slightly burdensome (just a onetime edit) because there are 63 changelog files.
Thoughts?
Another alternative would be to use 2 markdown configs, one for CHANGELOG and one for other markdowns. I don't mind disabling it across the repo, but could be nice to have it if not too complex.
Earlier we changed to
style: "dash"
to prefer dashes for bullets. In the core repo we disabled this rule locally in the 2 changelog files. Options:
If we have different config file for CHANGELOGs than this is addressed as well, but if not straight-forward than we can disable it locally in each file or use the "consistent"
option. What ever is easier and makes more sense to you
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'd prefer to not have two separate config files, because:
- it would be more likely for those config files to diverge,
- it is a little messy to have yet another config file at the top,
- it will mean markdownlint editor plugins (like the VSCode one referred to above) won't work properly -- the plugin will just use the default
.markdownlint-cli2.jsonc
file
In commit 2e03f59 I've opted to avoid <!-- markdownlist-disable ... -->
directives in every CHANGELOG.md file by selecting options that work for all .md files. That means ul-style: consistent
and no-multiple-blanks: false
.
(A personal preference note: I like using multiple blank lines sometimes, both in Markdown and code, to separate bigger sections vs. a single line for related blocks. So I was never a fan of no-multiple-blank
lines and the eslint equivalent in code.)
…CHANGELOG.md file and choose options that work for all .md files
This switches from
markdownlint-cli
tomarkdownlint-cli2
and dropsusage of the https://github.com/avto-dev/markdown-lint GitHub action in CI.
avto-dev/markdown-lint
action was using a 4y old version ofmarkdownlint
.AFAICT that action is not being maintained.
npm run lint:markdown
and thelint.yml
CI workflow uses it.markdownlint-cli
tomarkdownlint-cli2
and.markdownlint-cli2.jsonc
as the config allows using the https://marketplace.visualstudio.com/items?itemName=DavidAnson.vscode-markdownlint
VSCode plugin for in-editor Markdown lint warnings and intellisense in the config file.
Refs: open-telemetry/opentelemetry-js#4713
Refs: #2207
The same was done in the core repo in open-telemetry/opentelemetry-js#4713