mirror of
https://github.com/pelican-dev/panel.git
synced 2025-05-21 01:04:44 +02:00

* feat: First Webhook PoC draft * feat: Dispatch Webhooks PoC * fix: typo in webhook configuration scope * Update 2024_04_21_162552_create_webhooks_table.php Co-authored-by: Lance Pioch <lancepioch@gmail.com> * Update 2024_04_21_162552_create_webhooks_table.php Co-authored-by: Lance Pioch <lancepioch@gmail.com> * Update 2024_04_21_162544_create_webhook_configurations_table.php Co-authored-by: Lance Pioch <lancepioch@gmail.com> * Update 2024_04_21_162544_create_webhook_configurations_table.php Co-authored-by: Lance Pioch <lancepioch@gmail.com> * Update DispatchWebhooks.php Co-authored-by: Lance Pioch <lancepioch@gmail.com> * Update DispatchWebhooksJob.php Co-authored-by: Lance Pioch <lancepioch@gmail.com> * Update DispatchWebhookForConfiguration.php Co-authored-by: Lance Pioch <lancepioch@gmail.com> * Update DispatchWebhookForConfiguration.php Co-authored-by: Lance Pioch <lancepioch@gmail.com> * Update DispatchWebhookForConfiguration.php Co-authored-by: Lance Pioch <lancepioch@gmail.com> * Update DispatchWebhooksJob.php Co-authored-by: Lance Pioch <lancepioch@gmail.com> * Update DispatchWebhooksJob.php Co-authored-by: Lance Pioch <lancepioch@gmail.com> * Update DispatchWebhooksJob.php Co-authored-by: Lance Pioch <lancepioch@gmail.com> * chore: Implement Webhook Event Discovery * we got a test working for webhooks * WIP * Something is working! * More tests * clean up the tests now that they are passing * WIP * Don't use model specific events * WIP * WIP * WIP * WIP * WIP * Do it sync * Reset these * Don't need restored event type * Deleted some unused jobs * Find custom Events * Remove observers * Add custom event test * Run Pint * Add caching * Don't cache every single event * Fix tests * Run Pint * Phpstan fixes * Pint fix * Test fixes * Middleware unit test fix * Pint fixes * Remove index not working for older dbs * Use facade instead --------- Co-authored-by: Pascale Beier <mail@pascalebeier.de> Co-authored-by: Lance Pioch <lancepioch@gmail.com> Co-authored-by: Vehikl <go@vehikl.com>
73 lines
1.8 KiB
PHP
73 lines
1.8 KiB
PHP
<?php
|
|
|
|
namespace App\Tests\Unit\Http\Middleware;
|
|
|
|
use Mockery as m;
|
|
use Mockery\MockInterface;
|
|
use App\Models\Node;
|
|
use Illuminate\Http\Response;
|
|
use App\Models\Server;
|
|
use Illuminate\Contracts\Routing\ResponseFactory;
|
|
use App\Http\Middleware\MaintenanceMiddleware;
|
|
|
|
class MaintenanceMiddlewareTest extends MiddlewareTestCase
|
|
{
|
|
private MockInterface $response;
|
|
|
|
/**
|
|
* Setup tests.
|
|
*/
|
|
protected function setUp(): void
|
|
{
|
|
parent::setUp();
|
|
|
|
$this->response = m::mock(ResponseFactory::class);
|
|
}
|
|
|
|
/**
|
|
* Test that a node not in maintenance mode continues through the request cycle.
|
|
*/
|
|
public function testHandle(): void
|
|
{
|
|
// maintenance mode is off by default
|
|
$server = new Server();
|
|
|
|
$node = new Node([
|
|
'maintenance_mode' => false,
|
|
]);
|
|
$server->setRelation('node', $node);
|
|
|
|
$this->setRequestAttribute('server', $server);
|
|
|
|
$this->getMiddleware()->handle($this->request, $this->getClosureAssertions());
|
|
}
|
|
|
|
/**
|
|
* Test that a node in maintenance mode returns an error view.
|
|
*/
|
|
public function testHandleInMaintenanceMode(): void
|
|
{
|
|
$server = new Server();
|
|
|
|
$node = new Node([
|
|
'maintenance_mode' => true,
|
|
]);
|
|
$server->setRelation('node', $node);
|
|
|
|
$this->setRequestAttribute('server', $server);
|
|
|
|
$this->response->shouldReceive('view')
|
|
->once()
|
|
->with('errors.maintenance')
|
|
->andReturn(new Response());
|
|
|
|
$response = $this->getMiddleware()->handle($this->request, $this->getClosureAssertions());
|
|
$this->assertInstanceOf(Response::class, $response);
|
|
}
|
|
|
|
private function getMiddleware(): MaintenanceMiddleware
|
|
{
|
|
return new MaintenanceMiddleware($this->response);
|
|
}
|
|
}
|