Commit Graph

1738 Commits (eadabc036b9778dbaecb534fd41c5bbd7f290441)
 

Author SHA1 Message Date
Tianci Hu Marrero eadabc036b
Added job details to "rq info" command ()
* Update index.md

fixed minor duplicate article ("the its config var")

* added job details to rq info cli
Joris a9fae76e88
Fix error in example in the documentation ()
The solution that @rpkak proposes works. Closes 
Rony Lutsky 04722339d7
Consolidate job callbacks execution ()
* consolidate job failure callback execution

* fix

* success callback as well

* merge fix

* create Callback class and change how callbacks serde

* deprecation

* add tests

* string format

* pr fix

* revert serialization changes

* fix timeout typing

* add documentation

* add test

* fix a bug

* fix tests

* move job heartbeat call to worker and make sure there is always a callback timeout

* fix test

* fix test
Jochen Kupperschmidt 60164c5107
Fix typo in deprecation warning ()
Help when grepping through warnings.
Simó Albert i Beltran 64e202ea19
Check dependencies when enqueue via Queue.enqueue_job() ()
* test: check dependencies when enqueue via Queue.enqueue_job()

Signed-off-by: Simó Albert i Beltran <sim6@bona.gent>

* fix: check dependencies when enqueue via Queue.enqueue_job()

Signed-off-by: Simó Albert i Beltran <sim6@bona.gent>
Co-authored-by: Selwin Ong <selwin.ong@gmail.com>

---------

Signed-off-by: Simó Albert i Beltran <sim6@bona.gent>
Co-authored-by: Selwin Ong <selwin.ong@gmail.com>
Jesse P. Johnson 5a1c0a09f4
fix: remove unsafe formating and standardize qoutes ()
* test: resolve merge issues

* test: resolve merge issues
lowercase00 ec0b08ebf0
bugfix: type annotations as str to allow Windows usage ()
Jesse P. Johnson a21768ad90
refactor: remove python2 cruft ()
lowercase00 c12561db0a
docs: add deprecation warnings to connection functions ()
lowercase00 d5bde117c2
Remove `use_connection` ()
* feat: remove use_connection

* fix: clear old test
Joachim Burket 7f9f0f72ba
Update arguments passed to the Sentinel Object when created from the settings ()
* Updated arguments passed to the Sentinel Object when created from the settings

- added `USERNAME` key
- added `CONNECTION_KWARGS` key to allow passing additionals arguments to the Redis connections
- updated the documentation

* added missing comma

* tests(helpers): Added tests for Sentinel

---------

Co-authored-by: Joachim Burket <joachim.burket@hopitalvs.ch>
lowercase00 82a59e9791
feat: move `reorder_queues` to `dequeue_job` ()
* feat: move `reorder_queues` to `dequeue_job`

* Update worker.py
Tianci Hu Marrero 5de8cda1f9
Update index.md ()
fixed minor duplicate article ("the its config var")
lowercase00 654649743c
New dequeue strategy ()
* New dequeue strategy

This implements a new parameter `dequeue_strategy` that
should replace the `RoundRobinWorker` and `RandomWorker`.
Changes includes: feature, docs, tests, deprecation warning.

* Fix dequeue strategy name

* Black & Fix warning

* feat: tests, warnings, refactor naming

* feat: improve worker check

* fix: revert to str subclass

* fix: dequeue strategy into bootstrap

* org: move DequeueStrategy to worker

* refactor: round robin naming

* fix: naming

* fix: type annotation

* fix: typo

* refactor: remove kwarg from worker's init

* fix: typo

* move `dequeue_strategy` from `bootstrap()` into `work()`
Rony Lutsky 0ba3971d55
Add failure callback call to started job registry cleanup ()
* Add started job registry cleanup job failure callback call

* WIP - need to fix test

* fix test

* rename, tests and docs

* better log message

* use class name

* Update registry.py
lowercase00 95558fcc1d
docs: scheduler safe import ()
* docs: scheduler safe import

