Commit Graph

190 Commits

Author SHA1 Message Date
Matus Valo 58975b2a95
Ensure that restore is atomic in redis transport (#1444)
* Ensure that restore is atomic in redis transport

* Fix wrong variable

* Added integration tests

* Update unittests

* [pre-commit.ci] auto fixes from pre-commit.com hooks

for more information, see https://pre-commit.ci

* Fix integration tests

* Fix flake8

* Fix queue name in int. tests

* Cosmetic clean up of integration tests

Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
2021-12-10 23:53:40 +01:00
n0061q 081e9e6cff
SQS transport: detect FIFO queue properly by checking queue URL (#1450)
* SQS: detect FIFO queue properly

* SQS: validate predefined queues

Co-authored-by: Yaroslav Litus <Yaroslav.Litus@F-Secure.com>
2021-12-03 09:46:41 +01:00
Matus Valo 73b10a9346 Return empty list instead of InconsistencyError when exchange table is empty
Missing redis key containg set of queues bound to queue is caused
by removal all queues from the exchange. Hence, we should not raise an
exception but just return empty list of queues instead. This commit
fixes e.g. case publishing message against empty exchange:

import kombu
conn = kombu.Connection('redis://')
exchange = kombu.Exchange('name', type='direct')
exchange.declare(channel=conn.default_channel)

producer = conn.Producer()
producer.publish(
     {'hello': 'world'},
     exchange=exchange,
     routing_key='queue1'
)

But it also fixes the case when last queue is unbound from exchange and
after publishing to this exchange:

import kombu
conn = kombu.Connection('redis://')
exchange = kombu.Exchange('name', type='direct')
queue1 = kombu.Queue('queue1', exchange=exchange, routing_key='queue1')
exchange.declare(channel=conn.default_channel)
queue1 = queue1.bind(channel=conn.default_channel)
queue1.declare()

producer = conn.Producer()
producer.publish(
     {'hello': 'world'},
     exchange=exchange,
     routing_key='queue1'
)

queue1.delete()

producer.publish(
     {'hello': 'world'},
     exchange=exchange,
     routing_key='queue1'
)
2021-10-25 07:28:10 +06:00
Matus Valo 0253cfb7b2
Fix test_pidbox unittests to support non-linux platforms (#1398) 2021-10-05 22:37:59 +02:00
Matus Valo 4e8f217526
fix flake8 in kombu/asynchronous/aws/connection.py (#1397)
* fix flake8 in kombu/asynchronous/aws/connection.py

* [pre-commit.ci] auto fixes from pre-commit.com hooks

for more information, see https://pre-commit.ci

Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
2021-10-05 18:08:07 +06:00
Matus Valo 28c8984e7d Added unittests for #1394 2021-10-05 14:02:47 +02:00
pre-commit-ci[bot] ee99595232
[pre-commit.ci] pre-commit autoupdate (#1393)
* [pre-commit.ci] pre-commit autoupdate

updates:
- [github.com/asottile/pyupgrade: v2.26.0 → v2.28.0](https://github.com/asottile/pyupgrade/compare/v2.26.0...v2.28.0)

* [pre-commit.ci] auto fixes from pre-commit.com hooks

for more information, see https://pre-commit.ci

Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
2021-09-27 21:35:17 +03:00
kaiix 580b5219cc Fix: check redis response type 2021-09-16 20:50:28 +06:00
Matus Valo 07bab02bc3
Remove dependency to case (#1389)
* Remove dependency to case

* [pre-commit.ci] auto fixes from pre-commit.com hooks

for more information, see https://pre-commit.ci

* Fix flake8 errors

* Remove unused code

Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
2021-09-15 21:00:08 +06:00
Matus Valo ef6ec99154 Use ANY from unittest instead of case.mock 2021-09-12 01:03:09 +02:00
Matus Valo 7230665e5c Make BrokerState Transport specific 2021-08-30 14:02:20 +06:00
Gábor Boros 24b0820d0b fix: add missing commands to prefix
Add missing DEL, RPUSH, RPOP and SREM commands to the list of commands to prefix.

Also, this commit refactors the prefixing logic a bit to make it simpler.
2021-08-27 16:35:35 +06:00
Gábor Boros 39584a1940
Add global key prefix for keys set by Redis transporter (#1349)
* Introduce global key prefix for redis transport

Co-authored-by: Matus Valo <matusvalo@users.noreply.github.com>

* refactor: use a custom redis client

As per the suggestions, refactor the redis key prefixing to use a custom
redis client that prefixes the keys it uses.

The custom client implementation does not prefix every key by default as
the way of prefixing keys may differ for some redis commands, instead it
lists those keys that will be prefixed. In case of commands, where
multiple keys can be passed as an argument, the custom client defines
where the arg positions are starting and ending for the given command.

* test: fix unit tests by moving import statement

* fix: wrap redis.parse_response to remove key prefixes

Co-authored-by: Matus Valo <matusvalo@users.noreply.github.com>

* fix: typo

* fix: lint

Co-authored-by: Antonin Delpeuch <antonin@delpeuch.eu>
Co-authored-by: Matus Valo <matusvalo@users.noreply.github.com>
Co-authored-by: Jillian Vogel <jill@opencraft.com>
2021-08-25 14:08:17 +02:00
Brad Smith 9a91e8b780 SQS Channel.predefined_queues should be `{}` if not defined
Previously, calling `reject` when `predefined_queues` was not configured would cause `AttributeError` to be raised from `_extract_backoff_policy_configuration_and_message`. That exception could crash the whole Celery worker and force it to exit early because `AttributeError` is not excepted in the nearby call stack.
2021-08-21 16:22:41 +06:00
pre-commit-ci[bot] 1a512ffac9 [pre-commit.ci] auto fixes from pre-commit.com hooks
for more information, see https://pre-commit.ci
2021-08-05 20:05:25 +06:00
Matus Valo c0f2b847f0 Use hostname from URI when server_host is None 2021-08-05 20:05:25 +06:00
Thomas Grainger 241b5dcff8
enable pre-commit (#1355)
* enable pre-commit

* use extend-ignore for flake8

* manual flake8 fixes

* [pre-commit.ci] auto fixes from pre-commit.com hooks

for more information, see https://pre-commit.ci

* [pre-commit.ci] auto fixes from pre-commit.com hooks

for more information, see https://pre-commit.ci

* Update kombu/__init__.py

Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
2021-07-20 19:07:49 +06:00
Gábor Boros 2d036f54b6
Add support for setting redis username (#1351)
* feat: add support for setting redis username

* tests: add redis connparams credentials tests
2021-07-08 23:27:05 +02:00
Felix Yan e5dbfed8ae
Move pytest.importorskip to run earlier (#1346)
* Move pytest.importorskip to run earlier

Currently pytest fails to collect tests when `azure` is not present. Moving the pytest.importorskip clause before `from kombu.transport import azureservicebus` fixes it.

```
==================================== ERRORS ====================================
__________ ERROR collecting t/unit/transport/test_azureservicebus.py ___________
ImportError while importing test module '/build/python-kombu/src/kombu-5.1.0/t/unit/transport/test_azureservicebus.py'.
Hint: make sure your test modules/packages have valid Python names.
Traceback:
/usr/lib/python3.9/importlib/__init__.py:127: in import_module
    return _bootstrap._gcd_import(name[level:], package, level)
t/unit/transport/test_azureservicebus.py:12: in <module>
    from kombu.transport import azureservicebus
kombu/transport/azureservicebus.py:66: in <module>
    import azure.core.exceptions
E   ModuleNotFoundError: No module named 'azure'
```

* Add # noqa to make linter happy
2021-06-11 09:21:09 +02:00
Matus Valo 4cf1a21712
prepare_accept_content() now raises SerializerNotInstalled instead of KeyError (#1343)
* Fix broken nested() after #1320

* prepare_accept_content now raises SerializerNotInstalled when wrong serializer alias is passed
2021-05-23 12:09:06 +06:00
Luis Saavedra e6d76d13fc
add accept parameter to SimpleQueue class (#1140)
* add accept parameter to SimpleQueue class

* Fixed missing accept for get_nowait() and added unittests

* Remove unused **kwargs from SimpleQueue.__init__

* Use self.consumer.accept instead of new attribute in SimpleQueue

* Add tests for simple interface when accept=[]

Co-authored-by: Matus Valo <matusvalo@gmail.com>
2021-05-22 21:28:05 +02:00
Matus Valo a920bb0365
Revert "chore: Refactor code quality issues (#1320)" (#1342)
This reverts commit 3b6cd13d3b.
2021-05-19 14:05:14 +02:00
Aksh Gupta 3b6cd13d3b
chore: Refactor code quality issues (#1320)
* chore: refactor code quality issues

* remove .deepsource.toml config file
2021-04-28 18:40:37 +03:00
Matus Valo c35fd1d9b4
Make flake8 and pydocstyle happy (#1333)
* Make flake8 happy

* Make pydocstyle happy
2021-04-13 23:20:31 +02:00
Tomasz Niedziela-Brach 44dcc33a74
Azure Service Bus - versatile queue names fix (#1324)
* fixed character replace table according to the comment above - dots replaced by dashes, other punctuations replaced by underscores

* optimised with precalculated punctuation set - according to @thedrow suggestion

* queue name tests

* cleanup
2021-04-04 18:02:03 +03:00
Omer Katz 560518287a
Use a thread-safe implementation of cached_property (#1316)
* Use a thread-safe implementation of cached_property.

* Restore setter and deleter.

* Restore tests.

* Fix __get__ signature for backport.

* Cleanup.

Co-authored-by: Asif Saif Uddin <auvipy@gmail.com>
2021-04-01 13:48:00 +03:00
gal cohen b5a1edde48
SQS Broker - handle STS authentication with AWS (#1322)
* handle sqs sts

* add doc

* use string format

* improve docs

* Update kombu/transport/SQS.py

Co-authored-by: Omer Katz <omer.drow@gmail.com>

* add helper method and tests

* changer to private

Co-authored-by: galcohen <gal.cohen@autodesk.com>
Co-authored-by: Asif Saif Uddin <auvipy@gmail.com>
Co-authored-by: Omer Katz <omer.drow@gmail.com>
2021-03-29 11:35:49 +03:00
Omer Katz 1e20625d7b Drop support for the lzma backport. 2021-03-16 10:02:55 +06:00
Max Nikitenko 2a704e3585
fix: non kombu json message decoding in SQS transport (#1306)
* fix: non kombu json message decoding in SQS transport

* fix: non kombu json message decoding in SQS transport - add tests

Co-authored-by: Max Nikitenko <max.nikitenko@namecheap.com>
2021-03-07 14:35:55 +06:00
Matus Valo fccbb0d5d6 Fixed SQS unittests 2021-03-07 12:25:15 +06:00
Matus Valo d3ded0069c
Revert "Port of redis code improvements from prior revision (#1132)" (#1307)
This reverts commit 753f4ec174.
2021-03-06 20:36:59 +01:00
Matt Davis 753f4ec174
Port of redis code improvements from prior revision (#1132)
* Port of redis code improvements from prior revision

Add fakeredis requirement

* refine variable naming based on PR feedback.

* Remove python2 code style and remove unittest.Testcase from test_redis.py

* Code refactor of redis.py and test_redis.py

Co-authored-by: Matus Valo <matusvalo@gmail.com>
2021-03-03 22:40:37 +01:00
gal cohen 2e9856023c
SQS back-off policy (#1301)
* sqs retry policy

* add test

* method definition

* add validation

* rename policy

* add kombu doc

* improve docstring

* add test and doc

* test fix

* test fixes

* add doc

* Update docs/reference/kombu.transport.SQS.rst

Co-authored-by: Omer Katz <omer.drow@gmail.com>

* Update docs/reference/kombu.transport.SQS.rst

Co-authored-by: Omer Katz <omer.drow@gmail.com>

* Update kombu/transport/SQS.py

Co-authored-by: Omer Katz <omer.drow@gmail.com>

* Update kombu/transport/SQS.py

Co-authored-by: Omer Katz <omer.drow@gmail.com>

* Update kombu/transport/SQS.py

Co-authored-by: Omer Katz <omer.drow@gmail.com>

* review improvements

* improvements

* add improvements

* rename

Co-authored-by: galcohen <gal.cohen@autodesk.com>
Co-authored-by: Omer Katz <omer.drow@gmail.com>
Co-authored-by: Asif Saif Uddin <auvipy@gmail.com>
2021-03-02 12:22:47 +02:00
Choi Geonu 3e5263c481
Disable namedtuple to object feature in simplejson (#1297) 2021-03-01 14:42:42 +01:00
raittes ae9ce769c3 t/unit/asynchronous/http/test_curl: fix test_set_timeout 2021-02-12 10:35:01 +06:00
Terry Cain 90c6ac706e Fix issues with parsing URL with an extra / in it. 2021-01-06 21:57:40 +06:00
Terry Cain 3d41ab1389
Support for Azure Service Bus 7.0.0 (#1284)
* Started servicebus refactor

* Cleaned up, handle service bus SAS token parsing
2021-01-04 14:14:39 +01:00
AbdealiJK 6cb9d6639e redis: Support Sentinel with SSL
Use the SentinelManagedSSLConnection when SSL is enabled for the
transport. The redis-py project doesn't have a connection class for
SSL+Sentinel yet. So, create a class in redis.py to add that
functionality.
2020-12-03 12:50:15 +06:00
Matus Valo d4dd8d7206
Remove python2 compatibility code (#1277) 2020-11-25 12:19:10 +02:00
RezaSi b8594f8a33
Add timeout to producer publish (#1269)
* Add timeout and confirm_timeout to producer publish

* Remove confirm_timeout and add test for timeout

* Fix test

Co-authored-by: Reza Shiri <rezashiri@cafebazaar.ir>
2020-11-17 14:06:43 +06:00
Vinay Karanam c70c115c2b Revert "on worker restart - restore visible regardless to time (#905)"
This reverts commit a307726faa.
2020-10-15 15:29:47 +06:00
Chris Lambacher b79146d8a1 Test default channel gets used 2020-10-13 10:38:43 +06:00
Matus Valo faa1d86b52
Redis Transport: Small improvements of `SentinelChannel` (#1253)
* Redis Sentinel connection string now supports default sentinel port

* Raise ValueError when SentinelChannel is missing master_name transport option
2020-09-24 12:41:21 +03:00
Matus Valo 5b072fb171 Make flake8 happy 2020-08-17 10:16:05 +06:00
Matus Valo 1512c5d609 Removed case.skip 2020-08-17 10:16:05 +06:00
Matus Valo 04cf759625 Replace case.skip.todo with pytest 2020-08-17 10:16:05 +06:00
Matus Valo bd1a71215e Replace case.skip.if_win32 with pytest 2020-08-17 10:16:05 +06:00
Matus Valo f054205a5c Replace case.skip.SkipTest with pytest.skip 2020-08-17 10:16:05 +06:00
Matus Valo 410c815e44 Replaced case.skip.if_pypy and case.skip.if_python3 2020-08-17 10:16:05 +06:00
Matus Valo 20e2c45892 Use unittest.mock instead of case 2020-08-16 20:39:26 +06:00