-
-
Notifications
You must be signed in to change notification settings - Fork 42
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
Baseline should still work when allowed namespaces are changed #377
Comments
@LuigiCardamone in #365 you proposed to store the rule name and rule parameters for the baseline. the problem with using the name is when we have name clashes. and i think storing the rule parameters means that a baseline entry will still not match any longer if e.g. an additional namespace is added, or one is removed. imo the baseline should not care about that - if the scan finds a problem that we have previously seen and is thus stored in the baseline, we want to ignore it. |
@dbu you are right, since in #365 I wrote the wrong name. Please, consider
Like you, I was thinking that the line number in the baseline is useless for many rules . P.S. |
i thought you meant the reason that the user gives when setting the rules. when users provide that, i expect some people copy-paste and don't notice that they could adjust the name. i don't see explicit rule names in the code. e.g. DependsOnlyOnTheseNamespaces creates a violation and just creates the message on the fly. if you mean to add a rule identifier name to every rule, i think that is the best approach to this, as it keeps the freedom to tweak the message that is printed without breaking the baseline. the identifier could even be the class name i think. |
Yes, the class name of the rule (e.g. DependsOnlyOnTheseNamespaces) can be a good starting point. |
Feature Request
Summary
The baseline stores the full error message, which in case of namespace rules contains the list of all allowed namespaces. When the configuration is changed, all baseline entries no longer match.
The part that explains what is allowed
...but should depend only on classes in one of these namespaces ...
should not be part of the baseline and not be required to match.My idea would be to split the exception message into the actual
error
and ahint
part. The hint should not be stored in the baseline and not be used when comparing with the baseline.The text was updated successfully, but these errors were encountered: