X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/c6e196989e30aa45cac2ebddee1fdba919729cdc..refs/pull/3139/head:/tests/ThemeTest.php diff --git a/tests/ThemeTest.php b/tests/ThemeTest.php index f04250bff..fe8162559 100644 --- a/tests/ThemeTest.php +++ b/tests/ThemeTest.php @@ -2,16 +2,21 @@ namespace Tests; +use BookStack\Actions\ActivityType; +use BookStack\Actions\DispatchWebhookJob; +use BookStack\Actions\Webhook; use BookStack\Auth\User; use BookStack\Entities\Models\Page; use BookStack\Entities\Tools\PageContent; use BookStack\Facades\Theme; use BookStack\Theming\ThemeEvents; use Illuminate\Console\Command; +use Illuminate\Http\Client\Request as HttpClientRequest; use Illuminate\Http\Request; use Illuminate\Http\Response; use Illuminate\Support\Facades\Artisan; use Illuminate\Support\Facades\File; +use Illuminate\Support\Facades\Http; use League\CommonMark\ConfigurableEnvironmentInterface; class ThemeTest extends TestCase @@ -160,6 +165,36 @@ class ThemeTest extends TestCase $this->assertInstanceOf(User::class, $args[1]); } + public function test_event_webhook_call_before() + { + $args = []; + $callback = function (...$eventArgs) use (&$args) { + $args = $eventArgs; + return ['test' => 'hello!']; + }; + Theme::listen(ThemeEvents::WEBHOOK_CALL_BEFORE, $callback); + + Http::fake([ + '*' => Http::response('', 200), + ]); + + $webhook = new Webhook(['name' => 'Test webhook', 'endpoint' => 'https://example.com']); + $webhook->save(); + $event = ActivityType::PAGE_UPDATE; + $detail = Page::query()->first(); + + dispatch((new DispatchWebhookJob($webhook, $event, $detail))); + + $this->assertCount(3, $args); + $this->assertEquals($event, $args[0]); + $this->assertEquals($webhook->id, $args[1]->id); + $this->assertEquals($detail->id, $args[2]->id); + + Http::assertSent(function (HttpClientRequest $request) { + return $request->isJson() && $request->data()['test'] === 'hello!'; + }); + } + public function test_add_social_driver() { Theme::addSocialDriver('catnet', [ @@ -210,7 +245,7 @@ class ThemeTest extends TestCase public function test_register_command_allows_provided_command_to_be_usable_via_artisan() { - Theme::registerCommand(new MyCustomCommand); + Theme::registerCommand(new MyCustomCommand()); Artisan::call('bookstack:test-custom-command', []); $output = Artisan::output(); @@ -233,9 +268,12 @@ class ThemeTest extends TestCase } } -class MyCustomCommand extends Command { +class MyCustomCommand extends Command +{ protected $signature = 'bookstack:test-custom-command'; - public function handle() { + + public function handle() + { $this->line('Command ran!'); } -} \ No newline at end of file +}