mirror of
https://github.com/archtechx/tenancy.git
synced 2026-02-05 02:54:03 +00:00
Test encrypted cookie identification
This commit is contained in:
parent
5f7fd38e5a
commit
d218431b95
1 changed files with 24 additions and 2 deletions
|
|
@ -97,10 +97,32 @@ test('cookie identification works', function (string|null $tenantModelColumn) {
|
||||||
expect(fn () => $this->withoutExceptionHandling()->withUnencryptedCookie('tenant', $payload)->get('test'))->toThrow(TenantCouldNotBeIdentifiedByRequestDataException::class);
|
expect(fn () => $this->withoutExceptionHandling()->withUnencryptedCookie('tenant', $payload)->get('test'))->toThrow(TenantCouldNotBeIdentifiedByRequestDataException::class);
|
||||||
})->with([null, 'slug']);
|
})->with([null, 'slug']);
|
||||||
|
|
||||||
// todo@tests encrypted cookie
|
test('encrypted cookie identification works', function (string|null $tenantModelColumn) {
|
||||||
|
if ($tenantModelColumn) {
|
||||||
|
Schema::table('tenants', function (Blueprint $table) use ($tenantModelColumn) {
|
||||||
|
$table->string($tenantModelColumn)->unique();
|
||||||
|
});
|
||||||
|
Tenant::$extraCustomColumns = [$tenantModelColumn];
|
||||||
|
}
|
||||||
|
|
||||||
|
config(['tenancy.identification.resolvers.' . RequestDataTenantResolver::class . '.tenant_model_column' => $tenantModelColumn]);
|
||||||
|
|
||||||
|
$tenant = Tenant::create($tenantModelColumn ? [$tenantModelColumn => 'acme'] : []);
|
||||||
|
$payload = $tenantModelColumn ? 'acme' : $tenant->id;
|
||||||
|
|
||||||
|
// Default encrypted cookie name
|
||||||
|
$this->withoutExceptionHandling()->withCookie('tenant', $payload)->get('test')->assertSee($tenant->id);
|
||||||
|
|
||||||
|
// Custom encrypted cookie name
|
||||||
|
config(['tenancy.identification.resolvers.' . RequestDataTenantResolver::class . '.cookie' => 'custom_tenant_id']);
|
||||||
|
$this->withoutExceptionHandling()->withCookie('custom_tenant_id', $payload)->get('test')->assertSee($tenant->id);
|
||||||
|
|
||||||
|
// Setting the cookie to null disables cookie identification
|
||||||
|
config(['tenancy.identification.resolvers.' . RequestDataTenantResolver::class . '.cookie' => null]);
|
||||||
|
expect(fn () => $this->withoutExceptionHandling()->withCookie('tenant', $payload)->get('test'))->toThrow(TenantCouldNotBeIdentifiedByRequestDataException::class);
|
||||||
|
})->with([null, 'slug']);
|
||||||
|
|
||||||
test('an exception is thrown when no tenant data is provided in the request', function () {
|
test('an exception is thrown when no tenant data is provided in the request', function () {
|
||||||
pest()->expectException(TenantCouldNotBeIdentifiedByRequestDataException::class);
|
pest()->expectException(TenantCouldNotBeIdentifiedByRequestDataException::class);
|
||||||
$this->withoutExceptionHandling()->get('test');
|
$this->withoutExceptionHandling()->get('test');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue