call([new RunAutopodborSearchJob($runId), 'handle']); } it('успешный подбор: сохраняет конкурентов, списывает, status=done', function () { $tenant = Tenant::factory()->create(['balance_rub' => '100000.00']); DB::statement("SET app.current_tenant_id = ".$tenant->id); SystemSetting::updateOrCreate(['key' => 'autopodbor_price_search_rub'], ['value' => '500', 'type' => 'decimal']); SystemSetting::updateOrCreate(['key' => 'autopodbor_max_competitors'], ['value' => '15', 'type' => 'int']); $run = AutopodborRun::create([ 'tenant_id' => $tenant->id, 'kind' => 'search', 'status' => 'queued', 'region_code' => 16, 'params' => ['examples' => ['okna.ru'], 'about_self' => [], 'include_federal' => true], ]); runSearchJob($run->id); expect($run->fresh()->status)->toBe('done') ->and($run->fresh()->price_rub_charged)->toBe('500.00') ->and(AutopodborCompetitor::where('search_run_id', $run->id)->count())->toBeGreaterThan(0) ->and((string) $tenant->fresh()->balance_rub)->toBe('99500.00'); }); it('пустой результат: status=empty, без списания', function () { app()->bind(CompetitorAgent::class, \Tests\Doubles\EmptyCompetitorAgent::class); $tenant = Tenant::factory()->create(['balance_rub' => '100000.00']); DB::statement("SET app.current_tenant_id = ".$tenant->id); SystemSetting::updateOrCreate(['key' => 'autopodbor_price_search_rub'], ['value' => '500', 'type' => 'decimal']); $run = AutopodborRun::create([ 'tenant_id' => $tenant->id, 'kind' => 'search', 'status' => 'queued', 'region_code' => 16, 'params' => ['examples' => [], 'about_self' => [], 'include_federal' => false], ]); runSearchJob($run->id); expect($run->fresh()->status)->toBe('empty') ->and($run->fresh()->price_rub_charged)->toBeNull() ->and((string) $tenant->fresh()->balance_rub)->toBe('100000.00'); });