blob: 2c3858786ecabcf524de780ec971dd422802fb22 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
# We expect a warning with this textual form:
#
# . PATH/diagnostic-test-metadata-sarif.c: In function 'test_cwe':
# . PATH/diagnostic-test-metadata-sarif.c:8:3: warning: never use 'gets' [CWE-242] [STR34-C]
from sarif import *
import pytest
@pytest.fixture(scope='function', autouse=True)
def sarif():
return sarif_from_env()
def test_basics(sarif):
schema = sarif['$schema']
assert schema == "https://docs.oasis-open.org/sarif/sarif/v2.1.0/errata01/os/schemas/sarif-schema-2.1.0.json"
version = sarif['version']
assert version == "2.1.0"
def test_plugin_metadata(sarif):
runs = sarif['runs']
assert len(runs) == 1
run = runs[0]
tool = run['tool']
# We expect an extension, for the plugin.
extensions = tool['extensions']
assert len(extensions) == 1
extension = extensions[0]
assert extension['name'] == 'diagnostic_plugin_test_metadata'
assert 'diagnostic_plugin_test_metadata' in extension['fullName']
# TODO: ideally there would be a rule for [STR34-C] within
# the extension for the plugin with
# 'id': 'STR34-C',
# 'helpUri': 'https://example.com/'
def test_result(sarif):
runs = sarif['runs']
run = runs[0]
results = run['results']
assert len(results) == 1
result = results[0]
assert result['level'] == 'warning'
assert result['message']['text'] == "never use 'gets'"
assert len(result['taxa']) == 1
taxon = result['taxa'][0]
assert taxon['id'] == '242'
assert taxon['toolComponent']['name'] == 'cwe'
|