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

Implement a solid queue adapter #23

Merged
merged 14 commits into from
Oct 26, 2023
Merged

Implement a solid queue adapter #23

merged 14 commits into from
Oct 26, 2023

Conversation

rosa
Copy link
Member

@rosa rosa commented Sep 15, 2023

Besides the adapter itself with tests for it (massive kudos, @jorgemanrubia, for the existing testing harness for adapters you built, that was incredibly useful!), I've included a tiny change that I'll remove soon: allow adapters to declare that they don't support pausing queues, just for skipping tests for now, while I add pause support to Solid Queue. Resque has support via a plugin but I haven't built this yet. Should be easy, in any case, so much that I don't think it's worth to account for this in the UI.

Related work supporting this PR:

@rosa rosa force-pushed the solid-queue-adapter branch from 127ee2a to 5869f07 Compare September 15, 2023 20:03
@rosa rosa force-pushed the solid-queue-adapter branch from 5869f07 to d5888de Compare September 15, 2023 20:10
Probably should do this in the house-style repo, though.
It doesn't do anything, as there's nothing to change there. In the future,
if solid queue accept different DBs and we have different adapters, perhaps
we could do something here to select the database.
Copy link
Collaborator

@jorgemanrubia jorgemanrubia left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks fantastic @rosa!

@@ -186,7 +190,7 @@ def fetch_failed_resque_jobs

def fetch_queue_resque_jobs
unless jobs_relation.queue_name.present?
raise ActiveJob::Errors::QueryError, "This adapter only supports fetching failed jobs when no queue name is provided"
raise ActiveJob::Errors::QueryError, "This adapter requires a queue name unless fetching failed jobs"
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I changed this because I found it, personally, a bit confusing. I thought it meant that you must not provide a queue name when fetching failed jobs, but it's actually that if you don't provide a queue name, the only thing you can do is fetching failed jobs. I hope you don't mind!

rosa added 2 commits October 23, 2023 21:34
Before this worked without issues because resque was the only adapter set,
but after introducing Solid Queue, depending on the order of the tests, it
might happen that we run a resque test after a solid queue test, that will
finish with the solid queue adapter being used. This is a problem if we try
to fetch jobs of a certain kind via Active Job (eg. ApplicationJob.jobs.pending
and things like that), as that would use Solid Queue.
…eue_adapter`

This mimics what our job server does. It's not strictly necessary because Resque keeps
a global reference to the Redis connection being used, and activating just that is
enough even if another adapter is being used, but I find this clearer.
@rosa rosa force-pushed the solid-queue-adapter branch from 55daa1e to b428928 Compare October 25, 2023 13:09
rosa added 2 commits October 26, 2023 12:04
This messes up with failed filtering, and prevents it from working in Solid
Queue. In Solid Queue, failed is not a queue but a status of jobs, that continue
to belong to other queues. In Resque, failed is a separate queue, so when
we use the default queue when querying failed jobs, that's ignored and it
doesn't matter. However, for Solid Queue, we end up showing failed jobs
in the default queue alone, which is not what we want, since right now we
don't have a way to filter failed jobs by queue. We want to show all jobs
in all queues with failed status.

In all the other cases where we filter jobs, we want to provide a queue explicitly,
not the default one, and this is what happens everywhere. Not having a default
saves us from having to explicitly unset the queue every time we want to
fetch failed jobs.
This has changed in Ruby 3.3, from 3 arguments to 2, and it's not public API,
so it makes sense that it broke.
@rosa rosa force-pushed the solid-queue-adapter branch from b428928 to 2ec4f7a Compare October 26, 2023 10:04
@rosa rosa force-pushed the solid-queue-adapter branch from 7f4fb35 to 5eb1b0f Compare October 26, 2023 17:07
@rosa rosa merged commit fc04f21 into main Oct 26, 2023
2 checks passed
@rosa rosa deleted the solid-queue-adapter branch October 26, 2023 17:15
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants