mirror of
https://github.com/archtechx/tenancy.git
synced 2026-02-05 19:54:04 +00:00
Change terminology to pending
This commit is contained in:
parent
c8eadeb363
commit
500b2538fc
20 changed files with 387 additions and 385 deletions
|
|
@ -7,10 +7,10 @@ namespace Stancl\Tenancy\Tests\Etc;
|
|||
use Stancl\Tenancy\Contracts\TenantWithDatabase;
|
||||
use Stancl\Tenancy\Database\Concerns\HasDatabase;
|
||||
use Stancl\Tenancy\Database\Concerns\HasDomains;
|
||||
use Stancl\Tenancy\Database\Concerns\WithReadied;
|
||||
use Stancl\Tenancy\Database\Concerns\HasPending;
|
||||
use Stancl\Tenancy\Database\Models;
|
||||
|
||||
class Tenant extends Models\Tenant implements TenantWithDatabase
|
||||
{
|
||||
use HasDatabase, HasDomains, WithReadied;
|
||||
use HasDatabase, HasDomains, HasPending;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1 +1 @@
|
|||
{"userName":"Bar","shouldFail":false,"tenant_id":"The current tenant id is: a7f73c10-9879-40ae-b7b0-1ded7c1f7b1b"}
|
||||
{"tenant_id":"The current tenant id is: acme"}
|
||||
172
tests/PendingTenantsTest.php
Normal file
172
tests/PendingTenantsTest.php
Normal file
|
|
@ -0,0 +1,172 @@
|
|||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace Stancl\Tenancy\Tests;
|
||||
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Illuminate\Support\Facades\Event;
|
||||
use Stancl\Tenancy\Commands\ClearPendingTenants;
|
||||
use Stancl\Tenancy\Commands\CreatePendingTenants;
|
||||
use Stancl\Tenancy\Events\PullingPendingTenant;
|
||||
use Stancl\Tenancy\Events\PendingTenantPulled;
|
||||
use Stancl\Tenancy\Events\CreatingPendingTenant;
|
||||
use Stancl\Tenancy\Events\PendingTenantCreated;
|
||||
use Stancl\Tenancy\Tests\Etc\Tenant;
|
||||
|
||||
class PendingTenantsTest extends TestCase
|
||||
{
|
||||
public function setUp(): void
|
||||
{
|
||||
parent::setUp();
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function a_tenant_is_correctly_identified_as_pending()
|
||||
{
|
||||
Tenant::createPending();
|
||||
|
||||
$this->assertCount(1, Tenant::onlyPending()->get());
|
||||
|
||||
Tenant::onlyPending()->first()->update([
|
||||
'pending_since' => null
|
||||
]);
|
||||
|
||||
$this->assertCount(0, Tenant::onlyPending()->get());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function pending_trait_imports_query_scopes()
|
||||
{
|
||||
Tenant::createPending();
|
||||
Tenant::create();
|
||||
Tenant::create();
|
||||
|
||||
$this->assertCount(1, Tenant::onlyPending()->get());
|
||||
|
||||
$this->assertCount(3, Tenant::withPending(true)->get());
|
||||
|
||||
$this->assertCount(2, Tenant::withPending(false)->get());
|
||||
|
||||
$this->assertCount(2, Tenant::withoutPending()->get());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function pending_tenants_are_created_and_deleted_from_the_commands()
|
||||
{
|
||||
config(['tenancy.pending.count' => 4]);
|
||||
|
||||
Artisan::call(CreatePendingTenants::class);
|
||||
|
||||
$this->assertCount(4, Tenant::onlyPending()->get());
|
||||
|
||||
Artisan::call(ClearPendingTenants::class);
|
||||
|
||||
$this->assertCount(0, Tenant::onlyPending()->get());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function clear_pending_tenants_command_only_delete_pending_tenants_older_than()
|
||||
{
|
||||
config(['tenancy.pending.count' => 2]);
|
||||
|
||||
Artisan::call(CreatePendingTenants::class);
|
||||
|
||||
config(['tenancy.pending.older_than_days' => 2]);
|
||||
|
||||
tenancy()->model()->query()->onlyPending()->first()->update([
|
||||
'pending_since' => now()->subDays(5)->timestamp
|
||||
]);
|
||||
|
||||
Artisan::call(ClearPendingTenants::class);
|
||||
|
||||
$this->assertCount(1, Tenant::onlyPending()->get());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function clear_pending_tenants_command_all_option_overrides_config()
|
||||
{
|
||||
Tenant::createPending();
|
||||
Tenant::createPending();
|
||||
|
||||
tenancy()->model()->query()->onlyPending()->first()->update([
|
||||
'pending_since' => now()->subDays(10)
|
||||
]);
|
||||
|
||||
config(['tenancy.pending.older_than_days' => 4]);
|
||||
|
||||
Artisan::call(ClearPendingTenants::class, [
|
||||
'--all' => true
|
||||
]);
|
||||
|
||||
$this->assertCount(0, Tenant::onlyPending()->get());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function tenancy_can_check_for_rpending_tenants()
|
||||
{
|
||||
Tenant::query()->delete();
|
||||
|
||||
$this->assertFalse(Tenant::onlyPending()->exists());
|
||||
|
||||
Tenant::createPending();
|
||||
|
||||
$this->assertTrue(Tenant::onlyPending()->exists());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function tenancy_can_pull_a_pending_tenant()
|
||||
{
|
||||
$this->assertNull(Tenant::pullPendingTenant());
|
||||
|
||||
Tenant::createPending();
|
||||
|
||||
$this->assertInstanceOf(Tenant::class, Tenant::pullPendingTenant(true));
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function tenancy_can_create_if_none_are_pending()
|
||||
{
|
||||
$this->assertCount(0, Tenant::all());
|
||||
|
||||
Tenant::pullPendingTenant(true);
|
||||
|
||||
$this->assertCount(1, Tenant::all());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function pending_tenants_global_scope_config_can_include_or_exclude()
|
||||
{
|
||||
Tenant::createPending();
|
||||
|
||||
config(['tenancy.pending.include_in_queries' => false]);
|
||||
|
||||
$this->assertCount(0, Tenant::all());
|
||||
|
||||
config(['tenancy.pending.include_in_queries' => true]);
|
||||
|
||||
$this->assertCount(1, Tenant::all());
|
||||
Tenant::all();
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function pending_events_are_triggerred()
|
||||
{
|
||||
Event::fake([
|
||||
CreatingPendingTenant::class,
|
||||
PendingTenantCreated::class,
|
||||
PullingPendingTenant::class,
|
||||
PendingTenantPulled::class,
|
||||
]);
|
||||
|
||||
Tenant::createPending();
|
||||
|
||||
Event::assertDispatched(CreatingPendingTenant::class);
|
||||
Event::assertDispatched(PendingTenantCreated::class);
|
||||
|
||||
Tenant::pullPendingTenant();
|
||||
|
||||
Event::assertDispatched(PullingPendingTenant::class);
|
||||
Event::assertDispatched(PendingTenantPulled::class);
|
||||
}
|
||||
}
|
||||
|
|
@ -1,172 +0,0 @@
|
|||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace Stancl\Tenancy\Tests;
|
||||
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
use Illuminate\Support\Facades\Event;
|
||||
use Stancl\Tenancy\Commands\ClearReadiedTenants;
|
||||
use Stancl\Tenancy\Commands\CreateReadiedTenants;
|
||||
use Stancl\Tenancy\Events\PullingReadiedTenant;
|
||||
use Stancl\Tenancy\Events\ReadiedTenantPulled;
|
||||
use Stancl\Tenancy\Events\ReadyingTenant;
|
||||
use Stancl\Tenancy\Events\TenantReadied;
|
||||
use Stancl\Tenancy\Tests\Etc\Tenant;
|
||||
|
||||
class ReadiedTenantsTest extends TestCase
|
||||
{
|
||||
public function setUp(): void
|
||||
{
|
||||
parent::setUp();
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function a_tenant_is_correctly_identified_as_readied()
|
||||
{
|
||||
Tenant::createReadied();
|
||||
|
||||
$this->assertCount(1, Tenant::onlyReadied()->get());
|
||||
|
||||
Tenant::onlyReadied()->first()->update([
|
||||
'readied' => null
|
||||
]);
|
||||
|
||||
$this->assertCount(0, Tenant::onlyReadied()->get());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function readied_trait_imports_query_scopes()
|
||||
{
|
||||
Tenant::createReadied();
|
||||
Tenant::create();
|
||||
Tenant::create();
|
||||
|
||||
$this->assertCount(1, Tenant::onlyReadied()->get());
|
||||
|
||||
$this->assertCount(3, Tenant::withReadied(true)->get());
|
||||
|
||||
$this->assertCount(2, Tenant::withReadied(false)->get());
|
||||
|
||||
$this->assertCount(2, Tenant::withoutReadied()->get());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function readied_tenants_are_created_and_deleted_from_the_commands()
|
||||
{
|
||||
config(['tenancy.readied.count' => 4]);
|
||||
|
||||
Artisan::call(CreateReadiedTenants::class);
|
||||
|
||||
$this->assertCount(4, Tenant::onlyReadied()->get());
|
||||
|
||||
Artisan::call(ClearReadiedTenants::class);
|
||||
|
||||
$this->assertCount(0, Tenant::onlyReadied()->get());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function clear_readied_tenants_command_only_delete_readied_tenants_older_than()
|
||||
{
|
||||
config(['tenancy.readied.count' => 2]);
|
||||
|
||||
Artisan::call(CreateReadiedTenants::class);
|
||||
|
||||
config(['tenancy.readied.older_than_days' => 2]);
|
||||
|
||||
tenancy()->model()->query()->onlyReadied()->first()->update([
|
||||
'readied' => now()->subDays(5)->timestamp
|
||||
]);
|
||||
|
||||
Artisan::call(ClearReadiedTenants::class);
|
||||
|
||||
$this->assertCount(1, Tenant::onlyReadied()->get());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function clear_readied_tenants_command_all_option_overrides_config()
|
||||
{
|
||||
Tenant::createReadied();
|
||||
Tenant::createReadied();
|
||||
|
||||
tenancy()->model()->query()->onlyReadied()->first()->update([
|
||||
'readied' => now()->subDays(10)
|
||||
]);
|
||||
|
||||
config(['tenancy.readied.older_than_days' => 4]);
|
||||
|
||||
Artisan::call(ClearReadiedTenants::class, [
|
||||
'--all' => true
|
||||
]);
|
||||
|
||||
$this->assertCount(0, Tenant::onlyReadied()->get());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function tenancy_can_check_for_readied_tenants()
|
||||
{
|
||||
Tenant::query()->delete();
|
||||
|
||||
$this->assertFalse(Tenant::onlyReadied()->exists());
|
||||
|
||||
Tenant::createReadied();
|
||||
|
||||
$this->assertTrue(Tenant::onlyReadied()->exists());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function tenancy_can_pull_a_readied_tenant()
|
||||
{
|
||||
$this->assertNull(Tenant::pullReadiedTenant());
|
||||
|
||||
Tenant::createReadied();
|
||||
|
||||
$this->assertInstanceOf(Tenant::class, Tenant::pullReadiedTenant(true));
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function tenancy_can_create_if_none_are_readied()
|
||||
{
|
||||
$this->assertCount(0, Tenant::all());
|
||||
|
||||
Tenant::pullReadiedTenant(true);
|
||||
|
||||
$this->assertCount(1, Tenant::all());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function readied_tenants_global_scope_config_can_include_or_exclude()
|
||||
{
|
||||
Tenant::createReadied();
|
||||
|
||||
config(['tenancy.readied.include_in_queries' => false]);
|
||||
|
||||
$this->assertCount(0, Tenant::all());
|
||||
|
||||
config(['tenancy.readied.include_in_queries' => true]);
|
||||
|
||||
$this->assertCount(1, Tenant::all());
|
||||
Tenant::all();
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function readied_events_are_triggerred()
|
||||
{
|
||||
Event::fake([
|
||||
ReadyingTenant::class,
|
||||
TenantReadied::class,
|
||||
PullingReadiedTenant::class,
|
||||
ReadiedTenantPulled::class,
|
||||
]);
|
||||
|
||||
Tenant::createReadied();
|
||||
|
||||
Event::assertDispatched(ReadyingTenant::class);
|
||||
Event::assertDispatched(TenantReadied::class);
|
||||
|
||||
Tenant::pullReadiedTenant();
|
||||
|
||||
Event::assertDispatched(PullingReadiedTenant::class);
|
||||
Event::assertDispatched(ReadiedTenantPulled::class);
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue