From 6e48999e2a43c7d93a32af963e83e14683a825c0 Mon Sep 17 00:00:00 2001 From: Roberto Guido Date: Sun, 17 Nov 2024 11:11:16 +0100 Subject: [PATCH] =?UTF-8?q?limita=20notifiche=20ordini=20a=20utenti=20atti?= =?UTF-8?q?vi=20(non=20sospesi=20n=C3=A9=20cessati).=20closes=20#296?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- code/app/Models/Concerns/SuspendableTrait.php | 5 ++++ code/app/Order.php | 2 ++ code/tests/Services/UsersServiceTest.php | 29 +++++++++++++++++++ 3 files changed, 36 insertions(+) diff --git a/code/app/Models/Concerns/SuspendableTrait.php b/code/app/Models/Concerns/SuspendableTrait.php index b4ac30f2..753e3d79 100644 --- a/code/app/Models/Concerns/SuspendableTrait.php +++ b/code/app/Models/Concerns/SuspendableTrait.php @@ -46,4 +46,9 @@ public function printableStatus() return _i('Cessato'); } } + + public function scopeFullEnabled($query) + { + $query->whereNull('deleted_at')->whereNull('suspended_at'); + } } diff --git a/code/app/Order.php b/code/app/Order.php index db4ded62..d4e15aa4 100644 --- a/code/app/Order.php +++ b/code/app/Order.php @@ -452,6 +452,8 @@ public function notifiableUsers($gas) }); } + $query_users->fullEnabled(); + $deliveries = $order->deliveries; if ($deliveries->isEmpty() == false) { $query_users->where(function($query) use ($deliveries) { diff --git a/code/tests/Services/UsersServiceTest.php b/code/tests/Services/UsersServiceTest.php index 67b280b8..4ddf25ae 100644 --- a/code/tests/Services/UsersServiceTest.php +++ b/code/tests/Services/UsersServiceTest.php @@ -80,6 +80,7 @@ public function testCease() $this->actingAs($this->userWithAdminPerm); $users = app()->make('UsersService')->list(); $initial_count = $users->count(); + $initial_count_db = User::fullEnabled()->count(); $user = $users->random(); app()->make('UsersService')->update($user->id, [ @@ -88,9 +89,37 @@ public function testCease() 'suspended_at' => printableDate(date('Y-m-d')), ]); + $this->nextRound(); + $this->actingAs($this->userWithViewPerm); $users = app()->make('UsersService')->list('', true); $this->assertEquals($initial_count - 1, $users->count()); + $this->assertEquals($initial_count_db - 1, User::fullEnabled()->count()); + } + + /* + Sospensione utente + */ + public function testSuspend() + { + $this->actingAs($this->userWithAdminPerm); + $users = app()->make('UsersService')->list(); + $initial_count = $users->count(); + $initial_count_db = User::fullEnabled()->count(); + + $user = $users->random(); + app()->make('UsersService')->update($user->id, [ + 'status' => 'suspended', + 'deleted_at' => printableDate(date('Y-m-d')), + 'suspended_at' => printableDate(date('Y-m-d')), + ]); + + $this->nextRound(); + + $this->actingAs($this->userWithViewPerm); + $users = app()->make('UsersService')->list('', true); + $this->assertEquals($initial_count, $users->count()); + $this->assertEquals($initial_count_db - 1, User::fullEnabled()->count()); } /*