* docs: rollback main block
Marcus Ong e92682c83a
Fix TimerDeathPenalty not properly handling negative/infinite timeout ()
* Fix TimerDeathPenalty not properly handling negative/infinite timeout

* revert back to using exc_info

---------

Co-authored-by: Marcus <marcus@us2.ai>
Simó Albert i Beltran ed59b9248a
fix: Dependency list in depends_on ()
* test: Dependency list in depends_on

Signed-off-by: Simó Albert i Beltran <sim6@bona.gent>

* fix: Dependency list in depends_on

Signed-off-by: Simó Albert i Beltran <sim6@bona.gent>

---------

Signed-off-by: Simó Albert i Beltran <sim6@bona.gent>
Tianci Hu Marrero 1fa6ec1055
(Docs) Updated patterns - heroku ()
* Update index.md

* Update index.md

* Update index.md

import herokuWorker instead.
amks1 08d8f7c30c
removed import error warning and changed function doc ()
lowercase00 7bbef7e05a
docs: add warning of `decode_responses` ()
Selwin Ong 2c6c7ae586
Don't fail CI if codecov fails ()
Rony Lutsky aedc9b9e06
Worker - max_idle_time feature ()
* fix accessing None when dequeued result is None (burst=True, or timeout=None)

* add a test

* implement + tests

* fix if

* adjust test

* merge

* test

* test

* merge master

* take max_idle_time into account for dequeue_timeout

* refactor a bit

* potential bug fix

* tests

* math.ceil

* buffer tests
Rony Lutsky 41406db3eb
Configurable maintenance task interval ()
* Configurable maintenance task interval

* pass to worker

* rename parameter

* rename

* rename

* test
Selwin Ong 42ac7d4150 Bump version to 1.13.0
Rony Lutsky bba781d288
Enhance worker termination logic ()
* enhance worker termination logic and allow passing custom exc_info in failure callback

* handle ret_val None

* fix unbound variable

* typing

* docs

* Update exceptions.md

* rename

* typing

* rename

* Update exceptions.md

* revert test change
lowercase00 a985445486
refactor: new teardown worker method ()
* refactor: new teardown worker method

* refactor: consistent worker_registration usage

