-
Notifications
You must be signed in to change notification settings - Fork 11.1k
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
[5.7] Added test helper to assert that a Job has been queued with a Chain #23381
Conversation
I am sorry about the second commit for this PR. I removed some dead code I had from my previous implementation for the same feature. |
I made some extra digging and found out that when the expected chain assertion fails, it gives a not so helpful message when checking the compared values (at least on PhpStorm) However, working with serialization the other way around, the compared values are more meaningful for debugging. This is done by unserializing the jobs chain instead of serializing the expected chain. This could be decided going forward if the PR is a welcomed addition. Thanks. |
What if you pushed the same job once without a chain and once with chain. Wouldn't this fail since you are only checking the first pushed job for the chain? |
You are right @taylorotwell . Never crossed my mind on testing if the same job was queued but with different payload. Let me check on how to deal with this scenario. I imagine it has to be similar than using a call back to check if the correct job was queued. Is the proposed feature using correctly the job serialization/unserialization? I was also thinking on just testing for the class name to be chained instead of the object. What are your thoughts on this one? Thanks. |
- Added callback to support identifying particular jobs - Added tests
I have added support for checking for particular jobs using a callback. This will cover the scenario you spoke of:
I have also added support for checking for chained jobs using class names. Now it is possible to check using an array of job class names or an array of job objects Hope it is all good. Thanks for the feedback. Regards. |
I still see you taking the first job. What if I push the same job twice with different chains? I want to assert that the job was pushed with each chain, so I would call assertPushedWithChain twice for the same job type but different chains. I would expect them both to pass. Feel free to re-visit when that has been solved. |
The following PR adds a helper method for testing that allows to assert if a Job was pushed to the Queue with a specific Chain. The proposed method name is
assertPushedWithChain
and expects two parameters: the First Job in the Chain and an array of Jobs that will execute.I have attached an image on how this assertion can be used.
I have used the
Queueable
traitchain
method to simulate jobs serialization and have used the same method to check for the chain in the assertion method.This helper can be useful to assert that a chain has been triggered with a specific set of jobs and order.
Hope it is useful for others! Cheers!