File: 10-optional-6.2.03.t

package info (click to toggle)
libcsaf-perl 0.26-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 2,280 kB
  • sloc: perl: 7,583; makefile: 2
file content (55 lines) | stat: -rw-r--r-- 1,363 bytes parent folder | download
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
#!perl

use 5.010001;
use strict;
use warnings;
use Test::More;

use FindBin '$RealBin';
use lib "$RealBin/lib";

use Test::CSAF qw(base_csaf_security_advisory exec_validator_optional_test);

# 6.2.3 Missing Score

# For each Product ID (type /$defs/product_id_t) in the Product Status groups Affected it MUST be tested that a score object exists which
# covers this product.

# The relevant paths for this test are:
#   /vulnerabilities[]/product_status/first_affected[]
#   /vulnerabilities[]/product_status/known_affected[]
#   /vulnerabilities[]/product_status/last_affected[]

# Fail test:

# "product_tree": {
#   "full_product_names": [
#       {
#           "product_id": "CSAFPID-9080700",
#           "name": "Product A"
#       }
#   ]
# },
# "vulnerabilities": [
#   {
#       "product_status": {
#           "first_affected": [
#               "CSAFPID-9080700"
#           ]
#       }
#   }
# ]

my $csaf = base_csaf_security_advisory();

$csaf->product_tree->full_product_names->add(name => 'Product A', product_id => 'CSAFPID-9080700');
$csaf->product_tree->full_product_names->add(name => 'Product B', product_id => 'CSAFPID-9080701');

my $vulns = $csaf->vulnerabilities;
my $vuln  = $vulns->add(cve => 'CVE-2023-00000');

$vuln->product_status->first_affected(['CSAFPID-9080700']);

exec_validator_optional_test($csaf, '6.2.3');

done_testing;