mirror of
https://github.com/archtechx/tenancy.git
synced 2025-12-12 18:24:04 +00:00
[2.1.0] Central queue connections (#181)
* Central queues * Better dependency injection * tenancy=false => central=true; move config to env setup * Apply fixes from StyleCI
This commit is contained in:
parent
d5b01219fd
commit
cfcb2574c2
4 changed files with 34 additions and 13 deletions
|
|
@ -4,7 +4,8 @@ declare(strict_types=1);
|
||||||
|
|
||||||
namespace Stancl\Tenancy\TenancyBootstrappers;
|
namespace Stancl\Tenancy\TenancyBootstrappers;
|
||||||
|
|
||||||
use Illuminate\Contracts\Foundation\Application;
|
use Illuminate\Config\Repository;
|
||||||
|
use Illuminate\Queue\QueueManager;
|
||||||
use Illuminate\Support\Testing\Fakes\QueueFake;
|
use Illuminate\Support\Testing\Fakes\QueueFake;
|
||||||
use Stancl\Tenancy\Contracts\TenancyBootstrapper;
|
use Stancl\Tenancy\Contracts\TenancyBootstrapper;
|
||||||
use Stancl\Tenancy\Tenant;
|
use Stancl\Tenancy\Tenant;
|
||||||
|
|
@ -14,19 +15,18 @@ class QueueTenancyBootstrapper implements TenancyBootstrapper
|
||||||
/** @var bool Has tenancy been started. */
|
/** @var bool Has tenancy been started. */
|
||||||
public $started = false;
|
public $started = false;
|
||||||
|
|
||||||
/** @var Application */
|
/** @var Repository */
|
||||||
protected $app;
|
protected $config;
|
||||||
|
|
||||||
public function __construct(Application $app)
|
public function __construct(Repository $config, QueueManager $queue)
|
||||||
{
|
{
|
||||||
$this->app = $app;
|
$this->config = $config;
|
||||||
|
|
||||||
$bootstrapper = &$this;
|
$bootstrapper = &$this;
|
||||||
|
|
||||||
$queue = $this->app['queue'];
|
|
||||||
if (! $queue instanceof QueueFake) {
|
if (! $queue instanceof QueueFake) {
|
||||||
$queue->createPayloadUsing(function () use (&$bootstrapper) {
|
$queue->createPayloadUsing(function ($connection) use (&$bootstrapper) {
|
||||||
return $bootstrapper->getPayload();
|
return $bootstrapper->getPayload($connection);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -41,12 +41,16 @@ class QueueTenancyBootstrapper implements TenancyBootstrapper
|
||||||
$this->started = false;
|
$this->started = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getPayload()
|
public function getPayload(string $connection)
|
||||||
{
|
{
|
||||||
if (! $this->started) {
|
if (! $this->started) {
|
||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($this->config["queue.connections.$connection.central"]) {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
|
||||||
$id = tenant('id');
|
$id = tenant('id');
|
||||||
|
|
||||||
return [
|
return [
|
||||||
|
|
|
||||||
|
|
@ -33,6 +33,19 @@ class QueueTest extends TestCase
|
||||||
return $event->job->payload()['tenant_id'] === tenant('id');
|
return $event->job->payload()['tenant_id'] === tenant('id');
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** @test */
|
||||||
|
public function tenancy_is_not_initialized_in_non_tenant_queues()
|
||||||
|
{
|
||||||
|
$this->loadLaravelMigrations(['--database' => 'tenant']);
|
||||||
|
Event::fake();
|
||||||
|
|
||||||
|
dispatch(new TestJob())->onConnection('central');
|
||||||
|
|
||||||
|
Event::assertDispatched(JobProcessing::class, function ($event) {
|
||||||
|
return ! isset($event->job->payload()['tenant_id']);
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class TestJob implements ShouldQueue
|
class TestJob implements ShouldQueue
|
||||||
|
|
|
||||||
|
|
@ -4,9 +4,7 @@ declare(strict_types=1);
|
||||||
|
|
||||||
namespace Stancl\Tenancy\Tests;
|
namespace Stancl\Tenancy\Tests;
|
||||||
|
|
||||||
use Stancl\Tenancy\StorageDrivers\Database\DatabaseStorageDriver;
|
|
||||||
use Stancl\Tenancy\StorageDrivers\Database\TenantModel;
|
use Stancl\Tenancy\StorageDrivers\Database\TenantModel;
|
||||||
use Stancl\Tenancy\StorageDrivers\RedisStorageDriver;
|
|
||||||
use Stancl\Tenancy\Tenant;
|
use Stancl\Tenancy\Tenant;
|
||||||
|
|
||||||
class TenantStorageTest extends TestCase
|
class TenantStorageTest extends TestCase
|
||||||
|
|
@ -84,10 +82,12 @@ class TenantStorageTest extends TestCase
|
||||||
/** @test */
|
/** @test */
|
||||||
public function correct_storage_driver_is_used()
|
public function correct_storage_driver_is_used()
|
||||||
{
|
{
|
||||||
if (config('tenancy.storage_driver') == DatabaseStorageDriver::class) {
|
if (config('tenancy.storage_driver') == 'db') {
|
||||||
$this->assertSame('DatabaseStorageDriver', class_basename(tenancy()->storage));
|
$this->assertSame('DatabaseStorageDriver', class_basename(tenancy()->storage));
|
||||||
} elseif (config('tenancy.storage_driver') == RedisStorageDriver::class) {
|
} elseif (config('tenancy.storage_driver') == 'redis') {
|
||||||
$this->assertSame('RedisStorageDriver', class_basename(tenancy()->storage));
|
$this->assertSame('RedisStorageDriver', class_basename(tenancy()->storage));
|
||||||
|
} else {
|
||||||
|
dd(class_basename(config('tenancy.storage_driver')));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -99,6 +99,10 @@ abstract class TestCase extends \Orchestra\Testbench\TestCase
|
||||||
'tenancy.migrations_directory' => database_path('../migrations'),
|
'tenancy.migrations_directory' => database_path('../migrations'),
|
||||||
'tenancy.storage_drivers.db.connection' => 'central',
|
'tenancy.storage_drivers.db.connection' => 'central',
|
||||||
'tenancy.bootstrappers.redis' => \Stancl\Tenancy\TenancyBootstrappers\RedisTenancyBootstrapper::class,
|
'tenancy.bootstrappers.redis' => \Stancl\Tenancy\TenancyBootstrappers\RedisTenancyBootstrapper::class,
|
||||||
|
'queue.connections.central' => [
|
||||||
|
'driver' => 'sync',
|
||||||
|
'central' => true,
|
||||||
|
],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$app->singleton(\Stancl\Tenancy\TenancyBootstrappers\RedisTenancyBootstrapper::class);
|
$app->singleton(\Stancl\Tenancy\TenancyBootstrappers\RedisTenancyBootstrapper::class);
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue