File: test_resources.py

package info (click to toggle)
osinfo-db 0.20250606-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 28,856 kB
  • sloc: python: 2,161; sh: 357; makefile: 94
file content (137 lines) | stat: -rw-r--r-- 4,056 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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
# This work is licensed under the GNU GPLv2 or later.
# See the COPYING file in the top-level directory.

from collections import defaultdict

import logging

from . import util


def _test_resources_uniqueness_by_arch(osxml):
    """Ensure there's no more than one resource element per architecture"""
    result = defaultdict(list)
    for resources in osxml.resources_list:
        result[resources.get("arch")].append(resources)

    for value in result.values():
        assert len(value) == 1


@util.os_parametrize("osxml", filter_resources=True)
def test_resources(osxml):
    _test_resources_uniqueness_by_arch(osxml)

    # Ensure minimum resources are <= recommended resources
    _resources_helper(
        osxml,
        osxml.get_minimum_resources,
        "minimum",
        osxml.get_recommended_resources,
        "recommended",
    )

    # Ensure minimum resources are <= maximum resources
    _resources_helper(
        osxml,
        osxml.get_minimum_resources,
        "minimum",
        osxml.get_maximum_resources,
        "maximum",
    )

    # Ensure recommended resources are <= maximum resources
    _resources_helper(
        osxml,
        osxml.get_recommended_resources,
        "recommended",
        osxml.get_maximum_resources,
        "maximum",
    )

    # Ensure minimum resources <= network resources
    _resources_helper(
        osxml,
        osxml.get_minimum_resources,
        "minimum",
        osxml.get_network_install_resources,
        "network-install",
    )

    # Ensure recommended resources <= network resources
    _resources_helper(
        osxml,
        osxml.get_recommended_resources,
        "recommended",
        osxml.get_network_install_resources,
        "network-install",
    )

    # Ensure network resources <= maximum resources
    _resources_helper(
        osxml,
        osxml.get_network_install_resources,
        "network-install",
        osxml.get_maximum_resources,
        "maximum",
    )


def _resources_helper(osxml, smaller_func, smaller_str, bigger_func, bigger_str):
    broken = []
    for resource in osxml.resources_list:
        logging.info("resources | arch: %s", resource.get("arch"))
        smaller = smaller_func(resource)
        bigger = bigger_func(resource)

        if smaller is None or bigger is None:
            continue

        if not _resources_check(smaller, smaller_str, bigger, bigger_str):
            broken.append([smaller, bigger])
    assert broken == []


def _resources_check(smaller, smaller_str, bigger, bigger_str):
    ret = True
    if smaller.cpu is not None and bigger.cpu is not None:
        if smaller.cpu > bigger.cpu:
            logging.warning(
                "cpu value of %s should not be bigger than %s " "('%d' > '%d')",
                smaller_str,
                bigger_str,
                smaller.cpu,
                bigger.cpu,
            )
            ret = False
    if smaller.n_cpus is not None and bigger.n_cpus is not None:
        if smaller.n_cpus > bigger.n_cpus:
            logging.warning(
                "n-cpus value of %s should not be bigger than %s " "('%d' > '%d')",
                smaller_str,
                bigger_str,
                smaller.n_cpus,
                bigger.n_cpus,
            )
            ret = False
    if smaller.ram is not None and bigger.ram is not None:
        if smaller.ram > bigger.ram:
            logging.warning(
                "ram value of %s should not be bigger than %s " "('%d' > '%d')",
                smaller_str,
                bigger_str,
                smaller.ram,
                bigger.ram,
            )
            ret = False
    if smaller.storage is not None and bigger.storage is not None:
        if smaller.storage > bigger.storage:
            logging.warning(
                "storage value of %s should not be bigger than %s " "('%d' > '%d')",
                smaller_str,
                bigger_str,
                smaller.storage,
                bigger.storage,
            )
            ret = False
    return ret