mirror of
https://github.com/archtechx/tenancy.git
synced 2026-02-05 06:24:04 +00:00
Clarify Fortify bootstrapper test
This commit is contained in:
parent
cabf665e5c
commit
da30e1ee5c
1 changed files with 22 additions and 17 deletions
|
|
@ -27,7 +27,8 @@ afterEach(function () {
|
||||||
test('fortify route tenancy bootstrapper updates fortify config correctly', function() {
|
test('fortify route tenancy bootstrapper updates fortify config correctly', function() {
|
||||||
config(['tenancy.bootstrappers' => [FortifyRouteBootstrapper::class]]);
|
config(['tenancy.bootstrappers' => [FortifyRouteBootstrapper::class]]);
|
||||||
|
|
||||||
// Config used when FortifyRouteBootstrapper::$passQueryParameter is true (default)
|
// Config used for generating Fortify route URLs
|
||||||
|
// when FortifyRouteBootstrapper::$passQueryParameter is true (default)
|
||||||
config([
|
config([
|
||||||
// Parameter name (RequestDataTenantResolver::queryParameterName())
|
// Parameter name (RequestDataTenantResolver::queryParameterName())
|
||||||
'tenancy.identification.resolvers.' . RequestDataTenantResolver::class . '.query_parameter' => 'team_query',
|
'tenancy.identification.resolvers.' . RequestDataTenantResolver::class . '.query_parameter' => 'team_query',
|
||||||
|
|
@ -35,7 +36,8 @@ test('fortify route tenancy bootstrapper updates fortify config correctly', func
|
||||||
'tenancy.identification.resolvers.' . RequestDataTenantResolver::class . '.tenant_model_column' => 'company',
|
'tenancy.identification.resolvers.' . RequestDataTenantResolver::class . '.tenant_model_column' => 'company',
|
||||||
]);
|
]);
|
||||||
|
|
||||||
// Config used when FortifyRouteBootstrapper::$passQueryParameter is false
|
// Config used for generating Fortify route URLs
|
||||||
|
// when FortifyRouteBootstrapper::$passQueryParameter is false
|
||||||
config([
|
config([
|
||||||
// Parameter name (PathTenantResolver::tenantParameterName())
|
// Parameter name (PathTenantResolver::tenantParameterName())
|
||||||
'tenancy.identification.resolvers.' . PathTenantResolver::class . '.tenant_parameter_name' => 'team_path',
|
'tenancy.identification.resolvers.' . PathTenantResolver::class . '.tenant_parameter_name' => 'team_path',
|
||||||
|
|
@ -51,48 +53,51 @@ test('fortify route tenancy bootstrapper updates fortify config correctly', func
|
||||||
|
|
||||||
FortifyRouteBootstrapper::$fortifyHome = $homeRouteName;
|
FortifyRouteBootstrapper::$fortifyHome = $homeRouteName;
|
||||||
FortifyRouteBootstrapper::$fortifyRedirectMap['login'] = $welcomeRouteName;
|
FortifyRouteBootstrapper::$fortifyRedirectMap['login'] = $welcomeRouteName;
|
||||||
FortifyRouteBootstrapper::$passTenantParameter = true;
|
|
||||||
|
|
||||||
expect(config('fortify.home'))->toBe($originalFortifyHome);
|
expect(config('fortify.home'))->toBe($originalFortifyHome);
|
||||||
expect(config('fortify.redirects'))->toBe($originalFortifyRedirects);
|
expect(config('fortify.redirects'))->toBe($originalFortifyRedirects);
|
||||||
|
|
||||||
$tenant = Tenant::create([
|
$tenant = Tenant::create([
|
||||||
'name' => 'Foo', // Tenant parameter value for path identification
|
'company' => 'Acme', // Tenant parameter value $passQueryParameter is true
|
||||||
'company' => 'Acme', // Tenant parameter value for query string identification
|
'name' => 'Foo', // Tenant parameter value when $passQueryParameter is false
|
||||||
]);
|
]);
|
||||||
|
|
||||||
// RequestDataTenantResolver config used
|
// The bootstrapper overrides the URLs in the Fortify config correctly (the URLs have the correct tenant parameter + parameter value)
|
||||||
|
// When $passQueryParameter is true, use the RequestDataTenantResolver config
|
||||||
// - tenant parameter is 'team_query'
|
// - tenant parameter is 'team_query'
|
||||||
// - parameter value is the tenant's company
|
// - parameter value is the tenant's company ('Acme')
|
||||||
FortifyRouteBootstrapper::$passQueryParameter = true;
|
FortifyRouteBootstrapper::$passQueryParameter = true;
|
||||||
|
|
||||||
tenancy()->initialize($tenant);
|
tenancy()->initialize($tenant);
|
||||||
|
|
||||||
expect(config('fortify.home'))->toBe('http://localhost/home?team_query=Acme');
|
expect(config('fortify.home'))->toBe('http://localhost/home?team_query=Acme');
|
||||||
expect(config('fortify.redirects'))->toEqual(['login' => 'http://localhost/welcome?team_query=Acme']);
|
expect(config('fortify.redirects'))->toEqual(['login' => 'http://localhost/welcome?team_query=Acme']);
|
||||||
|
|
||||||
|
// The bootstrapper restores the original Fortify config when ending tenancy
|
||||||
tenancy()->end();
|
tenancy()->end();
|
||||||
|
|
||||||
expect(config('fortify.home'))->toBe($originalFortifyHome);
|
expect(config('fortify.home'))->toBe($originalFortifyHome);
|
||||||
expect(config('fortify.redirects'))->toBe($originalFortifyRedirects);
|
expect(config('fortify.redirects'))->toBe($originalFortifyRedirects);
|
||||||
|
|
||||||
// PathTenantResolver config used
|
// When $passQueryParameter is false, use the PathTenantResolver config
|
||||||
// - tenant parameter is 'team_path'
|
// - tenant parameter is 'team_path'
|
||||||
// - parameter value is the tenant's name
|
// - parameter value is the tenant's name ('Foo')
|
||||||
FortifyRouteBootstrapper::$passQueryParameter = false;
|
FortifyRouteBootstrapper::$passQueryParameter = false;
|
||||||
|
|
||||||
tenancy()->initialize($tenant);
|
tenancy()->initialize($tenant);
|
||||||
|
|
||||||
expect(config('fortify.home'))->toBe('http://localhost/home?team_path=Foo');
|
expect(config('fortify.home'))->toBe('http://localhost/home?team_path=Foo');
|
||||||
expect(config('fortify.redirects'))->toEqual(['login' => 'http://localhost/welcome?team_path=Foo']);
|
expect(config('fortify.redirects'))->toEqual(['login' => 'http://localhost/welcome?team_path=Foo']);
|
||||||
|
|
||||||
tenancy()->end();
|
tenancy()->end();
|
||||||
expect(config('fortify.home'))->toBe($originalFortifyHome);
|
|
||||||
expect(config('fortify.redirects'))->toBe($originalFortifyRedirects);
|
|
||||||
|
|
||||||
|
// The bootstrapper can override the home and redirects config without the tenant parameter being passed
|
||||||
FortifyRouteBootstrapper::$passTenantParameter = false;
|
FortifyRouteBootstrapper::$passTenantParameter = false;
|
||||||
tenancy()->initialize($tenant);
|
|
||||||
expect(config('fortify.home'))->toBe('http://localhost/home');
|
|
||||||
expect(config('fortify.redirects'))->toEqual(['login' => 'http://localhost/welcome']);
|
|
||||||
|
|
||||||
tenancy()->end();
|
tenancy()->initialize($tenant);
|
||||||
expect(config('fortify.home'))->toBe($originalFortifyHome);
|
|
||||||
expect(config('fortify.redirects'))->toBe($originalFortifyRedirects);
|
expect(config('fortify.home'))->toBe('http://localhost/home')
|
||||||
|
->not()->toBe($originalFortifyHome);
|
||||||
|
expect(config('fortify.redirects'))->toEqual(['login' => 'http://localhost/welcome'])
|
||||||
|
->not()->toBe($originalFortifyRedirects);
|
||||||
});
|
});
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue