-
Notifications
You must be signed in to change notification settings - Fork 94
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
Implement v1->v2 conversion for rules dictionary #1232
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
{ | ||
"$schema": "http://json.schemastore.org/sarif-2.0.0-csd.2.beta.2018-10-10", | ||
"version": "2.0.0-csd.2.beta.2018-10-10", | ||
"$schema": "http://json.schemastore.org/sarif-2.0.0-csd.2.beta.2018-11-28", | ||
"version": "2.0.0-csd.2.beta.2018-11-28", | ||
"runs": [ | ||
{ | ||
"tool": { | ||
|
@@ -10,30 +10,32 @@ | |
"results": [ | ||
{ | ||
"ruleId": "C2001", | ||
"ruleIndex": 0, | ||
"message": { | ||
"arguments": [ "someVariable" ], | ||
"messageId": "default" | ||
} | ||
}, | ||
{ | ||
"ruleId": "C2001", | ||
"ruleIndex": 0, | ||
"message": { | ||
"arguments": [ "anotherVariable" ], | ||
"messageId": "default" | ||
} | ||
}, | ||
{ | ||
"ruleId": "C2002-1", | ||
"ruleId": "C2002", | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
See the comment in the visitor code. It was never right to assign a There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. In this case, in the input, the In reply to: 250300944 [](ancestors = 250300944) |
||
"message": { "text": "Some testing occurred." } | ||
}, | ||
{ | ||
"ruleId": "C2003", | ||
"ruleIndex": 2, | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
In the input file, this result has no |
||
"message": { "text": "Some testing occurred." } | ||
} | ||
], | ||
"resources": { | ||
"rules": { | ||
"C2001": { | ||
"rules": [ | ||
{ | ||
"id": "C2001", | ||
"shortDescription": { | ||
"text": "A variable was used without being initialized." | ||
|
@@ -45,18 +47,19 @@ | |
"some_key": "FoxForceFive" | ||
} | ||
}, | ||
"C2002": { | ||
{ | ||
"id": "C2002", | ||
"fullDescription": { | ||
"text": "Catfish season continuous hen lamb include dose copy grant." | ||
}, | ||
"configuration": { | ||
"enabled": true, | ||
"defaultLevel": "error" | ||
"defaultLevel": "error", | ||
"defaultRank": 0.0 | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
I do not know why the serializer is emitting |
||
}, | ||
"helpUri": "http://www.domain.com/rules/c2002.html" | ||
}, | ||
"C2003": { | ||
{ | ||
"id": "C2003", | ||
"name": { | ||
"text": "Rule C2003" | ||
|
@@ -68,14 +71,13 @@ | |
"text": "Rent internal rebellion competence biography photograph." | ||
}, | ||
"configuration": { | ||
"defaultLevel": "note" | ||
"defaultLevel": "note", | ||
"defaultRank": 0.0 | ||
} | ||
}, | ||
"C2002-1": { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
The v1 file has a There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ok. side issue: what does v2 say about no rule id and ruleIndex == -1. Seems like an invalid condition. A rule (especially for a converted log file) might not have the SARIF notion of a rule id but in this case, should have a name, so the rule object should exist. IOW, suggest we say in the spec that either rule id or ruleIndex (with a corresponding rule object) SHOULD be present. In reply to: 250286632 [](ancestors = 250286632) There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. We discussed this in person, but for the record: This condition is valid. If a tool does not provide opaque, stable rule ids as required by the spec, In reply to: 250389698 [](ancestors = 250389698,250286632) |
||
"id": "C2002" | ||
} | ||
} | ||
} | ||
] | ||
}, | ||
"columnKind": "utf16CodeUnits" | ||
} | ||
] | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
{ | ||
"$schema": "http://json.schemastore.org/sarif-2.0.0-csd.2.beta.2018-11-28", | ||
"version": "2.0.0-csd.2.beta.2018-11-28", | ||
"$schema": "http://json.schemastore.org/sarif-2.0.0", | ||
"version": "2.0.0", | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Force pre-release compatibility transformation. |
||
"runs": [ | ||
{ | ||
"tool": { | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -41,13 +41,13 @@ public SarifNodeKind SarifNodeKind | |
public string Id { get; set; } | ||
|
||
/// <summary> | ||
/// The stable, unique identifier of the rule (if any) to which this notification is relevant. This member can be used to retrieve rule metadata from the rules dictionary, if it exists. | ||
/// The stable, unique identifier of the rule, if any, to which this notification is relevant. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
This was lost in the schema merge. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Sure. Would materialize on next BuildAndTest gesture. It's important to perform this step before finalizing a push to get relevant changes in autogen code, sorry for omitting this step. In reply to: 250303030 [](ancestors = 250303030) |
||
/// </summary> | ||
[DataMember(Name = "ruleId", IsRequired = false, EmitDefaultValue = false)] | ||
public string RuleId { get; set; } | ||
|
||
/// <summary> | ||
/// The index within the run resources array of the rule object associated with this notification. | ||
/// The index within the run resources array of the rule object, if any, associated with this notification. | ||
/// </summary> | ||
[DataMember(Name = "ruleIndex", IsRequired = false, EmitDefaultValue = false)] | ||
[DefaultValue(-1)] | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -3,7 +3,6 @@ | |
|
||
using System; | ||
using System.Collections.Generic; | ||
using System.Diagnostics; | ||
using System.Globalization; | ||
using System.Linq; | ||
using Microsoft.CodeAnalysis.Sarif.VersionOne; | ||
|
@@ -22,6 +21,7 @@ public class SarifVersionOneToCurrentVisitor : SarifRewritingVisitorVersionOne | |
private RunVersionOne _currentV1Run; | ||
private int _threadFlowLocationNestingLevel; | ||
private IDictionary<string, int> _v1FileKeytoV2IndexMap; | ||
private IDictionary<string, int> _v1RuleKeyToV2IndexMap; | ||
|
||
private IDictionary<string, string> _v1KeyToFullyQualifiedNameMap; | ||
private IDictionary<LogicalLocation, int> _v2LogicalLocationToIndexMap; | ||
|
@@ -732,51 +732,11 @@ internal Result CreateResult(ResultVersionOne v1Result) | |
result.AnalysisTarget = CreateFileLocation(v1Result.Locations[0].AnalysisTarget); | ||
} | ||
|
||
if (v1Result.RuleKey == null) | ||
{ | ||
result.RuleId = v1Result.RuleId; | ||
} | ||
else | ||
{ | ||
if (v1Result.RuleId == null) | ||
{ | ||
result.RuleId = v1Result.RuleKey; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
This was never right. It was never valid to assign a
In v2, " |
||
} | ||
else | ||
{ | ||
if (v1Result.RuleId == v1Result.RuleKey) | ||
{ | ||
result.RuleId = v1Result.RuleId; | ||
} | ||
else | ||
{ | ||
result.RuleId = v1Result.RuleKey; | ||
|
||
if (_currentRun.Resources == null) | ||
{ | ||
_currentRun.Resources = new Resources(); | ||
} | ||
|
||
#if TRANSFORM_CODE_AUTHORED | ||
if (_currentRun.Resources.Rules == null) | ||
{ | ||
_currentRun.Resources.Rules = new List<string, Rule>(); | ||
} | ||
|
||
IDictionary<string, Rule> rules = _currentRun.Resources.Rules; | ||
result.RuleId = v1Result.RuleId; | ||
|
||
if (!rules.ContainsKey(v1Result.RuleKey)) | ||
{ | ||
Rule rule = new Rule() { Id = v1Result.RuleId }; | ||
rules.Add(v1Result.RuleKey, rule); | ||
} | ||
string ruleKey = v1Result.RuleKey ?? v1Result.RuleId; | ||
result.RuleIndex = GetRuleIndexForRuleKey(ruleKey, _v1RuleKeyToV2IndexMap); | ||
|
||
Debug.Assert(rules[v1Result.RuleKey].Id == v1Result.RuleId); | ||
#endif | ||
} | ||
} | ||
} | ||
|
||
if (v1Result.FormattedRuleMessage != null) | ||
{ | ||
if (result.Message == null) | ||
|
@@ -875,6 +835,7 @@ internal Run CreateRun(RunVersionOne v1Run) | |
_currentV1Run = v1Run; | ||
|
||
_v1FileKeytoV2IndexMap = CreateFileKeyToIndexMapping(v1Run.Files); | ||
_v1RuleKeyToV2IndexMap = CreateRuleKeyToIndexMapping(v1Run.Rules); | ||
|
||
RunAutomationDetails id = null; | ||
RunAutomationDetails[] aggregateIds = null; | ||
|
@@ -905,20 +866,18 @@ internal Run CreateRun(RunVersionOne v1Run) | |
|
||
_currentRun = run; | ||
|
||
#if TRANSFORM_CODE_AUTHORED | ||
if (v1Run.Rules != null) | ||
{ | ||
run.Resources = new Resources | ||
{ | ||
Rules = new Dictionary<string, Rule>() | ||
Rules = new List<Rule>() | ||
}; | ||
|
||
foreach (var pair in v1Run.Rules) | ||
{ | ||
run.Resources.Rules.Add(pair.Key, CreateRule(pair.Value)); | ||
run.Resources.Rules.Add(CreateRule(pair.Value)); | ||
} | ||
} | ||
#endif | ||
|
||
if (v1Run.Files != null) | ||
{ | ||
|
@@ -1019,6 +978,32 @@ private static IDictionary<string, int> CreateFileKeyToIndexMapping(IDictionary< | |
return v1FileKeyToV2IndexMap; | ||
} | ||
|
||
private static IDictionary<string, int> CreateRuleKeyToIndexMapping(IDictionary<string, RuleVersionOne> v1Rules) | ||
{ | ||
var v1RuleKeyToV2IndexMap = new Dictionary<string, int>(); | ||
|
||
if (v1Rules != null) | ||
{ | ||
int index = 0; | ||
foreach (KeyValuePair<string, RuleVersionOne> entry in v1Rules) | ||
{ | ||
v1RuleKeyToV2IndexMap[entry.Key] = index++; | ||
} | ||
} | ||
|
||
return v1RuleKeyToV2IndexMap; | ||
} | ||
|
||
private int GetRuleIndexForRuleKey(string ruleKey, IDictionary<string, int> v1RuleKeyToV2IndexMap) | ||
{ | ||
if (ruleKey == null || !v1RuleKeyToV2IndexMap.TryGetValue(ruleKey, out int index)) | ||
{ | ||
index = -1; | ||
} | ||
|
||
return index; | ||
} | ||
|
||
private void PopulateLogicalLocation( | ||
Run v2Run, | ||
IDictionary<string, LogicalLocationVersionOne> v1LogicalLocations, | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -27,7 +27,7 @@ public override Result VisitResult(Result node) | |
{ | ||
if (_ruleKeyToIndexMap != null) | ||
{ | ||
if (_ruleKeyToIndexMap.TryGetValue(node.RuleId, out int ruleIndex)) | ||
if (node.RuleId != null &&_ruleKeyToIndexMap.TryGetValue(node.RuleId, out int ruleIndex)) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
One of the test cases has a result with a |
||
{ | ||
node.RuleIndex = ruleIndex; | ||
|
||
|
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.
The prerelease compatibility transformer, although it was performing correctly, masked some of the behavior this test needed to demonstrate. We can talk about the details offline (assuming I haven't forgotten them by then).