From babb1f7939a463749d67470ce03bc11fcad9a7be Mon Sep 17 00:00:00 2001 From: Aleksandr Zhuravlev Date: Mon, 8 Apr 2024 21:26:39 +1000 Subject: [PATCH 1/2] Name of job set by displayName() must be honoured by Schedule --- .../Console/Scheduling/Schedule.php | 13 ++-- .../Fixtures/JobToTestWithSchedule.php | 14 +++++ tests/Console/Scheduling/ScheduleTest.php | 62 +++++++++++++++++++ 3 files changed, 83 insertions(+), 6 deletions(-) create mode 100644 tests/Console/Fixtures/JobToTestWithSchedule.php create mode 100644 tests/Console/Scheduling/ScheduleTest.php diff --git a/src/Illuminate/Console/Scheduling/Schedule.php b/src/Illuminate/Console/Scheduling/Schedule.php index 684aec58fc4a..7231a1b64192 100644 --- a/src/Illuminate/Console/Scheduling/Schedule.php +++ b/src/Illuminate/Console/Scheduling/Schedule.php @@ -154,15 +154,16 @@ public function command($command, array $parameters = []) */ public function job($job, $queue = null, $connection = null) { - return $this->call(function () use ($job, $queue, $connection) { - $job = is_string($job) ? Container::getInstance()->make($job) : $job; + $jobObject = is_string($job) ? Container::getInstance()->make($job) : $job; + $jobName = method_exists($jobObject, 'displayName') ? $jobObject->displayName() : $jobObject::class; - if ($job instanceof ShouldQueue) { - $this->dispatchToQueue($job, $queue ?? $job->queue, $connection ?? $job->connection); + return $this->call(function () use ($jobObject, $queue, $connection) { + if ($jobObject instanceof ShouldQueue) { + $this->dispatchToQueue($jobObject, $queue ?? $jobObject->queue, $connection ?? $jobObject->connection); } else { - $this->dispatchNow($job); + $this->dispatchNow($jobObject); } - })->name(is_string($job) ? $job : get_class($job)); + })->name($jobName); } /** diff --git a/tests/Console/Fixtures/JobToTestWithSchedule.php b/tests/Console/Fixtures/JobToTestWithSchedule.php new file mode 100644 index 000000000000..78924c79131b --- /dev/null +++ b/tests/Console/Fixtures/JobToTestWithSchedule.php @@ -0,0 +1,14 @@ +container = new Container; + Container::setInstance($this->container); + $this->eventMutex = m::mock(EventMutex::class); + $this->container->instance(EventMutex::class, $this->eventMutex); + $this->schedulingMutex = m::mock(SchedulingMutex::class); + $this->container->instance(SchedulingMutex::class, $this->schedulingMutex); + } + + #[DataProvider('jobHonoursDisplayNameIfMethodExistsProvider')] + public function testJobHonoursDisplayNameIfMethodExists(string|object $job, string $jobName): void + { + $schedule = new Schedule(); + $scheduledJob = $schedule->job($job); + self::assertSame($jobName, $scheduledJob->description); + } + + public static function jobHonoursDisplayNameIfMethodExistsProvider(): array + { + $job = new class implements ShouldQueue + { + public function displayName(): string + { + return 'testJob-123'; + } + }; + + return [ + [JobToTestWithSchedule::class, JobToTestWithSchedule::class], + [new JobToTestWithSchedule, JobToTestWithSchedule::class], + [$job, 'testJob-123'], + ]; + } +} From 23361e4f55c68c96ab914eda431b313f566ff1c4 Mon Sep 17 00:00:00 2001 From: Taylor Otwell Date: Tue, 9 Apr 2024 10:37:14 -0500 Subject: [PATCH 2/2] formatting --- .../Console/Scheduling/Schedule.php | 23 +++++++++++-------- 1 file changed, 13 insertions(+), 10 deletions(-) diff --git a/src/Illuminate/Console/Scheduling/Schedule.php b/src/Illuminate/Console/Scheduling/Schedule.php index 7231a1b64192..65292e2fc16e 100644 --- a/src/Illuminate/Console/Scheduling/Schedule.php +++ b/src/Illuminate/Console/Scheduling/Schedule.php @@ -154,16 +154,19 @@ public function command($command, array $parameters = []) */ public function job($job, $queue = null, $connection = null) { - $jobObject = is_string($job) ? Container::getInstance()->make($job) : $job; - $jobName = method_exists($jobObject, 'displayName') ? $jobObject->displayName() : $jobObject::class; - - return $this->call(function () use ($jobObject, $queue, $connection) { - if ($jobObject instanceof ShouldQueue) { - $this->dispatchToQueue($jobObject, $queue ?? $jobObject->queue, $connection ?? $jobObject->connection); - } else { - $this->dispatchNow($jobObject); - } - })->name($jobName); + $instance = is_string($job) + ? Container::getInstance()->make($job) + : $job; + + $name = method_exists($instance, 'displayName') + ? $instance->displayName() + : $instance::class; + + return $this->call(function () use ($instance, $queue, $connection) { + $instance instanceof ShouldQueue + ? $this->dispatchToQueue($instance, $queue ?? $instance->queue, $connection ?? $instance->connection) + : $this->dispatchNow($instance); + })->name($name); } /**