40202caf34
- BulkProjectActionRequest: add update_regions/update_days/update_limit actions, scope.filter, withValidator for ids-or-scope + delta/replace mutual exclusion - ProjectBulkActionsTest: 4 new tests (3 pass, 1 todo pending Task 2 service handler) - ProjectsActionsTest: update > 100 ids limit test to match new max:500 - phpstan-baseline: add 4 actingAs false-positive entries for new test file Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
59 lines
1.7 KiB
PHP
59 lines
1.7 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
use App\Models\Project;
|
|
use App\Models\Tenant;
|
|
use App\Models\User;
|
|
|
|
it('accepts update_regions action with add/remove bitmask', function () {
|
|
$tenant = Tenant::factory()->create();
|
|
$user = User::factory()->for($tenant)->create();
|
|
$p = Project::factory()->for($tenant)->create(['region_mask' => 1]);
|
|
|
|
$this->actingAs($user)
|
|
->postJson('/api/projects/bulk', [
|
|
'action' => 'update_regions',
|
|
'ids' => [$p->id],
|
|
'add' => 6, // биты 2+4 = Северо-Западный + Южный
|
|
'remove' => 1, // бит 1 = Центральный
|
|
])
|
|
->assertOk()
|
|
->assertJsonStructure(['updated', 'skipped', 'warnings']);
|
|
})->todo('Service handler implemented in Task 2');
|
|
|
|
it('rejects unknown action', function () {
|
|
$user = User::factory()->create();
|
|
|
|
$this->actingAs($user)
|
|
->postJson('/api/projects/bulk', [
|
|
'action' => 'nuke_everything',
|
|
'ids' => [1],
|
|
])
|
|
->assertStatus(422)
|
|
->assertJsonValidationErrors(['action']);
|
|
});
|
|
|
|
it('rejects update_limit with both delta and replace', function () {
|
|
$user = User::factory()->create();
|
|
|
|
$this->actingAs($user)
|
|
->postJson('/api/projects/bulk', [
|
|
'action' => 'update_limit',
|
|
'ids' => [1],
|
|
'delta' => 50,
|
|
'replace' => 500,
|
|
])
|
|
->assertStatus(422);
|
|
});
|
|
|
|
it('rejects empty ids without scope', function () {
|
|
$user = User::factory()->create();
|
|
|
|
$this->actingAs($user)
|
|
->postJson('/api/projects/bulk', [
|
|
'action' => 'pause',
|
|
])
|
|
->assertStatus(422);
|
|
});
|