Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Conversation

unvalley
Copy link
Member

@unvalley unvalley commented Aug 22, 2025

Summary

Closes #6695

This PR updates the useNamingConvention lint rule so that it reports violations on TypeScript parameter properties even when modifiers are present, ensuring they still follow the naming convention.

The rule should report parameter properties

classProperty: class properties, including parameter properties
https://biomejs.dev/linter/rules/use-naming-convention/#typescript-type-parameter-names

Test Plan

  • Added snapshot test

Docs

@changeset-bot
Copy link

changeset-bot bot commented Aug 22, 2025

🦋 Changeset detected

Latest commit: 6bffe05

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 13 packages
Name Type
@biomejs/biome Patch
@biomejs/cli-win32-x64 Patch
@biomejs/cli-win32-arm64 Patch
@biomejs/cli-darwin-x64 Patch
@biomejs/cli-darwin-arm64 Patch
@biomejs/cli-linux-x64 Patch
@biomejs/cli-linux-arm64 Patch
@biomejs/cli-linux-x64-musl Patch
@biomejs/cli-linux-arm64-musl Patch
@biomejs/wasm-web Patch
@biomejs/wasm-bundler Patch
@biomejs/wasm-nodejs Patch
@biomejs/backend-jsonrpc Patch

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

@coderabbitai
Copy link
Contributor

coderabbitai bot commented Aug 22, 2025

Walkthrough

The PR updates use_naming_convention logic to handle TypeScript parameter properties with modifiers in selector_from_binding_declaration. It derives modifiers from TsPropertyParameter, ignores Override, and applies restricted modifiers consistent with other class members. A new From impl converts TsPropertyParameterModifierList to BitFlags. Tests are added to validate that private/readonly parameter properties are checked by classProperty and classMember selectors. A changeset documents the patch release notes. No exported/public API signatures are changed.

Assessment against linked issues

