Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

0.6.0 #1779

Draft
wants to merge 294 commits into
base: main
Choose a base branch
from
Draft

0.6.0 #1779

wants to merge 294 commits into from

Conversation

Lancetnik
Copy link
Member

@Lancetnik Lancetnik commented Sep 10, 2024

Description

Please include a summary of the change and specify which issue is being addressed. Additionally, provide relevant motivation and context.

fixes #1742, close #1308, close #1228, close #980, fixes #1742, #1895 feature, fixes #1954, close #1646, fixes #1625, close #1904, close #1507

Breaking changes:

  1. Drop Python3.8 support
  2. @broker.subscriber(..., filters=...) removed
  3. message.decoded_body removed, use await message.decode() instead
  4. publish(..., rpc=True) removed, use broker.request() instead
  5. RabbitMQ @broker.subscriber(..., reply_config=...) removed, use Response instead
  6. Context("broker") and Context("logger") moved to local context. They can not be accessed in lifespan hooks anymore
  7. FastStream(broker) is positional-only argument now (preparing to FastStream(*brokers) support)
  8. FastStream(**asyncapi_options) doesn't work anymore. Now, you have to create special AsyncAPI(broker, **asyncapi_options) to render documentation
  9. FastStream(broker) is POSITIONAL-ONLY option now. FastStream(broker=broker) doesn't work anymore
  10. broker.subscriber(..., retry=True) removed, use ack_policy instead

Lancetnik and others added 30 commits December 15, 2024 23:08
* feat: add raise BatchBufferOverflowException

* Update producer.py

---------

Co-authored-by: Pastukhov Nikita <nikita@pastukhov-dev.ru>
* feat: delayed broker setting

* feat: tests for delayed broker setting

* feat: addition test

* feat: broker -> **brokers

* feat: ruff
* feat: moved the creation of metrics to functions

* feat: ruff

* feat: pretty prometheus tests

* feat: ruff

* feat: fix test
* fix: use of overwritten message scheme and warning

* test: overwrite schema and warning

* test: deleted the loop and made a length check
Co-authored-by: Nikita Pastukhov <diementros@yandex.ru>
Co-authored-by: Pastukhov Nikita <nikita@pastukhov-dev.ru>
* fix: Disabled excessive throttling for BatchSubscriber.

* fix: Use separate thread for confluent kafka consumer.

* refactor: Added run_in_executor function.

* fix: Stop consumer client after consumer tasks are stopped.
* Feat: add tests

* Feat: add concurrent subscriber

* Fix: revert ruff

* Fix: again ruff

* Fix: fastapi init

* Fix: inheritance

---------

Co-authored-by: Daniil Dumchenko <dumchenko.de@sibvaleo.com>
Co-authored-by: Pastukhov Nikita <nikita@pastukhov-dev.ru>
* fix: Non-threadsafe operations in AsyncConfluentProducer.

* fix: Unbound error in AsyncConfluentProducer.publish method.

* fix: AsyncConfluentFastProducer type hints.
* feat: Mypy tests for broker middleware.

* refactor: Move BaseMiddleware to _internal module.

* fix: Added missed second type variable to BrokerMiddleware protocol.

* fix: Broker middleware mypy issues.

* fix: Added missed type vars to base prometheus middleware classes.

* fix: Redis prometheus middleware type hints.

* fix: Rabbit prometheus middleware type hints.

* fix: Nats prometheus middleware type-hints.

* fix: Kafka broker public middleware contract.

* fix: Confluent broker middleware public contract.

* fix: Confluent prometheus middleware type hints.

* fix: Kafka pometheus middleware type hints.

* fix: Linter issues.
* chore: merge main

* tests: new Listener tests

* chore: refactor CincurrentBetwwenPartitionsSubscriber

* chore: refactor CincurrentBetwwenPartitionsSubscriber

* fix: correct ConcurrentManualAckSubscriber behavior

* tests: increase timeout in kafka concurrent tests

* refactor: change ListenerProxy logic

* tests: increase workers number for kafka
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Core Issues related to core FastStream functionality and affects to all brokers enhancement New feature or request
Projects
Status: In Progress