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

Add the AvoidExclaimOperator rule to warn about the use of the ! negation operator. Fixes #1826 #1922

Merged
merged 7 commits into from
Sep 6, 2023

Conversation

liamjpeters
Copy link
Contributor

@liamjpeters liamjpeters commented Jun 14, 2023

Add a rule to warn about using the exclamation mark (!) as the negation operator. Suggests using -not instead.

PR Summary

Add the PSAvoidExclaimOperator rule to warn about the use of ! for negation. The rule is disabled by default as many people see this as a stylistic preference. Covered by tests .Fixes #1826

PR Checklist

@liamjpeters
Copy link
Contributor Author

@microsoft-github-policy-service agree

@liamjpeters liamjpeters changed the title WIP: Add the AvoidExclamationPointOperator rule to warn about the use of the exclamation point negation operator. Fixes #1826 Add the AvoidExclamationPointOperator rule to warn about the use of the exclamation point negation operator. Fixes #1826 Jun 14, 2023
@liamjpeters liamjpeters marked this pull request as ready for review June 14, 2023 11:56
@liamjpeters liamjpeters marked this pull request as draft June 16, 2023 13:29
@liamjpeters liamjpeters marked this pull request as ready for review June 16, 2023 13:29
@liamjpeters
Copy link
Contributor Author

@bergmeister - 👋 Can I get a review please? Sorry I didn't see a way to add a reviewer myself 😊 Thanks!

@bergmeister bergmeister self-requested a review June 16, 2023 14:44
Copy link
Collaborator

@bergmeister bergmeister left a comment

Choose a reason for hiding this comment

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

Looks good overall, just a few comments. Not sure on the rule name though, it's definitely rather exclamation mark and not exclamation point. Maybe even as short as ExclaimOperator, since that is the name of the token.

docs/Rules/AvoidExclamationPointOperator.md Outdated Show resolved Hide resolved
docs/Rules/AvoidExclamationPointOperator.md Outdated Show resolved Hide resolved
Rules/AvoidExclamationPointOperator.cs Outdated Show resolved Hide resolved
Rules/AvoidExclamationPointOperator.cs Outdated Show resolved Hide resolved
Rules/Strings.resx Outdated Show resolved Hide resolved
liamjpeters and others added 4 commits June 18, 2023 14:56
Co-authored-by: Christoph Bergmeister <c.bergmeister@gmail.com>
Co-authored-by: Christoph Bergmeister <c.bergmeister@gmail.com>
Co-authored-by: Christoph Bergmeister <c.bergmeister@gmail.com>
@liamjpeters liamjpeters changed the title Add the AvoidExclamationPointOperator rule to warn about the use of the exclamation point negation operator. Fixes #1826 Add the AvoidExclaimOperator rule to warn about the use of the ! negation operator. Fixes #1826 Jun 18, 2023
@liamjpeters
Copy link
Contributor Author

Renamed rule from AvoidExclamationPointOperator to AvoidExclaimOperator

@liamjpeters liamjpeters requested a review from bergmeister June 21, 2023 10:25
@liamjpeters liamjpeters requested a review from bergmeister June 21, 2023 18:56
@liamjpeters
Copy link
Contributor Author

@bergmeister - Thanks for your feedback so far - really helpful 😀. Was there anything else that needs to change for this to be considered for a merge? Anyone else I should be asking for a review from?

@bergmeister bergmeister requested a review from JamesWTruher June 28, 2023 10:15
@bergmeister
Copy link
Collaborator

Added James as well to review. Other than that I just want to test drive it a bit myself for some exploratory testing as the rule is disabled by default so wouldn't get exercised as part of existing test suite scenarios

@liamjpeters
Copy link
Contributor Author

Any news on this? I don't really know what my expectations should be, as this is my first contribution to this project - so please feel free to tell me to cool my jets and just be more patient.

I appreciate this PR doesn't introduce some killer feature that will be used by loads of people - but I'm excited for it and don't want the PR to be abandoned. Equally I'm excited to pick up other issues and open more PRs to improve the tool and my own c#, after testing the waters here.

Is there anything I can do to help?

@bergmeister
Copy link
Collaborator

Sorry for the delay @liamjpeters . It's not a bumper feature but because it can run on any PowerShell code, it's easy to miss a case that could result e.g. in a NullReferenceException. But the feature is not enabled by default, which is great to limit blast radius.
There's actually one thing you could help with, could you run PSSA with this rule enabled against a more complex script like this one as a one off and check there are no exceptions https://github.com/PowerShell/PowerShell/blob/master/build.psm1
Then happy to merge, the rest of the code looks good to me :-)

@liamjpeters
Copy link
Contributor Author

@bergmeister - Good idea to run it on a more complex test file.

I've run the existing and updated PSSA against the Powershell project's build file. No exceptions thrown and no difference in execution time (both take an average of 170ms on my machine over multiple runs - even with my additional rule enabled).

Invoke-ScriptAnalyzer -Path .\build.psm1 -Settings @{Rules = @{ 'PSAvoidExclaimOperator' = @{ Enable = $true }}}

The build file has a mix of usages of -not and ! so is a good candidate. Using a text search there are 33 instances of the "!" character, 9 of them are within strings or comments (leaving 24 being used as negation).

PSSA with the rule enabled correctly flags the 24 negation instances.

Calling Invoke-ScriptAnalyzer with -Fix correctly changes the 24 negation instances.

image

Anything else you can think I should check - please let me know.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Avoid exclamation point operator.
2 participants