* refactor: consistent utils import
dependabot[bot] 5192b1d2e4
Bump supercharge/redis-github-action from 1.4.0 to 1.5.0 ()
Bumps [supercharge/redis-github-action](https://github.com/supercharge/redis-github-action) from 1.4.0 to 1.5.0.
- [Release notes](https://github.com/supercharge/redis-github-action/releases)
- [Changelog](https://github.com/supercharge/redis-github-action/blob/main/CHANGELOG.md)
- [Commits](https://github.com/supercharge/redis-github-action/compare/1.4.0...1.5.0)

---
updated-dependencies:
- dependency-name: supercharge/redis-github-action
  dependency-type: direct:production
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
lowercase00 fc6d69529f
feat: splits the work loop into a bootstrap method ()
Simó Albert i Beltran 5798cddd04
fix: queue.result_ttl=-1 ()
* test: queue.result_ttl=-1

Signed-off-by: Simó Albert i Beltran <sim6@bona.gent>

* test: queue.result_ttl=0

Signed-off-by: Simó Albert i Beltran <sim6@bona.gent>

* fix: queue.result_ttl=-1

Signed-off-by: Simó Albert i Beltran <sim6@bona.gent>

---------

Signed-off-by: Simó Albert i Beltran <sim6@bona.gent>
Selwin Ong 46b5cf64c3
Added black config ()
lowercase00 9311eeba17
Worker docstrings ()
* docs: worker docstrings

* docs: more type annotaions
lowercase00 eef6dbbb3c
docs: fix typos ()
Daniel M 3d840a79ad
Add to worker redis record scheduler info ()
* add scheduler_pid property to queue

* Update return type

* Reformat code
lowercase00 a02ad29cef
Docs: Updated testing instructions ()
* docs: update rq repo address

* docs: detailed test instructions
Rony Lutsky b69ee10cbb
Fix - Use worker TTL for timeout ()
* Use worker TTL for timeout

* add test

* renames

* test

* use dequeue_timeout
Selwin Ong acdeff385d
Use job.return_value() instead of job.result when processing callbacks ()
* Use job.return_value() instead of job.result when processing callbacks

* job.return_value() should also support Redis server < 5.
Rony Lutsky 54db2fa8d1
Fix - TypeError - accessing None when dequeued result is None (when timeout=None, e.g. in burst mode) ()
* fix accessing None when dequeued result is None (burst=True, or timeout=None)

* add a test

* pr fix

* fix tests
Selwin Ong 83fa0adf15
Sync jobs should save job exceptions and results ()
* Sync jobs should save job exceptions and results

* Make job.handle_success() and job.handle_failure() private methods
lowercase00 27cbf48ad4
Debug mode log fixes ()
Current worker on debug mode doesn't raises errors,
but does have some formatting issues.
Paul Spooren fdb14df181
Black style ()
* treewide: apply black style

This PR applied the black code style, adds it to the CI and README. The
changes look big, however no functional changed are applied at all.

The line length is set to 120, which is different from black
recommendation of 88. I would suggest to stick to the 88 recommendation
and adapt the flake8 check.

Add the `-S` parameter to `black` to keep single quotes.

Signed-off-by: Paul Spooren <mail@aparcar.org>

* README: add black badge

Help people to find the used code style.

Signed-off-by: Paul Spooren <mail@aparcar.org>

* CI: check codestyle via black

Automatically run the CI and check that the code style is still black.

Signed-off-by: Paul Spooren <mail@aparcar.org>

---------

Signed-off-by: Paul Spooren <mail@aparcar.org>
lowercase00 cd62b4cb50
Fix bug when running worker on debug mode ()
When running on debug mode, some debug logs were
using colorizers on lists, which would raise an unhandled exception
on the worker. The same happened for a debug log that was
using colors on a response from Redis (bytes).
lowercase00 c2e6d95338
Enhanced Redis Connection Reliability ()
* Enhanced Redis Connection Reliability

The Redis connection may fail for several reasons. As the connection can be
(1) explicitly passed to the worker or (2) implicity set, this will improve the
Connection configuration by setting a timeout to the socket, and adding
an ExponentialBackoff Retry logic.

* Simpler Connection logic

* Add simple retry logic to Redis Connection Error

* Make retry exponential, add keepalive & socket_connect_timeout

* Handles configuration on Redis' connection pool

* Simplifies timeout exception logic

* Fix burst bug, add test

* Add docs related to `socket_timeout`, improve compatibility with older RedisPy versions

* Fixes

* New timeout private method

* Fix timeout
lowercase00 436250d36b
Queue Docstrings ()
* Docstrings

* Add commands docstrings

* More docstrings

* Fix Result.Type error

* Remove unfinished docstrings
lowercase00 271e7a8727
Add 3.11 Support ()
lowercase00 2c4c948207
Fix worker example ()
* Fix worker example

* Clean worker example

* Improve docs
lowercase00 bd07310253
Job methods docstrings ()
* Improve docstrings on `connections`

* Enhanced Job methods docstrings & Serialization Protocol

This adds docstrings to all Job methods in a standard format.
It also implements a `serializer` protocol.

* Excludes `Protocol` (keeping compatibility with < 3.8)

* Add docstrings & type annotation to the `job` decorator

* Docstrings for the `defaults` vars

* Add deprecation warning to Connection context manager

* Fix Types
lowercase00 398d5784db
Removes Python 3.5 from the classifiers ()
Oleg 4bd0f12ec9
Restart scheduler process if the process is not alive ()
lowercase00 55f833ab6f
Moves the `compact` helper to `utils` ()
* Moves the `compact` helper to `utils`

There is a helper funcion that excludes `None` values
from a list. This was being declared both in the Queue
and in the worker. This centralizes this helper in the `utils`
Importing

* Fix Type Annotation