From 30522b74cc5ee0dfc8a91b17fa06b6f3b320dd60 Mon Sep 17 00:00:00 2001 From: zerlok Date: Tue, 26 Nov 2024 18:13:35 +0100 Subject: [PATCH 1/6] bump pyprotostuben & ruff versions --- README.md | 1 + buf.gen.yaml | 4 +- poetry.lock | 183 +++++++++++++-------------- pyproject.toml | 6 +- src/brokrpc/message.py | 22 ++-- src/brokrpc/spec/v1/amqp_pb2.pyi | 13 +- src/brokrpc/spec/v1/call_pb2.pyi | 15 ++- src/brokrpc/spec/v1/consumer_pb2.pyi | 9 +- 8 files changed, 143 insertions(+), 110 deletions(-) diff --git a/README.md b/README.md index 9160528..b8628c1 100644 --- a/README.md +++ b/README.md @@ -1,5 +1,6 @@ # BrokRPC +[![Latest Version](https://img.shields.io/pypi/v/BrokRPC.svg)](https://pypi.python.org/pypi/BrokRPC) [![Python Supported versions](https://img.shields.io/pypi/pyversions/BrokRPC.svg)](https://pypi.python.org/pypi/BrokRPC) [![MyPy Strict](https://img.shields.io/badge/mypy-strict-blue)](https://mypy.readthedocs.io/en/stable/getting_started.html#strict-mode-and-configuration) [![Test Coverage](https://codecov.io/gh/zerlok/BrokRPC/branch/main/graph/badge.svg)](https://codecov.io/gh/zerlok/BrokRPC) diff --git a/buf.gen.yaml b/buf.gen.yaml index bc16b8d..014d90d 100644 --- a/buf.gen.yaml +++ b/buf.gen.yaml @@ -4,6 +4,8 @@ managed: plugins: - protoc_builtin: python out: src - - protoc_builtin: pyprotostuben + - protoc_builtin: mypy-stub out: src strategy: all + opt: + - include-descriptors diff --git a/poetry.lock b/poetry.lock index 96f9d87..bf18192 100644 --- a/poetry.lock +++ b/poetry.lock @@ -62,74 +62,74 @@ files = [ [[package]] name = "coverage" -version = "7.6.7" +version = "7.6.8" description = "Code coverage measurement for Python" category = "dev" optional = false python-versions = ">=3.9" files = [ - {file = "coverage-7.6.7-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:108bb458827765d538abcbf8288599fee07d2743357bdd9b9dad456c287e121e"}, - {file = "coverage-7.6.7-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:c973b2fe4dc445cb865ab369df7521df9c27bf40715c837a113edaa2aa9faf45"}, - {file = "coverage-7.6.7-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:3c6b24007c4bcd0b19fac25763a7cac5035c735ae017e9a349b927cfc88f31c1"}, - {file = "coverage-7.6.7-cp310-cp310-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:acbb8af78f8f91b3b51f58f288c0994ba63c646bc1a8a22ad072e4e7e0a49f1c"}, - {file = "coverage-7.6.7-cp310-cp310-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:ad32a981bcdedb8d2ace03b05e4fd8dace8901eec64a532b00b15217d3677dd2"}, - {file = "coverage-7.6.7-cp310-cp310-musllinux_1_2_aarch64.whl", hash = "sha256:34d23e28ccb26236718a3a78ba72744212aa383141961dd6825f6595005c8b06"}, - {file = "coverage-7.6.7-cp310-cp310-musllinux_1_2_i686.whl", hash = "sha256:e25bacb53a8c7325e34d45dddd2f2fbae0dbc230d0e2642e264a64e17322a777"}, - {file = "coverage-7.6.7-cp310-cp310-musllinux_1_2_x86_64.whl", hash = "sha256:af05bbba896c4472a29408455fe31b3797b4d8648ed0a2ccac03e074a77e2314"}, - {file = "coverage-7.6.7-cp310-cp310-win32.whl", hash = "sha256:796c9b107d11d2d69e1849b2dfe41730134b526a49d3acb98ca02f4985eeff7a"}, - {file = "coverage-7.6.7-cp310-cp310-win_amd64.whl", hash = "sha256:987a8e3da7da4eed10a20491cf790589a8e5e07656b6dc22d3814c4d88faf163"}, - {file = "coverage-7.6.7-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:7e61b0e77ff4dddebb35a0e8bb5a68bf0f8b872407d8d9f0c726b65dfabe2469"}, - {file = "coverage-7.6.7-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:1a5407a75ca4abc20d6252efeb238377a71ce7bda849c26c7a9bece8680a5d99"}, - {file = "coverage-7.6.7-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:df002e59f2d29e889c37abd0b9ee0d0e6e38c24f5f55d71ff0e09e3412a340ec"}, - {file = "coverage-7.6.7-cp311-cp311-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:673184b3156cba06154825f25af33baa2671ddae6343f23175764e65a8c4c30b"}, - {file = "coverage-7.6.7-cp311-cp311-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:e69ad502f1a2243f739f5bd60565d14a278be58be4c137d90799f2c263e7049a"}, - {file = "coverage-7.6.7-cp311-cp311-musllinux_1_2_aarch64.whl", hash = "sha256:60dcf7605c50ea72a14490d0756daffef77a5be15ed1b9fea468b1c7bda1bc3b"}, - {file = "coverage-7.6.7-cp311-cp311-musllinux_1_2_i686.whl", hash = "sha256:9c2eb378bebb2c8f65befcb5147877fc1c9fbc640fc0aad3add759b5df79d55d"}, - {file = "coverage-7.6.7-cp311-cp311-musllinux_1_2_x86_64.whl", hash = "sha256:3c0317288f032221d35fa4cbc35d9f4923ff0dfd176c79c9b356e8ef8ef2dff4"}, - {file = "coverage-7.6.7-cp311-cp311-win32.whl", hash = "sha256:951aade8297358f3618a6e0660dc74f6b52233c42089d28525749fc8267dccd2"}, - {file = "coverage-7.6.7-cp311-cp311-win_amd64.whl", hash = "sha256:5e444b8e88339a2a67ce07d41faabb1d60d1004820cee5a2c2b54e2d8e429a0f"}, - {file = "coverage-7.6.7-cp312-cp312-macosx_10_13_x86_64.whl", hash = "sha256:f07ff574986bc3edb80e2c36391678a271d555f91fd1d332a1e0f4b5ea4b6ea9"}, - {file = "coverage-7.6.7-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:49ed5ee4109258973630c1f9d099c7e72c5c36605029f3a91fe9982c6076c82b"}, - {file = "coverage-7.6.7-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:f3e8796434a8106b3ac025fd15417315d7a58ee3e600ad4dbcfddc3f4b14342c"}, - {file = "coverage-7.6.7-cp312-cp312-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:a3b925300484a3294d1c70f6b2b810d6526f2929de954e5b6be2bf8caa1f12c1"}, - {file = "coverage-7.6.7-cp312-cp312-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:3c42ec2c522e3ddd683dec5cdce8e62817afb648caedad9da725001fa530d354"}, - {file = "coverage-7.6.7-cp312-cp312-musllinux_1_2_aarch64.whl", hash = "sha256:0266b62cbea568bd5e93a4da364d05de422110cbed5056d69339bd5af5685433"}, - {file = "coverage-7.6.7-cp312-cp312-musllinux_1_2_i686.whl", hash = "sha256:e5f2a0f161d126ccc7038f1f3029184dbdf8f018230af17ef6fd6a707a5b881f"}, - {file = "coverage-7.6.7-cp312-cp312-musllinux_1_2_x86_64.whl", hash = "sha256:c132b5a22821f9b143f87446805e13580b67c670a548b96da945a8f6b4f2efbb"}, - {file = "coverage-7.6.7-cp312-cp312-win32.whl", hash = "sha256:7c07de0d2a110f02af30883cd7dddbe704887617d5c27cf373362667445a4c76"}, - {file = "coverage-7.6.7-cp312-cp312-win_amd64.whl", hash = "sha256:fd49c01e5057a451c30c9b892948976f5d38f2cbd04dc556a82743ba8e27ed8c"}, - {file = "coverage-7.6.7-cp313-cp313-macosx_10_13_x86_64.whl", hash = "sha256:46f21663e358beae6b368429ffadf14ed0a329996248a847a4322fb2e35d64d3"}, - {file = "coverage-7.6.7-cp313-cp313-macosx_11_0_arm64.whl", hash = "sha256:40cca284c7c310d622a1677f105e8507441d1bb7c226f41978ba7c86979609ab"}, - {file = "coverage-7.6.7-cp313-cp313-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:77256ad2345c29fe59ae861aa11cfc74579c88d4e8dbf121cbe46b8e32aec808"}, - {file = "coverage-7.6.7-cp313-cp313-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:87ea64b9fa52bf395272e54020537990a28078478167ade6c61da7ac04dc14bc"}, - {file = "coverage-7.6.7-cp313-cp313-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:2d608a7808793e3615e54e9267519351c3ae204a6d85764d8337bd95993581a8"}, - {file = "coverage-7.6.7-cp313-cp313-musllinux_1_2_aarch64.whl", hash = "sha256:cdd94501d65adc5c24f8a1a0eda110452ba62b3f4aeaba01e021c1ed9cb8f34a"}, - {file = "coverage-7.6.7-cp313-cp313-musllinux_1_2_i686.whl", hash = "sha256:82c809a62e953867cf57e0548c2b8464207f5f3a6ff0e1e961683e79b89f2c55"}, - {file = "coverage-7.6.7-cp313-cp313-musllinux_1_2_x86_64.whl", hash = "sha256:bb684694e99d0b791a43e9fc0fa58efc15ec357ac48d25b619f207c41f2fd384"}, - {file = "coverage-7.6.7-cp313-cp313-win32.whl", hash = "sha256:963e4a08cbb0af6623e61492c0ec4c0ec5c5cf74db5f6564f98248d27ee57d30"}, - {file = "coverage-7.6.7-cp313-cp313-win_amd64.whl", hash = "sha256:14045b8bfd5909196a90da145a37f9d335a5d988a83db34e80f41e965fb7cb42"}, - {file = "coverage-7.6.7-cp313-cp313t-macosx_10_13_x86_64.whl", hash = "sha256:f2c7a045eef561e9544359a0bf5784b44e55cefc7261a20e730baa9220c83413"}, - {file = "coverage-7.6.7-cp313-cp313t-macosx_11_0_arm64.whl", hash = "sha256:5dd4e4a49d9c72a38d18d641135d2fb0bdf7b726ca60a103836b3d00a1182acd"}, - {file = "coverage-7.6.7-cp313-cp313t-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:5c95e0fa3d1547cb6f021ab72f5c23402da2358beec0a8e6d19a368bd7b0fb37"}, - {file = "coverage-7.6.7-cp313-cp313t-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:f63e21ed474edd23f7501f89b53280014436e383a14b9bd77a648366c81dce7b"}, - {file = "coverage-7.6.7-cp313-cp313t-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:ead9b9605c54d15be228687552916c89c9683c215370c4a44f1f217d2adcc34d"}, - {file = "coverage-7.6.7-cp313-cp313t-musllinux_1_2_aarch64.whl", hash = "sha256:0573f5cbf39114270842d01872952d301027d2d6e2d84013f30966313cadb529"}, - {file = "coverage-7.6.7-cp313-cp313t-musllinux_1_2_i686.whl", hash = "sha256:e2c8e3384c12dfa19fa9a52f23eb091a8fad93b5b81a41b14c17c78e23dd1d8b"}, - {file = "coverage-7.6.7-cp313-cp313t-musllinux_1_2_x86_64.whl", hash = "sha256:70a56a2ec1869e6e9fa69ef6b76b1a8a7ef709972b9cc473f9ce9d26b5997ce3"}, - {file = "coverage-7.6.7-cp313-cp313t-win32.whl", hash = "sha256:dbba8210f5067398b2c4d96b4e64d8fb943644d5eb70be0d989067c8ca40c0f8"}, - {file = "coverage-7.6.7-cp313-cp313t-win_amd64.whl", hash = "sha256:dfd14bcae0c94004baba5184d1c935ae0d1231b8409eb6c103a5fd75e8ecdc56"}, - {file = "coverage-7.6.7-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:37a15573f988b67f7348916077c6d8ad43adb75e478d0910957394df397d2874"}, - {file = "coverage-7.6.7-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:b6cce5c76985f81da3769c52203ee94722cd5d5889731cd70d31fee939b74bf0"}, - {file = "coverage-7.6.7-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:a1ab9763d291a17b527ac6fd11d1a9a9c358280adb320e9c2672a97af346ac2c"}, - {file = "coverage-7.6.7-cp39-cp39-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:6cf96ceaa275f071f1bea3067f8fd43bec184a25a962c754024c973af871e1b7"}, - {file = "coverage-7.6.7-cp39-cp39-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:aee9cf6b0134d6f932d219ce253ef0e624f4fa588ee64830fcba193269e4daa3"}, - {file = "coverage-7.6.7-cp39-cp39-musllinux_1_2_aarch64.whl", hash = "sha256:2bc3e45c16564cc72de09e37413262b9f99167803e5e48c6156bccdfb22c8327"}, - {file = "coverage-7.6.7-cp39-cp39-musllinux_1_2_i686.whl", hash = "sha256:623e6965dcf4e28a3debaa6fcf4b99ee06d27218f46d43befe4db1c70841551c"}, - {file = "coverage-7.6.7-cp39-cp39-musllinux_1_2_x86_64.whl", hash = "sha256:850cfd2d6fc26f8346f422920ac204e1d28814e32e3a58c19c91980fa74d8289"}, - {file = "coverage-7.6.7-cp39-cp39-win32.whl", hash = "sha256:c296263093f099da4f51b3dff1eff5d4959b527d4f2f419e16508c5da9e15e8c"}, - {file = "coverage-7.6.7-cp39-cp39-win_amd64.whl", hash = "sha256:90746521206c88bdb305a4bf3342b1b7316ab80f804d40c536fc7d329301ee13"}, - {file = "coverage-7.6.7-pp39.pp310-none-any.whl", hash = "sha256:0ddcb70b3a3a57581b450571b31cb774f23eb9519c2aaa6176d3a84c9fc57671"}, - {file = "coverage-7.6.7.tar.gz", hash = "sha256:d79d4826e41441c9a118ff045e4bccb9fdbdcb1d02413e7ea6eb5c87b5439d24"}, + {file = "coverage-7.6.8-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:b39e6011cd06822eb964d038d5dff5da5d98652b81f5ecd439277b32361a3a50"}, + {file = "coverage-7.6.8-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:63c19702db10ad79151a059d2d6336fe0c470f2e18d0d4d1a57f7f9713875dcf"}, + {file = "coverage-7.6.8-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:3985b9be361d8fb6b2d1adc9924d01dec575a1d7453a14cccd73225cb79243ee"}, + {file = "coverage-7.6.8-cp310-cp310-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:644ec81edec0f4ad17d51c838a7d01e42811054543b76d4ba2c5d6af741ce2a6"}, + {file = "coverage-7.6.8-cp310-cp310-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:1f188a2402f8359cf0c4b1fe89eea40dc13b52e7b4fd4812450da9fcd210181d"}, + {file = "coverage-7.6.8-cp310-cp310-musllinux_1_2_aarch64.whl", hash = "sha256:e19122296822deafce89a0c5e8685704c067ae65d45e79718c92df7b3ec3d331"}, + {file = "coverage-7.6.8-cp310-cp310-musllinux_1_2_i686.whl", hash = "sha256:13618bed0c38acc418896005732e565b317aa9e98d855a0e9f211a7ffc2d6638"}, + {file = "coverage-7.6.8-cp310-cp310-musllinux_1_2_x86_64.whl", hash = "sha256:193e3bffca48ad74b8c764fb4492dd875038a2f9925530cb094db92bb5e47bed"}, + {file = "coverage-7.6.8-cp310-cp310-win32.whl", hash = "sha256:3988665ee376abce49613701336544041f2117de7b7fbfe91b93d8ff8b151c8e"}, + {file = "coverage-7.6.8-cp310-cp310-win_amd64.whl", hash = "sha256:f56f49b2553d7dd85fd86e029515a221e5c1f8cb3d9c38b470bc38bde7b8445a"}, + {file = "coverage-7.6.8-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:86cffe9c6dfcfe22e28027069725c7f57f4b868a3f86e81d1c62462764dc46d4"}, + {file = "coverage-7.6.8-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:d82ab6816c3277dc962cfcdc85b1efa0e5f50fb2c449432deaf2398a2928ab94"}, + {file = "coverage-7.6.8-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:13690e923a3932e4fad4c0ebfb9cb5988e03d9dcb4c5150b5fcbf58fd8bddfc4"}, + {file = "coverage-7.6.8-cp311-cp311-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:4be32da0c3827ac9132bb488d331cb32e8d9638dd41a0557c5569d57cf22c9c1"}, + {file = "coverage-7.6.8-cp311-cp311-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:44e6c85bbdc809383b509d732b06419fb4544dca29ebe18480379633623baafb"}, + {file = "coverage-7.6.8-cp311-cp311-musllinux_1_2_aarch64.whl", hash = "sha256:768939f7c4353c0fac2f7c37897e10b1414b571fd85dd9fc49e6a87e37a2e0d8"}, + {file = "coverage-7.6.8-cp311-cp311-musllinux_1_2_i686.whl", hash = "sha256:e44961e36cb13c495806d4cac67640ac2866cb99044e210895b506c26ee63d3a"}, + {file = "coverage-7.6.8-cp311-cp311-musllinux_1_2_x86_64.whl", hash = "sha256:3ea8bb1ab9558374c0ab591783808511d135a833c3ca64a18ec927f20c4030f0"}, + {file = "coverage-7.6.8-cp311-cp311-win32.whl", hash = "sha256:629a1ba2115dce8bf75a5cce9f2486ae483cb89c0145795603d6554bdc83e801"}, + {file = "coverage-7.6.8-cp311-cp311-win_amd64.whl", hash = "sha256:fb9fc32399dca861584d96eccd6c980b69bbcd7c228d06fb74fe53e007aa8ef9"}, + {file = "coverage-7.6.8-cp312-cp312-macosx_10_13_x86_64.whl", hash = "sha256:e683e6ecc587643f8cde8f5da6768e9d165cd31edf39ee90ed7034f9ca0eefee"}, + {file = "coverage-7.6.8-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:1defe91d41ce1bd44b40fabf071e6a01a5aa14de4a31b986aa9dfd1b3e3e414a"}, + {file = "coverage-7.6.8-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:d7ad66e8e50225ebf4236368cc43c37f59d5e6728f15f6e258c8639fa0dd8e6d"}, + {file = "coverage-7.6.8-cp312-cp312-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:3fe47da3e4fda5f1abb5709c156eca207eacf8007304ce3019eb001e7a7204cb"}, + {file = "coverage-7.6.8-cp312-cp312-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:202a2d645c5a46b84992f55b0a3affe4f0ba6b4c611abec32ee88358db4bb649"}, + {file = "coverage-7.6.8-cp312-cp312-musllinux_1_2_aarch64.whl", hash = "sha256:4674f0daa1823c295845b6a740d98a840d7a1c11df00d1fd62614545c1583787"}, + {file = "coverage-7.6.8-cp312-cp312-musllinux_1_2_i686.whl", hash = "sha256:74610105ebd6f33d7c10f8907afed696e79c59e3043c5f20eaa3a46fddf33b4c"}, + {file = "coverage-7.6.8-cp312-cp312-musllinux_1_2_x86_64.whl", hash = "sha256:37cda8712145917105e07aab96388ae76e787270ec04bcb9d5cc786d7cbb8443"}, + {file = "coverage-7.6.8-cp312-cp312-win32.whl", hash = "sha256:9e89d5c8509fbd6c03d0dd1972925b22f50db0792ce06324ba069f10787429ad"}, + {file = "coverage-7.6.8-cp312-cp312-win_amd64.whl", hash = "sha256:379c111d3558272a2cae3d8e57e6b6e6f4fe652905692d54bad5ea0ca37c5ad4"}, + {file = "coverage-7.6.8-cp313-cp313-macosx_10_13_x86_64.whl", hash = "sha256:0b0c69f4f724c64dfbfe79f5dfb503b42fe6127b8d479b2677f2b227478db2eb"}, + {file = "coverage-7.6.8-cp313-cp313-macosx_11_0_arm64.whl", hash = "sha256:c15b32a7aca8038ed7644f854bf17b663bc38e1671b5d6f43f9a2b2bd0c46f63"}, + {file = "coverage-7.6.8-cp313-cp313-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:63068a11171e4276f6ece913bde059e77c713b48c3a848814a6537f35afb8365"}, + {file = "coverage-7.6.8-cp313-cp313-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:6f4548c5ead23ad13fb7a2c8ea541357474ec13c2b736feb02e19a3085fac002"}, + {file = "coverage-7.6.8-cp313-cp313-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:3b4b4299dd0d2c67caaaf286d58aef5e75b125b95615dda4542561a5a566a1e3"}, + {file = "coverage-7.6.8-cp313-cp313-musllinux_1_2_aarch64.whl", hash = "sha256:c9ebfb2507751f7196995142f057d1324afdab56db1d9743aab7f50289abd022"}, + {file = "coverage-7.6.8-cp313-cp313-musllinux_1_2_i686.whl", hash = "sha256:c1b4474beee02ede1eef86c25ad4600a424fe36cff01a6103cb4533c6bf0169e"}, + {file = "coverage-7.6.8-cp313-cp313-musllinux_1_2_x86_64.whl", hash = "sha256:d9fd2547e6decdbf985d579cf3fc78e4c1d662b9b0ff7cc7862baaab71c9cc5b"}, + {file = "coverage-7.6.8-cp313-cp313-win32.whl", hash = "sha256:8aae5aea53cbfe024919715eca696b1a3201886ce83790537d1c3668459c7146"}, + {file = "coverage-7.6.8-cp313-cp313-win_amd64.whl", hash = "sha256:ae270e79f7e169ccfe23284ff5ea2d52a6f401dc01b337efb54b3783e2ce3f28"}, + {file = "coverage-7.6.8-cp313-cp313t-macosx_10_13_x86_64.whl", hash = "sha256:de38add67a0af869b0d79c525d3e4588ac1ffa92f39116dbe0ed9753f26eba7d"}, + {file = "coverage-7.6.8-cp313-cp313t-macosx_11_0_arm64.whl", hash = "sha256:b07c25d52b1c16ce5de088046cd2432b30f9ad5e224ff17c8f496d9cb7d1d451"}, + {file = "coverage-7.6.8-cp313-cp313t-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:62a66ff235e4c2e37ed3b6104d8b478d767ff73838d1222132a7a026aa548764"}, + {file = "coverage-7.6.8-cp313-cp313t-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:09b9f848b28081e7b975a3626e9081574a7b9196cde26604540582da60235fdf"}, + {file = "coverage-7.6.8-cp313-cp313t-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:093896e530c38c8e9c996901858ac63f3d4171268db2c9c8b373a228f459bbc5"}, + {file = "coverage-7.6.8-cp313-cp313t-musllinux_1_2_aarch64.whl", hash = "sha256:9a7b8ac36fd688c8361cbc7bf1cb5866977ece6e0b17c34aa0df58bda4fa18a4"}, + {file = "coverage-7.6.8-cp313-cp313t-musllinux_1_2_i686.whl", hash = "sha256:38c51297b35b3ed91670e1e4efb702b790002e3245a28c76e627478aa3c10d83"}, + {file = "coverage-7.6.8-cp313-cp313t-musllinux_1_2_x86_64.whl", hash = "sha256:2e4e0f60cb4bd7396108823548e82fdab72d4d8a65e58e2c19bbbc2f1e2bfa4b"}, + {file = "coverage-7.6.8-cp313-cp313t-win32.whl", hash = "sha256:6535d996f6537ecb298b4e287a855f37deaf64ff007162ec0afb9ab8ba3b8b71"}, + {file = "coverage-7.6.8-cp313-cp313t-win_amd64.whl", hash = "sha256:c79c0685f142ca53256722a384540832420dff4ab15fec1863d7e5bc8691bdcc"}, + {file = "coverage-7.6.8-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:3ac47fa29d8d41059ea3df65bd3ade92f97ee4910ed638e87075b8e8ce69599e"}, + {file = "coverage-7.6.8-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:24eda3a24a38157eee639ca9afe45eefa8d2420d49468819ac5f88b10de84f4c"}, + {file = "coverage-7.6.8-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:e4c81ed2820b9023a9a90717020315e63b17b18c274a332e3b6437d7ff70abe0"}, + {file = "coverage-7.6.8-cp39-cp39-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:bd55f8fc8fa494958772a2a7302b0354ab16e0b9272b3c3d83cdb5bec5bd1779"}, + {file = "coverage-7.6.8-cp39-cp39-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:f39e2f3530ed1626c66e7493be7a8423b023ca852aacdc91fb30162c350d2a92"}, + {file = "coverage-7.6.8-cp39-cp39-musllinux_1_2_aarch64.whl", hash = "sha256:716a78a342679cd1177bc8c2fe957e0ab91405bd43a17094324845200b2fddf4"}, + {file = "coverage-7.6.8-cp39-cp39-musllinux_1_2_i686.whl", hash = "sha256:177f01eeaa3aee4a5ffb0d1439c5952b53d5010f86e9d2667963e632e30082cc"}, + {file = "coverage-7.6.8-cp39-cp39-musllinux_1_2_x86_64.whl", hash = "sha256:912e95017ff51dc3d7b6e2be158dedc889d9a5cc3382445589ce554f1a34c0ea"}, + {file = "coverage-7.6.8-cp39-cp39-win32.whl", hash = "sha256:4db3ed6a907b555e57cc2e6f14dc3a4c2458cdad8919e40b5357ab9b6db6c43e"}, + {file = "coverage-7.6.8-cp39-cp39-win_amd64.whl", hash = "sha256:428ac484592f780e8cd7b6b14eb568f7c85460c92e2a37cb0c0e5186e1a0d076"}, + {file = "coverage-7.6.8-pp39.pp310-none-any.whl", hash = "sha256:5c52a036535d12590c32c49209e79cabaad9f9ad8aa4cbd875b68c4d67a9cbce"}, + {file = "coverage-7.6.8.tar.gz", hash = "sha256:8b2b8503edb06822c86d82fa64a4a5cb0760bb8f31f26e138ec743f422f37cfc"}, ] [package.extras] @@ -642,7 +642,7 @@ name = "protobuf" version = "5.28.3" description = "" category = "main" -optional = false +optional = true python-versions = ">=3.8" files = [ {file = "protobuf-5.28.3-cp310-abi3-win32.whl", hash = "sha256:0c4eec6f987338617072592b97943fdbe30d019c56126493111cf24344c1cc24"}, @@ -660,18 +660,17 @@ files = [ [[package]] name = "pyprotostuben" -version = "0.2.1" +version = "0.3.1" description = "Generate Python MyPy stub modules from protobuf files." category = "dev" optional = false -python-versions = "<4.0,>=3.9" -files = [ - {file = "pyprotostuben-0.2.1-py3-none-any.whl", hash = "sha256:848e9c7a17156e5630726b33c681210409c4544cd5e826b1df198ed9b85a3d29"}, - {file = "pyprotostuben-0.2.1.tar.gz", hash = "sha256:82417a0a574623821c3718ae869dff528ec2e7d1a146a240d5fb082e10d12513"}, -] +python-versions = "*" +files = [] +develop = true -[package.dependencies] -protobuf = ">=5.28.3,<6.0.0" +[package.source] +type = "directory" +url = "../pyprotostuben" [[package]] name = "pytest" @@ -1055,30 +1054,30 @@ files = [ [[package]] name = "ruff" -version = "0.7.4" +version = "0.8.0" description = "An extremely fast Python linter and code formatter, written in Rust." category = "dev" optional = false python-versions = ">=3.7" files = [ - {file = "ruff-0.7.4-py3-none-linux_armv6l.whl", hash = "sha256:a4919925e7684a3f18e18243cd6bea7cfb8e968a6eaa8437971f681b7ec51478"}, - {file = "ruff-0.7.4-py3-none-macosx_10_12_x86_64.whl", hash = "sha256:cfb365c135b830778dda8c04fb7d4280ed0b984e1aec27f574445231e20d6c63"}, - {file = "ruff-0.7.4-py3-none-macosx_11_0_arm64.whl", hash = "sha256:63a569b36bc66fbadec5beaa539dd81e0527cb258b94e29e0531ce41bacc1f20"}, - {file = "ruff-0.7.4-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:0d06218747d361d06fd2fdac734e7fa92df36df93035db3dc2ad7aa9852cb109"}, - {file = "ruff-0.7.4-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.whl", hash = "sha256:e0cea28d0944f74ebc33e9f934238f15c758841f9f5edd180b5315c203293452"}, - {file = "ruff-0.7.4-py3-none-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:80094ecd4793c68b2571b128f91754d60f692d64bc0d7272ec9197fdd09bf9ea"}, - {file = "ruff-0.7.4-py3-none-manylinux_2_17_ppc64.manylinux2014_ppc64.whl", hash = "sha256:997512325c6620d1c4c2b15db49ef59543ef9cd0f4aa8065ec2ae5103cedc7e7"}, - {file = "ruff-0.7.4-py3-none-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:00b4cf3a6b5fad6d1a66e7574d78956bbd09abfd6c8a997798f01f5da3d46a05"}, - {file = "ruff-0.7.4-py3-none-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:7dbdc7d8274e1422722933d1edddfdc65b4336abf0b16dfcb9dedd6e6a517d06"}, - {file = "ruff-0.7.4-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:0e92dfb5f00eaedb1501b2f906ccabfd67b2355bdf117fea9719fc99ac2145bc"}, - {file = "ruff-0.7.4-py3-none-musllinux_1_2_aarch64.whl", hash = "sha256:3bd726099f277d735dc38900b6a8d6cf070f80828877941983a57bca1cd92172"}, - {file = "ruff-0.7.4-py3-none-musllinux_1_2_armv7l.whl", hash = "sha256:2e32829c429dd081ee5ba39aef436603e5b22335c3d3fff013cd585806a6486a"}, - {file = "ruff-0.7.4-py3-none-musllinux_1_2_i686.whl", hash = "sha256:662a63b4971807623f6f90c1fb664613f67cc182dc4d991471c23c541fee62dd"}, - {file = "ruff-0.7.4-py3-none-musllinux_1_2_x86_64.whl", hash = "sha256:876f5e09eaae3eb76814c1d3b68879891d6fde4824c015d48e7a7da4cf066a3a"}, - {file = "ruff-0.7.4-py3-none-win32.whl", hash = "sha256:75c53f54904be42dd52a548728a5b572344b50d9b2873d13a3f8c5e3b91f5cac"}, - {file = "ruff-0.7.4-py3-none-win_amd64.whl", hash = "sha256:745775c7b39f914238ed1f1b0bebed0b9155a17cd8bc0b08d3c87e4703b990d6"}, - {file = "ruff-0.7.4-py3-none-win_arm64.whl", hash = "sha256:11bff065102c3ae9d3ea4dc9ecdfe5a5171349cdd0787c1fc64761212fc9cf1f"}, - {file = "ruff-0.7.4.tar.gz", hash = "sha256:cd12e35031f5af6b9b93715d8c4f40360070b2041f81273d0527683d5708fce2"}, + {file = "ruff-0.8.0-py3-none-linux_armv6l.whl", hash = "sha256:fcb1bf2cc6706adae9d79c8d86478677e3bbd4ced796ccad106fd4776d395fea"}, + {file = "ruff-0.8.0-py3-none-macosx_10_12_x86_64.whl", hash = "sha256:295bb4c02d58ff2ef4378a1870c20af30723013f441c9d1637a008baaf928c8b"}, + {file = "ruff-0.8.0-py3-none-macosx_11_0_arm64.whl", hash = "sha256:7b1f1c76b47c18fa92ee78b60d2d20d7e866c55ee603e7d19c1e991fad933a9a"}, + {file = "ruff-0.8.0-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:eb0d4f250a7711b67ad513fde67e8870109e5ce590a801c3722580fe98c33a99"}, + {file = "ruff-0.8.0-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.whl", hash = "sha256:0e55cce9aa93c5d0d4e3937e47b169035c7e91c8655b0974e61bb79cf398d49c"}, + {file = "ruff-0.8.0-py3-none-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:3f4cd64916d8e732ce6b87f3f5296a8942d285bbbc161acee7fe561134af64f9"}, + {file = "ruff-0.8.0-py3-none-manylinux_2_17_ppc64.manylinux2014_ppc64.whl", hash = "sha256:c5c1466be2a2ebdf7c5450dd5d980cc87c8ba6976fb82582fea18823da6fa362"}, + {file = "ruff-0.8.0-py3-none-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:2dabfd05b96b7b8f2da00d53c514eea842bff83e41e1cceb08ae1966254a51df"}, + {file = "ruff-0.8.0-py3-none-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:facebdfe5a5af6b1588a1d26d170635ead6892d0e314477e80256ef4a8470cf3"}, + {file = "ruff-0.8.0-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:87a8e86bae0dbd749c815211ca11e3a7bd559b9710746c559ed63106d382bd9c"}, + {file = "ruff-0.8.0-py3-none-musllinux_1_2_aarch64.whl", hash = "sha256:85e654f0ded7befe2d61eeaf3d3b1e4ef3894469cd664ffa85006c7720f1e4a2"}, + {file = "ruff-0.8.0-py3-none-musllinux_1_2_armv7l.whl", hash = "sha256:83a55679c4cb449fa527b8497cadf54f076603cc36779b2170b24f704171ce70"}, + {file = "ruff-0.8.0-py3-none-musllinux_1_2_i686.whl", hash = "sha256:812e2052121634cf13cd6fddf0c1871d0ead1aad40a1a258753c04c18bb71bbd"}, + {file = "ruff-0.8.0-py3-none-musllinux_1_2_x86_64.whl", hash = "sha256:780d5d8523c04202184405e60c98d7595bdb498c3c6abba3b6d4cdf2ca2af426"}, + {file = "ruff-0.8.0-py3-none-win32.whl", hash = "sha256:5fdb6efecc3eb60bba5819679466471fd7d13c53487df7248d6e27146e985468"}, + {file = "ruff-0.8.0-py3-none-win_amd64.whl", hash = "sha256:582891c57b96228d146725975fbb942e1f30a0c4ba19722e692ca3eb25cc9b4f"}, + {file = "ruff-0.8.0-py3-none-win_arm64.whl", hash = "sha256:ba93e6294e9a737cd726b74b09a6972e36bb511f9a102f1d9a7e1ce94dd206a6"}, + {file = "ruff-0.8.0.tar.gz", hash = "sha256:a7ccfe6331bf8c8dad715753e157457faf7351c2b69f62f32c165c2dbcbacd44"}, ] [[package]] @@ -1234,4 +1233,4 @@ protobuf = ["googleapis-common-protos", "protobuf"] [metadata] lock-version = "2.0" python-versions = "^3.12" -content-hash = "5d93bfcdb23a370b02ea2611ff6c1cccb3e6dd606553d5debed601cf578129d6" +content-hash = "a56190ddb19cfdbe1522b71a47d08840857efc13bb0b7186958d92bea4db708c" diff --git a/pyproject.toml b/pyproject.toml index df38880..8c74022 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [tool.poetry] name = "BrokRPC" -version = "0.2.0" +version = "0.2.1" description = "framework for gRPC like server-client communication over message brokers" authors = ["zerlok "] readme = "README.md" @@ -47,12 +47,12 @@ types-protobuf = "^5.26.0.20240422" mypy = "^1.13.0" pytest = "^8.3.3" pytest-cov = "^5.0.0" -ruff = "^0.7.4" +ruff = "^0.8.0" pytest-asyncio = "^0.24.0" pytest-timeout = "^2.3.1" pytest-mypy-plugins = "^3.1.2" types-aiofiles = "^24.1.0.20240626" -pyprotostuben = "0.2.1" +pyprotostuben = "^0.3.1" [build-system] diff --git a/src/brokrpc/message.py b/src/brokrpc/message.py index 3c27e1e..a35284c 100644 --- a/src/brokrpc/message.py +++ b/src/brokrpc/message.py @@ -130,22 +130,22 @@ def app_id(self) -> str | None: class AppMessage[T](Message[T]): __slots__ = ( + "__app_id", "__body", - "__routing_key", - "__exchange", - "__content_type", "__content_encoding", - "__headers", + "__content_type", + "__correlation_id", "__delivery_mode", + "__exchange", + "__headers", + "__message_id", + "__message_type", "__priority", - "__correlation_id", "__reply_to", + "__routing_key", "__timeout", - "__message_id", "__timestamp", - "__message_type", "__user_id", - "__app_id", ) # NOTE: message constructor has a lot of options to set up a structure (dataclass) @@ -276,12 +276,12 @@ def app_id(self) -> str | None: @t.final class PackedMessage[T](Message[T]): __slots__ = ( - "__original", "__body", - "__content_type", "__content_encoding", + "__content_type", "__headers", "__message_type", + "__original", ) # NOTE: message constructor has a lot of options to set up a structure (dataclass) @@ -382,8 +382,8 @@ def app_id(self) -> str | None: @t.final class UnpackedMessage[T](Message[T]): __slots__ = ( - "__original", "__body", + "__original", ) def __init__(self, original: Message[object], body: T) -> None: diff --git a/src/brokrpc/spec/v1/amqp_pb2.pyi b/src/brokrpc/spec/v1/amqp_pb2.pyi index bd834f6..f808355 100644 --- a/src/brokrpc/spec/v1/amqp_pb2.pyi +++ b/src/brokrpc/spec/v1/amqp_pb2.pyi @@ -1,6 +1,9 @@ import builtins import enum +import google.protobuf.descriptor +import google.protobuf.descriptor_pb2 import google.protobuf.message +import pyprotostuben.protobuf.extension import typing class ExchangeType(enum.IntEnum): @@ -21,6 +24,7 @@ class ArgumentListValue(google.protobuf.message.Message): def HasField(self, field_name: typing.NoReturn) -> typing.NoReturn:... def WhichOneof(self, oneof_group: typing.NoReturn) -> typing.NoReturn:... + DESCRIPTOR: google.protobuf.descriptor.Descriptor class ArgumentMapValue(google.protobuf.message.Message): @@ -32,6 +36,7 @@ class ArgumentMapValue(google.protobuf.message.Message): def HasField(self, field_name: typing.NoReturn) -> typing.NoReturn:... def WhichOneof(self, oneof_group: typing.NoReturn) -> typing.NoReturn:... + DESCRIPTOR: google.protobuf.descriptor.Descriptor class ArgumentValue(google.protobuf.message.Message): @@ -61,6 +66,7 @@ class ArgumentValue(google.protobuf.message.Message): def HasField(self, field_name: typing.NoReturn) -> typing.NoReturn:... def WhichOneof(self, oneof_group: typing.Literal['value']) -> typing.Optional[typing.Literal['null_value', 'bool_value', 'int_value', 'float_value', 'str_value', 'list_value', 'map_value']]:... + DESCRIPTOR: google.protobuf.descriptor.Descriptor class ExchangeOptions(google.protobuf.message.Message): """A set of attributes of exchange entity in AMQP""" @@ -85,6 +91,7 @@ class ExchangeOptions(google.protobuf.message.Message): def HasField(self, field_name: typing.Literal['name', 'type', 'durable', 'auto_delete']) -> builtins.bool:... def WhichOneof(self, oneof_group: typing.NoReturn) -> typing.NoReturn:... + DESCRIPTOR: google.protobuf.descriptor.Descriptor class QueueOptions(google.protobuf.message.Message): """A set of attributes of queue entity in AMQP""" @@ -108,4 +115,8 @@ class QueueOptions(google.protobuf.message.Message): def HasField(self, field_name: typing.Literal['name', 'durable', 'exclusive', 'auto_delete']) -> builtins.bool:... - def WhichOneof(self, oneof_group: typing.NoReturn) -> typing.NoReturn:... \ No newline at end of file + def WhichOneof(self, oneof_group: typing.NoReturn) -> typing.NoReturn:... + DESCRIPTOR: google.protobuf.descriptor.Descriptor +exchange: typing.Final[pyprotostuben.protobuf.extension.ExtensionDescriptor[google.protobuf.descriptor_pb2.ServiceOptions, ExchangeOptions]] +queue: typing.Final[pyprotostuben.protobuf.extension.ExtensionDescriptor[google.protobuf.descriptor_pb2.MethodOptions, QueueOptions]] +DESCRIPTOR: google.protobuf.descriptor.FileDescriptor \ No newline at end of file diff --git a/src/brokrpc/spec/v1/call_pb2.pyi b/src/brokrpc/spec/v1/call_pb2.pyi index a70c6de..9c357c5 100644 --- a/src/brokrpc/spec/v1/call_pb2.pyi +++ b/src/brokrpc/spec/v1/call_pb2.pyi @@ -1,5 +1,6 @@ import builtins import google.protobuf.any_pb2 +import google.protobuf.descriptor import google.protobuf.message import google.rpc.code_pb2 import typing @@ -17,6 +18,7 @@ class Error(google.protobuf.message.Message): def HasField(self, field_name: typing.Literal['message']) -> builtins.bool:... def WhichOneof(self, oneof_group: typing.NoReturn) -> typing.NoReturn:... + DESCRIPTOR: google.protobuf.descriptor.Descriptor class UnaryRequest(google.protobuf.message.Message): @@ -31,6 +33,7 @@ class UnaryRequest(google.protobuf.message.Message): def HasField(self, field_name: typing.NoReturn) -> typing.NoReturn:... def WhichOneof(self, oneof_group: typing.NoReturn) -> typing.NoReturn:... + DESCRIPTOR: google.protobuf.descriptor.Descriptor class UnaryResponse(google.protobuf.message.Message): @@ -51,6 +54,7 @@ class UnaryResponse(google.protobuf.message.Message): def HasField(self, field_name: typing.Literal['payload', 'error']) -> builtins.bool:... def WhichOneof(self, oneof_group: typing.NoReturn) -> typing.NoReturn:... + DESCRIPTOR: google.protobuf.descriptor.Descriptor class StreamRequest(google.protobuf.message.Message): @@ -61,6 +65,7 @@ class StreamRequest(google.protobuf.message.Message): def HasField(self, field_name: typing.NoReturn) -> typing.NoReturn:... def WhichOneof(self, oneof_group: typing.NoReturn) -> typing.NoReturn:... + DESCRIPTOR: google.protobuf.descriptor.Descriptor class Part(google.protobuf.message.Message): @@ -72,6 +77,7 @@ class StreamRequest(google.protobuf.message.Message): def HasField(self, field_name: typing.NoReturn) -> typing.NoReturn:... def WhichOneof(self, oneof_group: typing.NoReturn) -> typing.NoReturn:... + DESCRIPTOR: google.protobuf.descriptor.Descriptor class End(google.protobuf.message.Message): @@ -80,6 +86,7 @@ class StreamRequest(google.protobuf.message.Message): def HasField(self, field_name: typing.NoReturn) -> typing.NoReturn:... def WhichOneof(self, oneof_group: typing.NoReturn) -> typing.NoReturn:... + DESCRIPTOR: google.protobuf.descriptor.Descriptor def __init__(self, *, uuid: builtins.bytes, index: builtins.int, start: typing.Optional[StreamRequest.Start]=None, part: typing.Optional[StreamRequest.Part]=None, end: typing.Optional[StreamRequest.End]=None) -> None:... @@ -101,6 +108,7 @@ class StreamRequest(google.protobuf.message.Message): def HasField(self, field_name: typing.NoReturn) -> typing.NoReturn:... def WhichOneof(self, oneof_group: typing.Literal['event']) -> typing.Optional[typing.Literal['start', 'part', 'end']]:... + DESCRIPTOR: google.protobuf.descriptor.Descriptor class StreamResponse(google.protobuf.message.Message): @@ -111,6 +119,7 @@ class StreamResponse(google.protobuf.message.Message): def HasField(self, field_name: typing.NoReturn) -> typing.NoReturn:... def WhichOneof(self, oneof_group: typing.NoReturn) -> typing.NoReturn:... + DESCRIPTOR: google.protobuf.descriptor.Descriptor class Part(google.protobuf.message.Message): @@ -122,6 +131,7 @@ class StreamResponse(google.protobuf.message.Message): def HasField(self, field_name: typing.NoReturn) -> typing.NoReturn:... def WhichOneof(self, oneof_group: typing.NoReturn) -> typing.NoReturn:... + DESCRIPTOR: google.protobuf.descriptor.Descriptor class End(google.protobuf.message.Message): @@ -136,6 +146,7 @@ class StreamResponse(google.protobuf.message.Message): def HasField(self, field_name: typing.Literal['error']) -> builtins.bool:... def WhichOneof(self, oneof_group: typing.NoReturn) -> typing.NoReturn:... + DESCRIPTOR: google.protobuf.descriptor.Descriptor def __init__(self, *, uuid: builtins.bytes, index: builtins.int, start: typing.Optional[StreamResponse.Start]=None, part: typing.Optional[StreamResponse.Part]=None, end: typing.Optional[StreamResponse.End]=None) -> None:... @@ -156,4 +167,6 @@ class StreamResponse(google.protobuf.message.Message): def HasField(self, field_name: typing.NoReturn) -> typing.NoReturn:... - def WhichOneof(self, oneof_group: typing.Literal['event']) -> typing.Optional[typing.Literal['start', 'part', 'end']]:... \ No newline at end of file + def WhichOneof(self, oneof_group: typing.Literal['event']) -> typing.Optional[typing.Literal['start', 'part', 'end']]:... + DESCRIPTOR: google.protobuf.descriptor.Descriptor +DESCRIPTOR: google.protobuf.descriptor.FileDescriptor \ No newline at end of file diff --git a/src/brokrpc/spec/v1/consumer_pb2.pyi b/src/brokrpc/spec/v1/consumer_pb2.pyi index 5ede463..9a9b567 100644 --- a/src/brokrpc/spec/v1/consumer_pb2.pyi +++ b/src/brokrpc/spec/v1/consumer_pb2.pyi @@ -1,5 +1,8 @@ import builtins +import google.protobuf.descriptor +import google.protobuf.descriptor_pb2 import google.protobuf.message +import pyprotostuben.protobuf.extension import typing class Void(google.protobuf.message.Message): @@ -11,6 +14,7 @@ class Void(google.protobuf.message.Message): def HasField(self, field_name: typing.NoReturn) -> typing.NoReturn:... def WhichOneof(self, oneof_group: typing.NoReturn) -> typing.NoReturn:... + DESCRIPTOR: google.protobuf.descriptor.Descriptor class ConsumerOptions(google.protobuf.message.Message): @@ -23,4 +27,7 @@ class ConsumerOptions(google.protobuf.message.Message): def HasField(self, field_name: typing.Literal['fading']) -> builtins.bool:... - def WhichOneof(self, oneof_group: typing.NoReturn) -> typing.NoReturn:... \ No newline at end of file + def WhichOneof(self, oneof_group: typing.NoReturn) -> typing.NoReturn:... + DESCRIPTOR: google.protobuf.descriptor.Descriptor +consumer: typing.Final[pyprotostuben.protobuf.extension.ExtensionDescriptor[google.protobuf.descriptor_pb2.MethodOptions, ConsumerOptions]] +DESCRIPTOR: google.protobuf.descriptor.FileDescriptor \ No newline at end of file From 13b5e10290c796fdefa794af7f0c29a5f22dc4a0 Mon Sep 17 00:00:00 2001 From: zerlok Date: Tue, 26 Nov 2024 18:51:19 +0100 Subject: [PATCH 2/6] add buf CI --- .github/workflows/publish.yaml | 1 + .github/workflows/pull-request.yaml | 12 +++++++++++- .github/workflows/push.yaml | 19 +++++++++++++++++++ 3 files changed, 31 insertions(+), 1 deletion(-) create mode 100644 .github/workflows/push.yaml diff --git a/.github/workflows/publish.yaml b/.github/workflows/publish.yaml index cc36a0e..cffe9d2 100644 --- a/.github/workflows/publish.yaml +++ b/.github/workflows/publish.yaml @@ -7,6 +7,7 @@ on: jobs: publish: runs-on: ubuntu-latest + environment: release permissions: id-token: write steps: diff --git a/.github/workflows/pull-request.yaml b/.github/workflows/pull-request.yaml index f6e9b50..e2032ac 100644 --- a/.github/workflows/pull-request.yaml +++ b/.github/workflows/pull-request.yaml @@ -7,8 +7,18 @@ on: push: branches: - main - jobs: + buf: + runs-on: ubuntu-latest + strategy: + fail-fast: false + steps: + - uses: actions/checkout@v4 + - uses: bufbuild/buf-setup-action@v1 + - uses: bufbuild/buf-lint-action@v1 + - uses: bufbuild/buf-breaking-action@v1 + with: + against: 'https://github.com/zerlok/BrokRPC.git#branch=main' static: runs-on: ubuntu-latest strategy: diff --git a/.github/workflows/push.yaml b/.github/workflows/push.yaml new file mode 100644 index 0000000..b5c0e0a --- /dev/null +++ b/.github/workflows/push.yaml @@ -0,0 +1,19 @@ +name: Push + +environment: + +on: + push: + branches: + - main + +jobs: + buf: + environment: release + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - uses: bufbuild/buf-setup-action@v1 + - uses: bufbuild/buf-push-action@v1 + with: + buf_token: ${{ secrets.BUF_TOKEN }} From e507797c6ff5dcabaecb9f1dfd74dd70c9d28d2d Mon Sep 17 00:00:00 2001 From: zerlok Date: Tue, 26 Nov 2024 18:51:24 +0100 Subject: [PATCH 3/6] add dependabot CI --- .github/dependabot.yml | 34 ++++++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) create mode 100644 .github/dependabot.yml diff --git a/.github/dependabot.yml b/.github/dependabot.yml new file mode 100644 index 0000000..a07d781 --- /dev/null +++ b/.github/dependabot.yml @@ -0,0 +1,34 @@ +# To get started with Dependabot version updates, you'll need to specify which +# package ecosystems to update and where the package manifests are located. +# Please see the documentation for all configuration options: +# https://docs.github.com/code-security/dependabot/dependabot-version-updates/configuration-options-for-the-dependabot.yml-file + +version: 2 +updates: + - package-ecosystem: "pip" + directory: "/" + schedule: + interval: "weekly" + day: sunday + time: "12:00" + reviewers: + - "zerlok" + groups: + main-dependencies: + applies-to: version-updates + dependency-type: production + patterns: + - "^protobuf$" + - "^yarl$" + - "^aiormq$" + - "^aiofiles$" + dev-dependencies: + applies-to: version-updates + dependency-type: development + patterns: + - "*" + exclude-patterns: + - "^protobuf$" + - "^yarl$" + - "^aiormq$" + - "^aiofiles$" From 8739e357aface6c0643a3d004d99e3910dca9bf5 Mon Sep 17 00:00:00 2001 From: zerlok Date: Tue, 26 Nov 2024 18:56:14 +0100 Subject: [PATCH 4/6] fix poetry.lock --- poetry.lock | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/poetry.lock b/poetry.lock index bf18192..99657a3 100644 --- a/poetry.lock +++ b/poetry.lock @@ -642,7 +642,7 @@ name = "protobuf" version = "5.28.3" description = "" category = "main" -optional = true +optional = false python-versions = ">=3.8" files = [ {file = "protobuf-5.28.3-cp310-abi3-win32.whl", hash = "sha256:0c4eec6f987338617072592b97943fdbe30d019c56126493111cf24344c1cc24"}, @@ -664,13 +664,14 @@ version = "0.3.1" description = "Generate Python MyPy stub modules from protobuf files." category = "dev" optional = false -python-versions = "*" -files = [] -develop = true +python-versions = "<4.0,>=3.9" +files = [ + {file = "pyprotostuben-0.3.1-py3-none-any.whl", hash = "sha256:799dd8a59e558fae3c92f761ae81b50339592ccb8829cb26e20b1dac943b8d08"}, + {file = "pyprotostuben-0.3.1.tar.gz", hash = "sha256:ad5e7f310082c98deabdeea863764f3d38ca2b2396a9801a11738e1d79a5afc5"}, +] -[package.source] -type = "directory" -url = "../pyprotostuben" +[package.dependencies] +protobuf = ">=5.28.3,<6.0.0" [[package]] name = "pytest" From 3e7da5c05f049344cdd94bd811ea791f46ddcc65 Mon Sep 17 00:00:00 2001 From: zerlok Date: Tue, 26 Nov 2024 19:12:35 +0100 Subject: [PATCH 5/6] reconfigure buf action --- .github/workflows/publish.yaml | 18 ++++++++++++++++-- .github/workflows/pull-request.yaml | 19 ++++++++++--------- .github/workflows/push.yaml | 19 ------------------- 3 files changed, 26 insertions(+), 30 deletions(-) delete mode 100644 .github/workflows/push.yaml diff --git a/.github/workflows/publish.yaml b/.github/workflows/publish.yaml index cffe9d2..a6c64f7 100644 --- a/.github/workflows/publish.yaml +++ b/.github/workflows/publish.yaml @@ -1,11 +1,25 @@ -name: Publish Python Package +name: publish release on: release: types: [published] jobs: - publish: + buf: + runs-on: ubuntu-latest + permissions: + contents: read + steps: + - uses: actions/checkout@v4 + - uses: bufbuild/buf-action@v1 + with: + lint: false + format: false + breaking: false + push: true + token: ${{ secrets.BUF_TOKEN }} + + pypi: runs-on: ubuntu-latest environment: release permissions: diff --git a/.github/workflows/pull-request.yaml b/.github/workflows/pull-request.yaml index e2032ac..b790f8f 100644 --- a/.github/workflows/pull-request.yaml +++ b/.github/workflows/pull-request.yaml @@ -1,4 +1,4 @@ -name: Check On Pull Request +name: pull request checks on: pull_request: @@ -7,26 +7,26 @@ on: push: branches: - main + jobs: buf: runs-on: ubuntu-latest - strategy: - fail-fast: false + permissions: + contents: read + pull-requests: write steps: - uses: actions/checkout@v4 - - uses: bufbuild/buf-setup-action@v1 - - uses: bufbuild/buf-lint-action@v1 - - uses: bufbuild/buf-breaking-action@v1 + - uses: bufbuild/buf-action@v1 with: - against: 'https://github.com/zerlok/BrokRPC.git#branch=main' + breaking_against: 'https://github.com/zerlok/BrokRPC.git#branch=main' + token: ${{ secrets.BUF_TOKEN }} + static: runs-on: ubuntu-latest strategy: fail-fast: false matrix: python-version: [ "3.12" ] -# TODO: enable buf lint & format -# buf-version: [ "1.31.0" ] steps: - uses: actions/checkout@v4 - name: Install Python ${{ matrix.python-version }} @@ -54,6 +54,7 @@ jobs: run: poetry run ruff check - name: Run ruff format run: poetry run ruff format --check + test: runs-on: ubuntu-latest services: diff --git a/.github/workflows/push.yaml b/.github/workflows/push.yaml deleted file mode 100644 index b5c0e0a..0000000 --- a/.github/workflows/push.yaml +++ /dev/null @@ -1,19 +0,0 @@ -name: Push - -environment: - -on: - push: - branches: - - main - -jobs: - buf: - environment: release - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v4 - - uses: bufbuild/buf-setup-action@v1 - - uses: bufbuild/buf-push-action@v1 - with: - buf_token: ${{ secrets.BUF_TOKEN }} From a25015e8f31df7a45aa6a43a44176c1cba94abaa Mon Sep 17 00:00:00 2001 From: zerlok Date: Tue, 26 Nov 2024 19:26:30 +0100 Subject: [PATCH 6/6] add BSR note to README.md --- README.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/README.md b/README.md index b8628c1..ba68e4b 100644 --- a/README.md +++ b/README.md @@ -28,6 +28,8 @@ You can generate python code for server & client from `.proto` files. The [pyprotostuben](https://github.com/zerlok/pyprotostuben) project provides protoc plugin `protoc-gen-brokrpc`. See pyprotostuben project example for more details. +You may configure codegen output using protobuf extensions from [buf schema registry](https://buf.build/zerlok/brokrpc). + ## supported brokers & protocols * [AMQP](https://www.rabbitmq.com/tutorials/amqp-concepts)