Commit a6031dad by Vladislav
2 parents 9c40e9d5 645a5632
...@@ -46,8 +46,9 @@ class LoadUpdatedCampaigns extends Command ...@@ -46,8 +46,9 @@ class LoadUpdatedCampaigns extends Command
public function handle() public function handle()
{ {
$campaigns = Campaigns::forUpdated()->get(); $campaigns = Campaigns::forUpdated()->get();
if (!$campaigns) if (!$campaigns->count()){
return; return;
}
$token = Tokens::where('type', Tokens::MAIN)->first(); $token = Tokens::where('type', Tokens::MAIN)->first();
if (!$token){ if (!$token){
......
...@@ -11,10 +11,9 @@ class GetDictionaries extends DirectRequest ...@@ -11,10 +11,9 @@ class GetDictionaries extends DirectRequest
{ {
protected $next; protected $next;
function call($next = null, $response = null) function call($params = null)
{ {
$this->next = $next; $this->requestPrepare($params);
$this->requestPrepare($response);
$process = new ProcessCallLimitedAPI($this); $process = new ProcessCallLimitedAPI($this);
dispatch($process)->onQueue('limits'); dispatch($process)->onQueue('limits');
} }
...@@ -52,7 +51,7 @@ class GetDictionaries extends DirectRequest ...@@ -52,7 +51,7 @@ class GetDictionaries extends DirectRequest
} }
} }
private function requestPrepare($response) private function requestPrepare($params)
{ {
$this->setService('dictionaries'); $this->setService('dictionaries');
$this->setMethod('get'); $this->setMethod('get');
......
...@@ -15,7 +15,7 @@ class CreateCampaignsTable extends Migration ...@@ -15,7 +15,7 @@ class CreateCampaignsTable extends Migration
{ {
Schema::create('campaigns', function (Blueprint $table) { Schema::create('campaigns', function (Blueprint $table) {
$table->id(); $table->id();
$table->bigInteger('token'); $table->bigInteger('token')->unsigned();
$table->bigInteger('external_id')->unique(); $table->bigInteger('external_id')->unique();
$table->string('name', 255)->nullable(); $table->string('name', 255)->nullable();
$table->json('time_targeting')->nullable(); $table->json('time_targeting')->nullable();
......
<?php
namespace Tests\Unit;
use App\Jobs\ProcessCallLimitedAPI;
use App\Models\Account;
use App\Models\Campaigns;
use App\Models\Dictionary;
use App\Models\Tokens;
use App\Models\User;
use App\Service\Contract\API;
use App\Service\Requests\APIRequest;
use Illuminate\Support\Facades\Queue;
use Tests\TestCase;
use Illuminate\Foundation\Testing\RefreshDatabase;
class GetDictionariesTest extends TestCase
{
use RefreshDatabase;
private $request;
protected function setUp(): void
{
parent::setUp();
$account = Account::create(['name' => 'Acme Corporation']);
$this->user = factory(User::class)->create([
'account_id' => $account->id,
'first_name' => 'John',
'last_name' => 'Doe',
'email' => 'johndoe@example.com',
'owner' => true,
]);
$this->token = factory(Tokens::class)->create([
'created_by' => $this->user->id
]);
$this->request = APIRequest::getInstance(API::YANDEX)
->setToken($this->token)
->getRequest('dictionaries', 'get');
}
public function testCallApi()
{
Queue::fake();
Queue::assertNothingPushed();
$this->request->call();
Queue::assertPushed(ProcessCallLimitedAPI::class);
}
public function testHandleApi()
{
$this->request->handle([
'result' => [
'GeoRegions' => [
[
'GeoRegionId' => 1,
'GeoRegionName' => 'test',
'GeoRegionType' => 'World',
'ParentId' => 0
], [
'GeoRegionId' => 2,
'GeoRegionName' => 'test2',
'GeoRegionType' => 'City',
'ParentId' => 1
], [
'GeoRegionId' => 3,
'GeoRegionName' => 'test3',
'GeoRegionType' => 'Village',
'ParentId' => 2
],
]
]
]);
$this->assertEquals(3, Dictionary::all()->count());
$city = Dictionary::where('region_id', 1)->first();
$this->assertEquals($city->name, 'test');
$this->assertEquals($city->type, 'World');
$this->assertEquals($city->type, 'World');
$city = Dictionary::where('region_id', 2)->first();
$this->assertEquals($city->name, 'test2');
$this->assertEquals($city->type, 'City');
$this->assertEquals($city->parent_id, 1);
$city = Dictionary::where('region_id', 3)->first();
$this->assertEquals($city->name, 'test3');
$this->assertEquals($city->type, 'Village');
$this->assertEquals($city->parent_id, 2);
}
}
Markdown is supported
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!