Objective Addressed Explanation
Apply useNamingConvention selectors classProperty/classMember to TS parameter properties, respecting modifiers (private/readonly) (#6695)

Assessment against linked issues: Out-of-scope changes

(No out-of-scope functional changes identified.)

Suggested reviewers

  • siketyan

Tip

🔌 Remote MCP (Model Context Protocol) integration is now available!

Pro plan users can now connect to remote MCP servers from the Integrations page. Connect with popular remote MCPs such as Notion and Linear to add more context to your reviews and chats.

✨ Finishing Touches
  • 📝 Generate Docstrings
🧪 Generate unit tests
  • Create PR with unit tests
  • Post copyable unit tests in a comment

Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out.

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

‼️ IMPORTANT
Auto-reply has been disabled for this repository in the CodeRabbit settings. The CodeRabbit bot will not respond to your replies unless it is explicitly tagged.

  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.

Support

Need help? Create a ticket on our support page for assistance with any issues or questions.

CodeRabbit Commands (Invoked using PR/Issue comments)

Type @coderabbitai help to get the list of available commands.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

Status, Documentation and Community

  • Visit our Status Page to check the current availability of CodeRabbit.
  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

@github-actions github-actions bot added A-Linter Area: linter A-Parser Area: parser L-JavaScript Language: JavaScript and super languages labels Aug 22, 2025
@codspeed-hq
Copy link

codspeed-hq bot commented Aug 22, 2025

CodSpeed Performance Report

Merging #7298 will not alter performance

Comparing unvalley:fix-naming-convention-for-parameter-property (6bffe05) with main (660031b)

Summary

✅ 133 untouched benchmarks

@unvalley unvalley marked this pull request as ready for review August 22, 2025 18:35
Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

🧹 Nitpick comments (4)
.changeset/red-baboons-rush.md (1)

5-7: Add a minimal before/after example in the changeset for users.

Release note reads well and follows tense/punctuation. Consider adding a short snippet to make the change immediately tangible.

Example to append:

#### Example.

Before (was not reported):
```ts
class C {
  constructor(private readonly badName: string) {}
}

After (reported; underscore required by configuration):

class C {
  constructor(private readonly _goodName: string) {}
}

</blockquote></details>
<details>
<summary>crates/biome_js_analyze/tests/specs/style/useNamingConvention/invalidParameterPropertyWithModifiers.ts (1)</summary><blockquote>

`1-7`: **Nice negative case; add a couple of companions to shore up coverage.**

You’re exercising the private+readonly path. Please also cover:
- private without readonly.
- a clearly valid example with the underscore.

Suggested additions (new files in the same folder):

```ts
// invalidParameterPropertyWithoutReadonly.ts
class SomeClass2 {
  // invalid per rules (no underscore)
  constructor(private private4: string) {}
}
// validParameterPropertyWithModifiers.ts
class OkClass {
  private readonly _p1: string;
  constructor(private readonly _p2: string) {}
}

If you prefer single-file snapshots, we can split by folder-level options instead.

I can wire up the matching .options.json for the new tests if helpful.

crates/biome_js_syntax/src/modifier_ext.rs (1)

202-209: Consistent import style for TsPropertyParameterModifierList (tiny tidy-up).

All other impls use the imported type rather than a crate::-qualified path. Aligning improves readability.

Apply within this hunk:

-impl From<&crate::TsPropertyParameterModifierList> for enumflags2::BitFlags<Modifier> {
-    fn from(value: &crate::TsPropertyParameterModifierList) -> Self {
+impl From<&TsPropertyParameterModifierList> for enumflags2::BitFlags<Modifier> {
+    fn from(value: &TsPropertyParameterModifierList) -> Self {
         value
             .into_iter()
             .map(|m| Modifier::from(&m))
             .fold(Self::empty(), |acc, m| acc | m)
     }
 }

And add the import alongside the other lists:

// outside the selected range:
use crate::{
    // ...
    TsPropertyParameterModifierList,
    // ...
};
crates/biome_js_analyze/src/lint/style/use_naming_convention.rs (1)

1209-1220: Correctly treats parameter properties as classProperty and respects modifiers.

Deriving BitFlags<Modifier> from param.modifiers() and ignoring override mirrors the class member path. This should close the gap for parameter properties.

Follow-ups to make this bulletproof:

  • Add tests for:
    • private parameter property without readonly (expected diagnostic).
    • a clearly valid private parameter property with underscore (no diagnostic).
  • Optional: if TypeScript allows override on parameter properties in your parser, add a test ensuring it’s ignored.

I can drop in the exact test files if you want them added to this PR.

📜 Review details

Configuration used: Path: .coderabbit.yaml

Review profile: CHILL

Plan: Pro

💡 Knowledge Base configuration:

  • MCP integration is disabled by default for public repositories
  • Jira integration is disabled by default for public repositories
  • Linear integration is disabled by default for public repositories

You can enable these sources in your CodeRabbit configuration.

📥 Commits

Reviewing files that changed from the base of the PR and between 660031b and 6bffe05.

⛔ Files ignored due to path filters (1)
  • crates/biome_js_analyze/tests/specs/style/useNamingConvention/invalidParameterPropertyWithModifiers.ts.snap is excluded by !**/*.snap and included by **
📒 Files selected for processing (5)
  • .changeset/red-baboons-rush.md (1 hunks)
  • crates/biome_js_analyze/src/lint/style/use_naming_convention.rs (1 hunks)
  • crates/biome_js_analyze/tests/specs/style/useNamingConvention/invalidParameterPropertyWithModifiers.options.json (1 hunks)
  • crates/biome_js_analyze/tests/specs/style/useNamingConvention/invalidParameterPropertyWithModifiers.ts (1 hunks)
  • crates/biome_js_syntax/src/modifier_ext.rs (1 hunks)
🧰 Additional context used
📓 Path-based instructions (5)
.changeset/*.md

📄 CodeRabbit inference engine (CONTRIBUTING.md)

.changeset/*.md: Create changesets with just new-changeset; store them in .changeset/ with correct frontmatter (package keys and change type).
In changeset descriptions, follow content conventions: user-facing changes only; past tense for what you did; present tense for current behavior; link issues for fixes; link rules/assists; include representative code blocks; end every sentence with a period.
When adding headers in a changeset, only use #### or ##### levels.

Files:

  • .changeset/red-baboons-rush.md
crates/biome_*_{syntax,parser,formatter,analyze,factory,semantic}/**

📄 CodeRabbit inference engine (CLAUDE.md)

Maintain the per-language crate structure: biome_{lang}_{syntax,parser,formatter,analyze,factory,semantic}

Files:

  • crates/biome_js_analyze/tests/specs/style/useNamingConvention/invalidParameterPropertyWithModifiers.ts
  • crates/biome_js_analyze/src/lint/style/use_naming_convention.rs
  • crates/biome_js_analyze/tests/specs/style/useNamingConvention/invalidParameterPropertyWithModifiers.options.json
  • crates/biome_js_syntax/src/modifier_ext.rs
crates/biome_*/**

📄 CodeRabbit inference engine (CLAUDE.md)

Place core crates under /crates/biome_*/

Files:

  • crates/biome_js_analyze/tests/specs/style/useNamingConvention/invalidParameterPropertyWithModifiers.ts
  • crates/biome_js_analyze/src/lint/style/use_naming_convention.rs
  • crates/biome_js_analyze/tests/specs/style/useNamingConvention/invalidParameterPropertyWithModifiers.options.json
  • crates/biome_js_syntax/src/modifier_ext.rs
**/tests/**

📄 CodeRabbit inference engine (CLAUDE.md)

Place test files under a tests/ directory in each crate

Files:

  • crates/biome_js_analyze/tests/specs/style/useNamingConvention/invalidParameterPropertyWithModifiers.ts
  • crates/biome_js_analyze/tests/specs/style/useNamingConvention/invalidParameterPropertyWithModifiers.options.json
**/*.{rs,toml}

📄 CodeRabbit inference engine (CONTRIBUTING.md)

Format Rust and TOML files before committing (use just f/just format).

Files:

  • crates/biome_js_analyze/src/lint/style/use_naming_convention.rs
  • crates/biome_js_syntax/src/modifier_ext.rs
🧠 Learnings (5)
📚 Learning: 2025-08-17T08:56:30.831Z
Learnt from: CR
PR: biomejs/biome#0
File: crates/biome_analyze/CONTRIBUTING.md:0-0
Timestamp: 2025-08-17T08:56:30.831Z
Learning: Applies to crates/biome_analyze/crates/**/tests/specs/**/{invalid*,valid*}.{js,jsx,ts,tsx,css,graphql,jsonc} : Place snapshot test cases under `tests/specs/<group>/<ruleName>/` using files prefixed with `invalid` and `valid`

Applied to files:

  • crates/biome_js_analyze/tests/specs/style/useNamingConvention/invalidParameterPropertyWithModifiers.ts
  • crates/biome_js_analyze/tests/specs/style/useNamingConvention/invalidParameterPropertyWithModifiers.options.json
📚 Learning: 2025-08-11T11:48:27.774Z
Learnt from: CR
PR: biomejs/biome#0
File: crates/biome_formatter/CONTRIBUTING.md:0-0
Timestamp: 2025-08-11T11:48:27.774Z
Learning: Applies to crates/biome_formatter/biome_html_formatter/tests/specs/html/**/options.json : When non-default formatting options are needed for a test group, place an options.json (biome.json format) alongside the .html files in that folder

Applied to files:

  • crates/biome_js_analyze/tests/specs/style/useNamingConvention/invalidParameterPropertyWithModifiers.options.json
📚 Learning: 2025-08-17T08:56:30.831Z
Learnt from: CR
PR: biomejs/biome#0
File: crates/biome_analyze/CONTRIBUTING.md:0-0
Timestamp: 2025-08-17T08:56:30.831Z
Learning: Applies to crates/biome_analyze/crates/biome_js_analyze/lib/src/lint/nursery/*.rs : For new JavaScript lint rules generated by `just new-js-lintrule`, implement the rule in the generated file under `biome_js_analyze/lib/src/lint/nursery/`

Applied to files:

  • crates/biome_js_analyze/tests/specs/style/useNamingConvention/invalidParameterPropertyWithModifiers.options.json
📚 Learning: 2025-08-17T08:56:30.831Z
Learnt from: CR
PR: biomejs/biome#0
File: crates/biome_analyze/CONTRIBUTING.md:0-0
Timestamp: 2025-08-17T08:56:30.831Z
Learning: Applies to crates/biome_analyze/crates/**/tests/specs/**/*.jsonc : `.jsonc` snapshot files must contain an array of code strings; they are interpreted in script mode (no ESM syntax)

Applied to files:

  • crates/biome_js_analyze/tests/specs/style/useNamingConvention/invalidParameterPropertyWithModifiers.options.json
📚 Learning: 2025-08-05T14:43:29.581Z
Learnt from: dyc3
PR: biomejs/biome#7081
File: packages/@biomejs/biome/configuration_schema.json:7765-7781
Timestamp: 2025-08-05T14:43:29.581Z
Learning: The file `packages/biomejs/biome/configuration_schema.json` is auto-generated and should not be manually edited or reviewed for schema issues; any changes should be made at the code generation source.

Applied to files:

  • crates/biome_js_analyze/tests/specs/style/useNamingConvention/invalidParameterPropertyWithModifiers.options.json
🔇 Additional comments (1)
crates/biome_js_analyze/tests/specs/style/useNamingConvention/invalidParameterPropertyWithModifiers.options.json (1)

1-41: LGTM: options exercise both classProperty variants and classMember.

  • Order is specific-to-generic, which is ideal.
  • The schema path looks right relative to this folder.

@Conaclos
Copy link
Member

Thanks!

@unvalley unvalley merged commit 46a8e93 into biomejs:main Aug 23, 2025
33 checks passed
@unvalley unvalley deleted the fix-naming-convention-for-parameter-property branch August 23, 2025 05:54
SkyBird233 pushed a commit to SkyBird233/biomejs that referenced this pull request Aug 28, 2025
SkyBird233 pushed a commit to SkyBird233/biomejs that referenced this pull request Aug 28, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

A-Linter Area: linter A-Parser Area: parser L-JavaScript Language: JavaScript and super languages

Projects

None yet

Development

Successfully merging this pull request may close these issues.

💅 useNamingConvention: selectors classProperty and classMember don't apply to parameter properties

3 participants