mirror of
https://github.com/archtechx/tenancy.git
synced 2025-12-12 12:44:02 +00:00
* Run cache tests on all supported drivers * update ci healthcheck for memcached * remove memcached healthcheck * fix typos in test comments, expand internal.md [ci skip] * add empty line [ci skip] * switch to using $store->setPrefix() * add dynamodb * refactor try-finally to try-catch * remove unnecessary clearResolvedInstances() call * add dual Cache:: and cache() assertions * add apc * Flush APCu cache in test setup * Revert "add dual Cache:: and cache() assertions" This reverts commit a0bab162fbe2dd0d25e7056ceca4fb7ce54efc77. * phpstan fix * Add logic for scoping 'file' disks to FilesystemTenancyBootstrapper * minor changes, add todos * refactor how the session.connection is used in the DB session bootstrapper * add session forgery prevention logic to the db session bootstrapper * only use the fs bootstrapper for file disk in 'cache data is separated' dataset * minor session scoping test changes * Add session scoping logic to FilesystemTenancyBootstrapper, correctly update disk roots even with storage_path_tenancy disabled * Fix code style (php-cs-fixer) * update docblock * make not-null check more explicit * separate bootstrapper tests, fix swapped test names for two tests * refactor cache bootstrapper tests * resolve global cache todo * expand tests: session separation tests, more filesystem separation assertions; change prefix_base-type config keys to templates/formats * add apc session scoping test, various session separation bugfixes * phpstan + minor logic fixes * prefix_format -> prefix * fix database session separation test * revert composer.json changes, update laravel dependencies to expected next release * only run session scoping logic in cache bootstrapper for redis, memcached, dynamodb, apc; update gitattributes * tenancy.central_domains -> tenancy.identification.central_domains * db session separation test: add datasets --------- Co-authored-by: PHP CS Fixer <phpcsfixer@example.com>
105 lines
4.2 KiB
PHP
105 lines
4.2 KiB
PHP
<?php
|
|
|
|
use Illuminate\Broadcasting\BroadcastManager;
|
|
use Illuminate\Support\Facades\Event;
|
|
use Stancl\Tenancy\Bootstrappers\BroadcastingConfigBootstrapper;
|
|
use Stancl\Tenancy\Events\TenancyEnded;
|
|
use Stancl\Tenancy\Events\TenancyInitialized;
|
|
use Stancl\Tenancy\Listeners\BootstrapTenancy;
|
|
use Stancl\Tenancy\Listeners\RevertToCentralContext;
|
|
use Stancl\Tenancy\Overrides\TenancyBroadcastManager;
|
|
use Stancl\Tenancy\Tests\Etc\TestingBroadcaster;
|
|
|
|
beforeEach(function () {
|
|
Event::listen(TenancyInitialized::class, BootstrapTenancy::class);
|
|
Event::listen(TenancyEnded::class, RevertToCentralContext::class);
|
|
|
|
BroadcastingConfigBootstrapper::$credentialsMap = [];
|
|
TenancyBroadcastManager::$tenantBroadcasters = ['pusher', 'ably'];
|
|
});
|
|
|
|
afterEach(function () {
|
|
BroadcastingConfigBootstrapper::$credentialsMap = [];
|
|
TenancyBroadcastManager::$tenantBroadcasters = ['pusher', 'ably'];
|
|
});
|
|
|
|
test('BroadcastingConfigBootstrapper binds TenancyBroadcastManager to BroadcastManager and reverts the binding when tenancy is ended', function() {
|
|
config(['tenancy.bootstrappers' => [BroadcastingConfigBootstrapper::class]]);
|
|
|
|
expect(app(BroadcastManager::class))->toBeInstanceOf(BroadcastManager::class);
|
|
|
|
tenancy()->initialize(Tenant::create());
|
|
|
|
expect(app(BroadcastManager::class))->toBeInstanceOf(TenancyBroadcastManager::class);
|
|
|
|
tenancy()->end();
|
|
|
|
expect(app(BroadcastManager::class))->toBeInstanceOf(BroadcastManager::class);
|
|
});
|
|
|
|
test('BroadcastingConfigBootstrapper maps tenant broadcaster credentials to config as specified in the $credentialsMap property and reverts the config after ending tenancy', function() {
|
|
config([
|
|
'broadcasting.connections.testing.driver' => 'testing',
|
|
'broadcasting.connections.testing.message' => $defaultMessage = 'default',
|
|
'tenancy.bootstrappers' => [BroadcastingConfigBootstrapper::class],
|
|
]);
|
|
|
|
BroadcastingConfigBootstrapper::$credentialsMap = [
|
|
'broadcasting.connections.testing.message' => 'testing_broadcaster_message',
|
|
];
|
|
|
|
$tenant = Tenant::create(['testing_broadcaster_message' => $tenantMessage = 'first testing']);
|
|
$tenant2 = Tenant::create(['testing_broadcaster_message' => $secondTenantMessage = 'second testing']);
|
|
|
|
tenancy()->initialize($tenant);
|
|
|
|
expect(array_key_exists('testing_broadcaster_message', tenant()->getAttributes()))->toBeTrue();
|
|
expect(config('broadcasting.connections.testing.message'))->toBe($tenantMessage);
|
|
|
|
tenancy()->initialize($tenant2);
|
|
|
|
expect(config('broadcasting.connections.testing.message'))->toBe($secondTenantMessage);
|
|
|
|
tenancy()->end();
|
|
|
|
expect(config('broadcasting.connections.testing.message'))->toBe($defaultMessage);
|
|
});
|
|
|
|
test('BroadcastingConfigBootstrapper makes the app use broadcasters with the correct credentials', function() {
|
|
config([
|
|
'broadcasting.default' => 'testing',
|
|
'broadcasting.connections.testing.driver' => 'testing',
|
|
'broadcasting.connections.testing.message' => $defaultMessage = 'default',
|
|
'tenancy.bootstrappers' => [BroadcastingConfigBootstrapper::class],
|
|
]);
|
|
|
|
TenancyBroadcastManager::$tenantBroadcasters[] = 'testing';
|
|
BroadcastingConfigBootstrapper::$credentialsMap = [
|
|
'broadcasting.connections.testing.message' => 'testing_broadcaster_message',
|
|
];
|
|
|
|
$registerTestingBroadcaster = fn() => app(BroadcastManager::class)->extend('testing', fn ($app, $config) => new TestingBroadcaster($config['message']));
|
|
|
|
$registerTestingBroadcaster();
|
|
|
|
expect(invade(app(BroadcastManager::class)->driver())->message)->toBe($defaultMessage);
|
|
|
|
$tenant = Tenant::create(['testing_broadcaster_message' => $tenantMessage = 'first testing']);
|
|
$tenant2 = Tenant::create(['testing_broadcaster_message' => $secondTenantMessage = 'second testing']);
|
|
|
|
tenancy()->initialize($tenant);
|
|
$registerTestingBroadcaster();
|
|
|
|
expect(invade(app(BroadcastManager::class)->driver())->message)->toBe($tenantMessage);
|
|
|
|
tenancy()->initialize($tenant2);
|
|
$registerTestingBroadcaster();
|
|
|
|
expect(invade(app(BroadcastManager::class)->driver())->message)->toBe($secondTenantMessage);
|
|
|
|
tenancy()->end();
|
|
$registerTestingBroadcaster();
|
|
|
|
expect(invade(app(BroadcastManager::class)->driver())->message)->toBe($defaultMessage);
|
|
});
|
|
|