diff --git a/CHANGELOG.md b/CHANGELOG.md index d78a641..dbfe41a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,6 +5,9 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). ## Unreleased +* pin osidb-bindings 3.3.0 +* update crypto python module +* fix generation of affects ## [0.2.8] - 2023-06-28 ### Added diff --git a/griffon/commands/queries.py b/griffon/commands/queries.py index 1391624..f2002a5 100644 --- a/griffon/commands/queries.py +++ b/griffon/commands/queries.py @@ -36,7 +36,14 @@ generate_entity_report, generate_license_report, ) -from griffon.output import console, cprint, raw_json_transform +from griffon.output import ( + console, + cprint, + generate_affects, + generate_normalised_results, + generate_result_tree, + raw_json_transform, +) from griffon.services import QueryService, core_queries # , exp logger = logging.getLogger("griffon") @@ -382,18 +389,20 @@ def get_product_contain_component( # generate affects output = raw_json_transform(q, True) - ordered_results = sorted(output["results"], key=lambda d: d["product_stream"]) - affects = [] - product_versions = sorted( - list(set([item["product_version"] for item in ordered_results])) + + exclude_products = [] + if get_config_option(ctx.obj["PROFILE"], "exclude"): + exclude_products = get_config_option(ctx.obj["PROFILE"], "exclude").split("\n") + exclude_components = [] + if get_config_option(ctx.obj["PROFILE"], "exclude_components"): + exclude_components = get_config_option( + ctx.obj["PROFILE"], "exclude_components" + ).split("\n") + normalised_results = generate_normalised_results( + output, exclude_products, exclude_components ) - for pv in product_versions: - names = [item["name"] for item in ordered_results if pv == item["product_version"]] - names = list(set(names)) - for name in names: - affects.append( - {"product_version": pv, "component_name": name, "operation": "add"} - ) + result_tree = generate_result_tree(normalised_results) + affects = generate_affects(ctx, result_tree, exclude_components, "add", format="json") # attempt to import sfm2client module try: diff --git a/griffon/output.py b/griffon/output.py index ba79afa..ac9652c 100644 --- a/griffon/output.py +++ b/griffon/output.py @@ -155,6 +155,115 @@ def text_output_product_summary(ctx, output, format, exclude_products, no_wrap=F ctx.exit() +def generate_normalised_results(output, exclude_products, exclude_components): + normalised_results = list() + if "results" in output: + for item in output["results"]: + for ps in item["product_streams"]: + if ps["product_versions"][0]["name"] not in exclude_products: + if not any([match in item["name"] for match in exclude_components]): + c = { + "product_version": ps["product_versions"][0]["name"], + "product_stream": ps.get("name"), + "namespace": item.get("namespace"), + "name": item.get("name"), + "nvr": item.get("nvr"), + "type": item.get("type"), + "arch": item.get("arch"), + "version": item.get("version"), + "related_url": item.get("related_url"), + "purl": item.get("purl"), + "sources": item.get("sources"), + "upstreams": item.get("upstreams"), + } + if "software_build" in item: + c["build_source_url"] = item["software_build"].get("source") + normalised_results.append(c) + return normalised_results + + +def generate_result_tree(normalised_results): + product_versions = sorted(list(set([item["product_version"] for item in normalised_results]))) + result_tree = {} + for pv in product_versions: + result_tree[pv] = {} + product_streams = sorted( + list( + set( + [ + item["product_stream"] + for item in normalised_results + if item["product_version"] == pv + ] + ) + ) + ) + for ps in product_streams: + result_tree[pv][ps] = {} + component_names = sorted( + list( + set( + [ + item["name"] + for item in normalised_results + if item["product_stream"] == ps + ] + ) + ) + ) + for cn in component_names: + result_tree[pv][ps][cn] = {} + nvrs = [ + item + for item in normalised_results + if item["product_stream"] == ps and item["name"] == cn + ] + + for nvr in nvrs: + result_tree[pv][ps][cn][nvr["nvr"]] = nvr + return result_tree + + +def generate_affects( + ctx, result_tree, exclude_components, flaw_operation, format="text", no_wrap=False +): + search_component_name = ctx.params["component_name"] + for pv in result_tree.keys(): + component_names = set() + for ps in result_tree[pv].keys(): + for component_name in result_tree[pv][ps].keys(): + for nvr in result_tree[pv][ps][component_name].keys(): + source_names = [ + source["name"] + for source in result_tree[pv][ps][component_name][nvr]["sources"] + if source["namespace"] == "REDHAT" + ] + component_names.update(source_names) + # we should only show component name if both {component name} and {component name-container} exists # noqa + if ( + search_component_name in component_names + and f"{search_component_name}-container" in component_names + ): + component_names.remove(f"{search_component_name}-container") + if format == "text": + for cn in component_names: + # ensure {component name} is not in profile exclude components enum + if not any([match in cn for match in exclude_components]): + console.print( + f"{pv}/{cn}={flaw_operation}", + no_wrap=no_wrap, + ) + else: + affects = [] + for cn in component_names: + # ensure {component name} is not in profile exclude components enum + if not any([match in cn for match in exclude_components]): + affects.append( + {"product_version": pv, "component_name": cn, "operation": flaw_operation} + ) + return affects + + def text_output_products_contain_component( ctx, output, exclude_products, exclude_components, no_wrap=False ): @@ -178,69 +287,10 @@ def text_output_products_contain_component( # ordered_results = sorted(output["results"], key=lambda d: d["product_stream"]) # first flatten the tree - normalised_results = list() - if "results" in output: - for item in output["results"]: - for ps in item["product_streams"]: - if ps["product_versions"][0]["name"] not in exclude_products: - if not any([match in item["name"] for match in exclude_components]): - c = { - "product_version": ps["product_versions"][0]["name"], - "product_stream": ps.get("name"), - "namespace": item.get("namespace"), - "name": item.get("name"), - "nvr": item.get("nvr"), - "type": item.get("type"), - "arch": item.get("arch"), - "version": item.get("version"), - "related_url": item.get("related_url"), - "purl": item.get("purl"), - "sources": item.get("sources"), - "upstreams": item.get("upstreams"), - } - if "software_build" in item: - c["build_source_url"] = item["software_build"].get("source") - normalised_results.append(c) - product_versions = sorted( - list(set([item["product_version"] for item in normalised_results])) + normalised_results = generate_normalised_results( + output, exclude_products, exclude_components ) - result_tree = {} - for pv in product_versions: - result_tree[pv] = {} - product_streams = sorted( - list( - set( - [ - item["product_stream"] - for item in normalised_results - if item["product_version"] == pv - ] - ) - ) - ) - for ps in product_streams: - result_tree[pv][ps] = {} - component_names = sorted( - list( - set( - [ - item["name"] - for item in normalised_results - if item["product_stream"] == ps - ] - ) - ) - ) - for cn in component_names: - result_tree[pv][ps][cn] = {} - nvrs = [ - item - for item in normalised_results - if item["product_stream"] == ps and item["name"] == cn - ] - - for nvr in nvrs: - result_tree[pv][ps][cn][nvr["nvr"]] = nvr + result_tree = generate_result_tree(normalised_results) # TODO - MAVEN component type will require special handling if ctx.params["affect_mode"]: @@ -254,23 +304,8 @@ def text_output_products_contain_component( if flaw_mode == "update": flaw_operation = "update" - for pv in result_tree.keys(): - component_names = set() - for ps in result_tree[pv].keys(): - component_names.update(result_tree[pv][ps].keys()) - # we should only show component name if both {component name} and {component name-container} exists # noqa - if ( - search_component_name in component_names - and f"{search_component_name}-container" in component_names - ): - component_names.remove(f"{search_component_name}-container") - for cn in component_names: - # ensure {component name} is not in profile exclude components enum - if not any([match in cn for match in exclude_components]): - console.print( - f"{pv}/{cn}={flaw_operation}", - no_wrap=no_wrap, - ) + generate_affects(ctx, result_tree, exclude_components, flaw_operation, no_wrap=False) + else: if ctx.obj["VERBOSE"] == 0: # product_version X component_name for pv in result_tree.keys(): diff --git a/griffon/services/core_queries.py b/griffon/services/core_queries.py index 31ad939..dc205d6 100644 --- a/griffon/services/core_queries.py +++ b/griffon/services/core_queries.py @@ -271,7 +271,7 @@ def __init__(self, params: dict) -> None: def execute(self) -> List[Dict[str, Any]]: results = [] params = { - "include_fields": "link,purl,type,name,related_url,namespace,software_build,nvr,sources.nvr,sources.purl,sources.name,sources.download_url,sources.related_url,upstreams.nvr,upstreams.purl,upstreams.name,upstreams.download_url,upstreams.related_url,release,version,arch,product_streams.product_versions,product_streams.name,product_streams.ofuri", # noqa + "include_fields": "link,purl,type,name,related_url,namespace,software_build,nvr,sources.nvr,sources.purl,sources.name,sources.namespace,sources.download_url,sources.related_url,upstreams.nvr,upstreams.purl,upstreams.name,upstreams.download_url,upstreams.related_url,release,version,arch,product_streams.product_versions,product_streams.name,product_streams.ofuri", # noqa } if self.search_latest: diff --git a/requirements/base.txt b/requirements/base.txt index 349889d..525ab43 100644 --- a/requirements/base.txt +++ b/requirements/base.txt @@ -1,5 +1,5 @@ # -# This file is autogenerated by pip-compile with Python 3.9 +# This file is autogenerated by pip-compile with Python 3.11 # by the following command: # # pip-compile --allow-unsafe --generate-hashes requirements/base.in diff --git a/requirements/dev.txt b/requirements/dev.txt index 14da222..e4894c4 100644 --- a/requirements/dev.txt +++ b/requirements/dev.txt @@ -1,8 +1,8 @@ # -# This file is autogenerated by pip-compile with Python 3.9 +# This file is autogenerated by pip-compile with Python 3.11 # by the following command: # -# pip-compile --allow-unsafe --generate-hashes dev.in +# pip-compile --allow-unsafe --generate-hashes requirements/dev.in # asttokens==2.2.1 \ --hash=sha256:4622110b2a6f30b77e1473affaa97e711bc2f07d3f10848420ff1898edbe94f3 \ @@ -12,8 +12,8 @@ attrs==22.2.0 \ --hash=sha256:29e95c7f6778868dbd49170f98f8818f78f3dc5e0e37c0b1f474e3561b240836 \ --hash=sha256:c9227bfc2f01993c03f68db37d1d15c9690188323c067c641f1a35ca58185f99 # via - # -r base.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/test.txt # component-registry-bindings # osidb-bindings # pytest @@ -24,7 +24,7 @@ backcall==0.2.0 \ behave==1.2.6 \ --hash=sha256:b9662327aa53294c1351b0a9c369093ccec1d21026f050c3bd9b3e5cccf81a86 \ --hash=sha256:ebda1a6c9e5bfe95c5f9f0a2794e01c7098b3dde86c10a95d8621c5907ff6f1c - # via -r test.txt + # via -r requirements/test.txt bleach==6.0.0 \ --hash=sha256:1a1a85c1595e07d8db14c5f09f09e6433502c51c595970edc090551f0db99414 \ --hash=sha256:33c16e3353dbd13028ab4799a0f89a83f113405c766e9c122df8a06f5b85b3f4 @@ -37,9 +37,9 @@ certifi==2022.12.7 \ --hash=sha256:35824b4c3a97115964b408844d64aa14db1cc518f6562e8d7261699d1350a9e3 \ --hash=sha256:4ad3232f5e926d6718ec31cfc1fcadfde020920e278684144551c91769c7bc18 # via - # -r base.txt - # -r lint.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/lint.txt + # -r requirements/test.txt # requests cffi==1.15.1 \ --hash=sha256:00a9ed42e88df81ffae7a8ab6d9356b371399b91dbdf0c3cb1e84c03a13aceb5 \ @@ -197,29 +197,29 @@ charset-normalizer==3.0.1 \ --hash=sha256:f9d0c5c045a3ca9bedfc35dca8526798eb91a07aa7a2c0fee134c6c6f321cbd7 \ --hash=sha256:ff6f3db31555657f3163b15a6b7c6938d08df7adbfc9dd13d9d19edad678f1e8 # via - # -r base.txt - # -r lint.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/lint.txt + # -r requirements/test.txt # requests click==8.1.3 \ --hash=sha256:7682dc8afb30297001674575ea00d1814d808d6a36af415a82bd481d37ba7b8e \ --hash=sha256:bb4d8133cb15a609f44e8213d9b391b0809795062913b383c62be0ee95b1db48 # via - # -r base.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/test.txt # click-completion # pip-tools click-completion==0.5.2 \ --hash=sha256:5bf816b81367e638a190b6e91b50779007d14301b3f9f3145d68e3cade7bce86 # via - # -r base.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/test.txt component-registry-bindings==1.3.4 \ --hash=sha256:9ea5e1f83123ed6712e15c487caf50216b865677d5054a0932afc4ad73f6c5be \ --hash=sha256:d85d140b53a6a7ba7ff08d55a5990d9199ecead107e54013b5128d7e4e628ce8 # via - # -r base.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/test.txt coverage[toml]==7.2.0 \ --hash=sha256:049806ae2df69468c130f04f0fab4212c46b34ba5590296281423bb1ae379df2 \ --hash=sha256:08e3dd256b8d3e07bb230896c8c96ec6c5dffbe5a133ba21f8be82b275b900e8 \ @@ -273,7 +273,7 @@ coverage[toml]==7.2.0 \ --hash=sha256:f3ff4205aff999164834792a3949f82435bc7c7655c849226d5836c3242d7451 \ --hash=sha256:ffa637a2d5883298449a5434b699b22ef98dd8e2ef8a1d9e60fa9cfe79813411 # via - # -r test.txt + # -r requirements/test.txt # pytest-cov cryptography==41.0.0 \ --hash=sha256:0ddaee209d1cf1f180f1efa338a68c4621154de0afaef92b89486f5f96047c55 \ @@ -300,15 +300,15 @@ decorator==5.1.1 \ --hash=sha256:637996211036b6385ef91435e4fae22989472f9d571faba8927ba8253acbc330 \ --hash=sha256:b8c3f85900b9dc423225913c5aace94729fe1fa9763b38939a95226f02d37186 # via - # -r base.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/test.txt # gssapi # ipdb # ipython detect-secrets==1.4.0 \ --hash=sha256:d08ecabeee8b68c0acb0e8a354fb98d822a653f6ed05e520cead4c6fc1fc02cd \ --hash=sha256:d56787e339758cef48c9ccd6692f7a094b9963c979c9813580b0169e41132833 - # via -r lint.txt + # via -r requirements/lint.txt docutils==0.19 \ --hash=sha256:33995a6753c30b7f577febfc2c50411fec6aac7f7ffeb7c4cfe5991072dcf9e6 \ --hash=sha256:5e1de4d849fee02c63b040a4a3fd567f4ab104defd8a5511fbbc24a8a017efbc @@ -317,9 +317,8 @@ exceptiongroup==1.1.0 \ --hash=sha256:327cbda3da756e2de031a3107b81ab7b3770a602c4d16ca618298c526f4bec1e \ --hash=sha256:bcb67d800a4497e1b404c2dd44fca47d3b7a5e5433dbab67f96c1a685cdfdf23 # via - # -r lint.txt - # -r test.txt - # pytest + # -r requirements/lint.txt + # -r requirements/test.txt executing==1.2.0 \ --hash=sha256:0314a69e37426e3608aada02473b4161d4caf5a4b244d1d0c48072b8fee7bacc \ --hash=sha256:19da64c18d2d851112f09c287f8d3dbbdf725ab0e569077efb6cdcbd3497c107 @@ -327,7 +326,7 @@ executing==1.2.0 \ flake8==6.0.0 \ --hash=sha256:3833794e27ff64ea4e9cf5d410082a8b97ff1a06c16aa3d2027339cd0f1195c7 \ --hash=sha256:c61007e76655af75e6785a931f452915b371dc48f56efd765247c8fe68f2b181 - # via -r lint.txt + # via -r requirements/lint.txt gssapi==1.8.2 \ --hash=sha256:02e0a8f35e1f5b1c0eada646e3da1af3022c25e8df26ded3fd18ee78abb155ea \ --hash=sha256:13aba9a947994f5f5f1fb6f425b397a359b191cee2983fa33911cf5e212d6cfb \ @@ -350,16 +349,16 @@ gssapi==1.8.2 \ --hash=sha256:f75b094913a1757e5e634b70b03e808cab0eb02c802ec50b760636b23b0aa50c \ --hash=sha256:fac7d1f4b14383bd29d3996cf5f6f23d0dc50ffd7965d2bc35bcc0849da24152 # via - # -r base.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/test.txt # requests-gssapi idna==3.4 \ --hash=sha256:814f528e8dead7d329833b91c5faa87d60bf71824cd12a7530b5526063d02cb4 \ --hash=sha256:90b77e79eaa3eba6de819a0c442c0b4ceefc341a7a2ab77d7562bf49f425c5c2 # via - # -r base.txt - # -r lint.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/lint.txt + # -r requirements/test.txt # requests # yarl importlib-metadata==6.0.0 \ @@ -372,22 +371,22 @@ iniconfig==2.0.0 \ --hash=sha256:2d91e135bf72d31a410b17c16da610a82cb55f6b0477d1a902134b24a455b8b3 \ --hash=sha256:b6a85871a79d2e3b22d2d1b94ac2824226a63c6b741c88f7ae975f18b6778374 # via - # -r test.txt + # -r requirements/test.txt # pytest ipdb==0.13.11 \ --hash=sha256:c23b6736f01fd4586cc2ecbebdf79a5eb454796853e1cd8f2ed3b7b91d4a3e93 \ --hash=sha256:f74c2f741c18b909eaf89f19fde973f745ac721744aa1465888ce45813b63a9c - # via -r dev.in + # via -r requirements/dev.in ipython==8.10.0 \ --hash=sha256:b13a1d6c1f5818bd388db53b7107d17454129a70de2b87481d555daede5eb49e \ --hash=sha256:b38c31e8fc7eff642fc7c597061fff462537cf2314e3225a19c906b7b0d8a345 # via - # -r dev.in + # -r requirements/dev.in # ipdb isort==5.11.4 \ --hash=sha256:6db30c5ded9815d813932c04c2f85a360bcdd35fed496f4d8f35495ef0a261b6 \ --hash=sha256:c033fd0edb91000a7f09527fe5c75321878f98322a77ddcc81adbd83724afb7b - # via -r lint.txt + # via -r requirements/lint.txt jaraco-classes==3.2.3 \ --hash=sha256:2353de3288bc6b82120752201c6b1c1a14b058267fa424ed5ce5984e3b922158 \ --hash=sha256:89559fa5c1d3c34eff6f631ad80bb21f378dbcbb35dd161fd2c6b93f5be2f98a @@ -406,8 +405,8 @@ jinja2==3.1.2 \ --hash=sha256:31351a702a408a9e7595a8fc6150fc3f43bb6bf7e319770cbc0db9df9437e852 \ --hash=sha256:6088930bfe239f0e6710546ab9c19c9ef35e29792895fed6e6e31a023a182a61 # via - # -r base.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/test.txt # click-completion keyring==23.13.1 \ --hash=sha256:771ed2a91909389ed6148631de678f82ddc73737d85a927f382a8a1b157898cd \ @@ -491,13 +490,13 @@ lxml==4.9.2 \ --hash=sha256:efa29c2fe6b4fdd32e8ef81c1528506895eca86e1d8c4657fda04c9b3786ddf9 \ --hash=sha256:f1496ea22ca2c830cbcbd473de8f114a320da308438ae65abad6bab7867fe38f \ --hash=sha256:f49e52d174375a7def9915c9f06ec4e569d235ad428f70751765f48d5926678c - # via -r test.txt + # via -r requirements/test.txt markdown-it-py==2.2.0 \ --hash=sha256:5a35f8d1870171d9acc47b99612dc146129b631baf04970128b568f190d0cc30 \ --hash=sha256:7c9a5e412688bc771c67432cbfebcdd686c93ce6484913dccf06cb5a0bea35a1 # via - # -r base.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/test.txt # rich markupsafe==2.1.2 \ --hash=sha256:0576fe974b40a400449768941d5d0858cc624e3249dfd1e0c33674e5c7ca7aed \ @@ -551,8 +550,8 @@ markupsafe==2.1.2 \ --hash=sha256:f2bfb563d0211ce16b63c7cb9395d2c682a23187f54c3d79bfec33e6705473c6 \ --hash=sha256:f8ffb705ffcf5ddd0e80b65ddf7bed7ee4f5a441ea7d3419e861a12eaf41af58 # via - # -r base.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/test.txt # jinja2 matplotlib-inline==0.1.6 \ --hash=sha256:f1f41aab5328aa5aaea9b16d083b128102f8712542f819fe7e6a420ff581b311 \ @@ -562,14 +561,14 @@ mccabe==0.7.0 \ --hash=sha256:348e0240c33b60bbdf4e523192ef919f28cb2c3d7d5c7794f74009290f236325 \ --hash=sha256:6c2d30ab6be0e4a46919781807b4f0d834ebdd6c6e3dca0bda5a15f863427b6e # via - # -r lint.txt + # -r requirements/lint.txt # flake8 mdurl==0.1.2 \ --hash=sha256:84008a41e51615a49fc9966191ff91509e3c40b939176e643fd50a5c2196b8f8 \ --hash=sha256:bb413d29f5eea38f31dd4754dd7377d4465116fb207585f97bf925588687c1ba # via - # -r base.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/test.txt # markdown-it-py more-itertools==9.0.0 \ --hash=sha256:250e83d7e81d0c87ca6bd942e6aeab8cc9daa6096d12c5308f3f92fa5e5c1f41 \ @@ -651,7 +650,7 @@ multidict==6.0.4 \ --hash=sha256:fc35cb4676846ef752816d5be2193a1e8367b4c1397b74a565a9d0389c433a1d \ --hash=sha256:ff959bee35038c4624250473988b24f846cbeb2c6639de3602c073f10410ceba # via - # -r test.txt + # -r requirements/test.txt # yarl mypy==1.0.1 \ --hash=sha256:0af4f0e20706aadf4e6f8f8dc5ab739089146b83fd53cb4a7e0e850ef3de0bb6 \ @@ -680,43 +679,44 @@ mypy==1.0.1 \ --hash=sha256:e64f48c6176e243ad015e995de05af7f22bbe370dbb5b32bd6988438ec873919 \ --hash=sha256:e831662208055b006eef68392a768ff83596035ffd6d846786578ba1714ba8f6 \ --hash=sha256:eda5c8b9949ed411ff752b9a01adda31afe7eae1e53e946dbdf9db23865e66c4 - # via -r test.txt + # via -r requirements/test.txt mypy-extensions==1.0.0 \ --hash=sha256:4392f6c0eb8a5668a69e23d168ffa70f0be9ccfd32b5cc2d26a34ae5b844552d \ --hash=sha256:75dbf8955dc00442a438fc4d0666508a9a97b6bd41aa2f0ffe9d2f2725af0782 # via - # -r test.txt + # -r requirements/test.txt # mypy -osidb-bindings==3.1.0 \ - --hash=sha256:38e62d3210ba2ede9da82af0d713e19602f41b2e212641d04f17e71941394e99 \ - --hash=sha256:6b222623bfdf2a90f75dcf621ec0d1c949c7b109e6ff572eb6431184b9c5154d +osidb-bindings==3.3.0 \ + --hash=sha256:19e8660dd68c06f21fcaf0b092b0565d887dcd9ea05bd98342e88de4bd949727 \ + --hash=sha256:e6bfee4a66d9805d2d45de07f3b707eac72c753317c1c79bc599265a34d79f43 # via - # -r base.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/test.txt packageurl-python==0.10.4 \ --hash=sha256:5c91334f942cd55d45eb0c67dd339a535ef90e25f05b9ec016ad188ed0ef9048 \ --hash=sha256:bf8a1ffe755634776f6563904d792fb0aa13b377fc86115c36fe17f69b6e59db # via - # -r base.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/test.txt packaging==23.0 \ --hash=sha256:714ac14496c3e68c99c29b00845f7a2b85f3bb6f1078fd9f72fd20f0570002b2 \ --hash=sha256:b6ad297f8907de0fa2fe1ccbd26fdaf387f5f47c7275fedf8cce89f99446cf97 # via - # -r test.txt + # -r requirements/test.txt # build # pytest -parse==1.19.0 \ - --hash=sha256:9ff82852bcb65d139813e2a5197627a94966245c897796760a3a2a8eb66f020b +parse==1.19.1 \ + --hash=sha256:371ed3800dc63983832159cc9373156613947707bc448b5215473a219dbd4362 \ + --hash=sha256:cc3a47236ff05da377617ddefa867b7ba983819c664e1afe46249e5b469be464 # via - # -r test.txt + # -r requirements/test.txt # behave # parse-type parse-type==0.6.0 \ --hash=sha256:20b43c660e48ed47f433bce5873a2a3d4b9b6a7ba47bd7f7d2a7cec4bec5551f \ --hash=sha256:c148e88436bd54dab16484108e882be3367f44952c649c9cd6b82a7370b650cb # via - # -r test.txt + # -r requirements/test.txt # behave parso==0.8.3 \ --hash=sha256:8c07be290bb59f03588915921e29e8a50002acaf2cdc5fa0e0114f91709fafa0 \ @@ -733,7 +733,7 @@ pickleshare==0.7.5 \ pip-tools==6.12.2 \ --hash=sha256:6a51f4fd67140d5e83703ebfa9610fb61398727151f56a1be02a972d062e4679 \ --hash=sha256:8b903696df4598b10d469026ef9995c5f9a874b416e88e7a214884ebe4a70245 - # via -r dev.in + # via -r requirements/dev.in pkginfo==1.9.6 \ --hash=sha256:4b7a555a6d5a22169fcc9cf7bfd78d296b0361adad412a346c1226849af5e546 \ --hash=sha256:8fd5896e8718a4372f0ea9cc9d96f6417c9b986e23a4d116dda26b62cc29d046 @@ -742,7 +742,7 @@ pluggy==1.0.0 \ --hash=sha256:4224373bacce55f955a878bf9cfa763c1e360858e330072059e10bad68531159 \ --hash=sha256:74134bbf457f031a36d68416e1509f34bd5ccc019f0bcc952c7b909d06b37bd3 # via - # -r test.txt + # -r requirements/test.txt # pytest prompt-toolkit==3.0.37 \ --hash=sha256:6a2948ec427dfcc7c983027b1044b355db6aaa8be374f54ad2015471f7d81c5b \ @@ -760,7 +760,7 @@ pycodestyle==2.10.0 \ --hash=sha256:347187bdb476329d98f695c213d7295a846d1152ff4fe9bacb8a9590b8ee7053 \ --hash=sha256:8a4eaf0d0495c7395bdab3589ac2db602797d76207242c17d470186815706610 # via - # -r lint.txt + # -r requirements/lint.txt # flake8 pycparser==2.21 \ --hash=sha256:8ee45429555515e1f6b185e78100aea234072576aa43ab53aefcae078162fca9 \ @@ -770,14 +770,14 @@ pyflakes==3.0.1 \ --hash=sha256:ec55bf7fe21fff7f1ad2f7da62363d749e2a470500eab1b555334b67aa1ef8cf \ --hash=sha256:ec8b276a6b60bd80defed25add7e439881c19e64850afd9b346283d4165fd0fd # via - # -r lint.txt + # -r requirements/lint.txt # flake8 pygments==2.14.0 \ --hash=sha256:b3ed06a9e8ac9a9aae5a6f5dbe78a8a58655d17b43b93c078f094ddc476ae297 \ --hash=sha256:fa7bd7bd2771287c0de303af8bfdfc731f51bd2c6a47ab69d117138893b82717 # via - # -r base.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/test.txt # ipython # readme-renderer # rich @@ -789,18 +789,18 @@ pytest==7.2.1 \ --hash=sha256:c7c6ca206e93355074ae32f7403e8ea12163b1163c976fee7d4d84027c162be5 \ --hash=sha256:d45e0952f3727241918b8fd0f376f5ff6b301cc0777c6f9a556935c92d8a7d42 # via - # -r test.txt + # -r requirements/test.txt # pytest-cov pytest-cov==4.0.0 \ --hash=sha256:2feb1b751d66a8bd934e5edfa2e961d11309dc37b73b0eabe73b5945fee20f6b \ --hash=sha256:996b79efde6433cdbd0088872dbc5fb3ed7fe1578b68cdbba634f14bb8dd0470 - # via -r test.txt + # via -r requirements/test.txt python-dateutil==2.8.2 \ --hash=sha256:0123cacc1627ae19ddf3c27a5de5bd67ee4586fbdd6440d9748f8abb483d3e86 \ --hash=sha256:961d03dc3453ebbc59dbdea9e4e11c5651520a876d0f4db161e8674aae935da9 # via - # -r base.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/test.txt # component-registry-bindings # osidb-bindings pyyaml==6.0 \ @@ -845,8 +845,8 @@ pyyaml==6.0 \ --hash=sha256:e61ceaab6f49fb8bdfaa0f92c4b57bcfbea54c09277b1b4f7ac376bfb7a7c174 \ --hash=sha256:f84fbc98b019fef2ee9a1cb3ce93e3187a6df0b2538a651bfb890254ba9f90b5 # via - # -r lint.txt - # -r test.txt + # -r requirements/lint.txt + # -r requirements/test.txt # detect-secrets # vcrpy readme-renderer==37.3 \ @@ -857,9 +857,9 @@ requests==2.31.0 \ --hash=sha256:58cd2187c01e70e6e26505bca751777aa9f2ee0b7f4300988b709f44e013003f \ --hash=sha256:942c5a758f98d790eaed1a29cb6eefc7ffb0d1cf7af05c3d2791656dbd6ad1e1 # via - # -r base.txt - # -r lint.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/lint.txt + # -r requirements/test.txt # component-registry-bindings # detect-secrets # osidb-bindings @@ -869,8 +869,8 @@ requests==2.31.0 \ requests-gssapi==1.2.3 \ --hash=sha256:20784508981401f7153c933eed095338933a40818da65a259dbf2d80dccb150e # via - # -r base.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/test.txt # osidb-bindings requests-toolbelt==0.10.1 \ --hash=sha256:18565aa58116d9951ac39baa288d3adb5b3ff975c4f25eee78555d89e8f247f7 \ @@ -884,8 +884,8 @@ rich==13.3.1 \ --hash=sha256:125d96d20c92b946b983d0d392b84ff945461e5a06d3867e9f9e575f8697b67f \ --hash=sha256:8aa57747f3fc3e977684f0176a88e789be314a99f99b43b75d1e9cb5dc6db9e9 # via - # -r base.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/test.txt # twine secretstorage==3.3.3 \ --hash=sha256:2403533ef369eca6d2ba81718576c5e0f564d5cca1b58f73a8b23e7d4eeebd77 \ @@ -895,15 +895,15 @@ shellingham==1.5.0.post1 \ --hash=sha256:368bf8c00754fd4f55afb7bbb86e272df77e4dc76ac29dbcbb81a59e9fc15744 \ --hash=sha256:823bc5fb5c34d60f285b624e7264f4dda254bc803a3774a147bf99c0e3004a28 # via - # -r base.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/test.txt # click-completion six==1.16.0 \ --hash=sha256:1e61c37477a1626458e36f7b1d82aa5c9b094fa4802892072e49de9c60c4c926 \ --hash=sha256:8abb2f1d86890a2dfb989f9a77cfcfd3e47c2a354b01111771326f8aa26e0254 # via - # -r base.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/test.txt # asttokens # behave # bleach @@ -919,14 +919,8 @@ tomli==2.0.1 \ --hash=sha256:939de3e7a6161af0c887ef91b7d41a53e7c5a1ca976325f429cb46ea9bc30ecc \ --hash=sha256:de526c12914f0c550d15924c62d72abc48d6fe7364aa87328337a31007fe8a4f # via - # -r lint.txt - # -r test.txt - # build - # coverage - # ipdb - # mypy - # pyproject-hooks - # pytest + # -r requirements/lint.txt + # -r requirements/test.txt traitlets==5.9.0 \ --hash=sha256:9e6ec080259b9a5940c797d58b613b5e31441c2257b87c2e795c5228ae80d2d8 \ --hash=sha256:f6cde21a9c68cf756af02035f72d5a723bf607e862e7be33ece505abf4a3bad9 @@ -936,37 +930,37 @@ traitlets==5.9.0 \ twine==4.0.2 \ --hash=sha256:929bc3c280033347a00f847236564d1c52a3e61b1ac2516c97c48f3ceab756d8 \ --hash=sha256:9e102ef5fdd5a20661eb88fad46338806c3bd32cf1db729603fe3697b1bc83c8 - # via -r dev.in + # via -r requirements/dev.in types-requests==2.28.11.14 \ --hash=sha256:232792870b60adb07d23175451ab4e6190021b0c584edf052d92d9b993118f06 \ --hash=sha256:f84613b0d4c5d0eeb7879dfa05e14a3702b9c1f7a4ee81dfe9b4321b13fe93a1 - # via -r test.txt + # via -r requirements/test.txt types-urllib3==1.26.25.7 \ --hash=sha256:28d2d7f5c31ff8ed4d9d2e396ce906c49d37523c3ec207d03d3b1695755a7199 \ --hash=sha256:df4d3e5472bf8830bd74eac12d56e659f88662ba040c7d106bf3a5bee26fff28 # via - # -r test.txt + # -r requirements/test.txt # types-requests typing-extensions==4.5.0 \ --hash=sha256:5cb5f4a79139d699607b3ef622a1dedafa84e115ab0024e0d9c044a9479ca7cb \ --hash=sha256:fb33085c39dd998ac16d1431ebc293a8b3eedd00fd4a32de0ff79002c19511b4 # via - # -r lint.txt - # -r test.txt + # -r requirements/lint.txt + # -r requirements/test.txt # mypy urllib3==1.26.14 \ --hash=sha256:076907bf8fd355cde77728471316625a4d2f7e713c125f51953bb5b3eecf4f72 \ --hash=sha256:75edcdc2f7d85b137124a6c3c9fc3933cdeaa12ecb9a6a959f22797a0feca7e1 # via - # -r base.txt - # -r lint.txt - # -r test.txt + # -r requirements/base.txt + # -r requirements/lint.txt + # -r requirements/test.txt # requests # twine vcrpy==4.2.1 \ --hash=sha256:7cd3e81a2c492e01c281f180bcc2a86b520b173d2b656cb5d89d99475423e013 \ --hash=sha256:efac3e2e0b2af7686f83a266518180af7a048619b2f696e7bad9520f5e2eac09 - # via -r test.txt + # via -r requirements/test.txt wcwidth==0.2.6 \ --hash=sha256:795b138f6875577cd91bba52baf9e445cd5118fd32723b460e30a0af30ea230e \ --hash=sha256:a5220780a404dbe3353789870978e472cfe477761f06ee55077256e509b156d0 @@ -1045,7 +1039,7 @@ wrapt==1.14.1 \ --hash=sha256:ee6acae74a2b91865910eef5e7de37dc6895ad96fa23603d1d27ea69df545015 \ --hash=sha256:ef3f72c9666bba2bab70d2a8b79f2c6d2c1a42a7f7e2b0ec83bb2f9e383950af # via - # -r test.txt + # -r requirements/test.txt # vcrpy yarl==1.8.2 \ --hash=sha256:009a028127e0a1755c38b03244c0bea9d5565630db9c4cf9572496e947137a87 \ @@ -1123,7 +1117,7 @@ yarl==1.8.2 \ --hash=sha256:fc77086ce244453e074e445104f0ecb27530d6fd3a46698e33f6c38951d5a0f1 \ --hash=sha256:ff205b58dc2929191f68162633d5e10e8044398d7a45265f90a0f1d51f85f72c # via - # -r test.txt + # -r requirements/test.txt # vcrpy zipp==3.14.0 \ --hash=sha256:188834565033387710d046e3fe96acfc9b5e86cbca7f39ff69cf21a4128198b7 \ diff --git a/requirements/test.txt b/requirements/test.txt index 522388c..d73bc66 100644 --- a/requirements/test.txt +++ b/requirements/test.txt @@ -484,9 +484,9 @@ mypy-extensions==1.0.0 \ --hash=sha256:4392f6c0eb8a5668a69e23d168ffa70f0be9ccfd32b5cc2d26a34ae5b844552d \ --hash=sha256:75dbf8955dc00442a438fc4d0666508a9a97b6bd41aa2f0ffe9d2f2725af0782 # via mypy -osidb-bindings==3.1.0 \ - --hash=sha256:38e62d3210ba2ede9da82af0d713e19602f41b2e212641d04f17e71941394e99 \ - --hash=sha256:6b222623bfdf2a90f75dcf621ec0d1c949c7b109e6ff572eb6431184b9c5154d +osidb-bindings==3.3.0 \ + --hash=sha256:19e8660dd68c06f21fcaf0b092b0565d887dcd9ea05bd98342e88de4bd949727 \ + --hash=sha256:e6bfee4a66d9805d2d45de07f3b707eac72c753317c1c79bc599265a34d79f43 # via -r requirements/base.txt packageurl-python==0.10.4 \ --hash=sha256:5c91334f942cd55d45eb0c67dd339a535ef90e25f05b9ec016ad188ed0ef9048 \ @@ -496,8 +496,9 @@ packaging==23.0 \ --hash=sha256:714ac14496c3e68c99c29b00845f7a2b85f3bb6f1078fd9f72fd20f0570002b2 \ --hash=sha256:b6ad297f8907de0fa2fe1ccbd26fdaf387f5f47c7275fedf8cce89f99446cf97 # via pytest -parse==1.19.0 \ - --hash=sha256:9ff82852bcb65d139813e2a5197627a94966245c897796760a3a2a8eb66f020b +parse==1.19.1 \ + --hash=sha256:371ed3800dc63983832159cc9373156613947707bc448b5215473a219dbd4362 \ + --hash=sha256:cc3a47236ff05da377617ddefa867b7ba983819c664e1afe46249e5b469be464 # via # behave # parse-type