2021-06-26 15:23:15 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Tests;
|
2015-07-12 20:01:42 +01:00
|
|
|
|
2020-11-22 00:17:45 +00:00
|
|
|
use BookStack\Entities\Models\Entity;
|
2017-02-05 14:37:50 +00:00
|
|
|
use Illuminate\Foundation\Testing\DatabaseTransactions;
|
2017-02-04 11:58:42 +00:00
|
|
|
use Illuminate\Foundation\Testing\TestCase as BaseTestCase;
|
2015-09-02 18:26:33 +01:00
|
|
|
|
2017-02-04 11:58:42 +00:00
|
|
|
abstract class TestCase extends BaseTestCase
|
2015-07-12 20:01:42 +01:00
|
|
|
{
|
2017-02-04 11:58:42 +00:00
|
|
|
use CreatesApplication;
|
2017-02-05 14:37:50 +00:00
|
|
|
use DatabaseTransactions;
|
2018-04-14 18:47:13 +01:00
|
|
|
use SharedTestHelpers;
|
2018-09-21 15:15:16 +01:00
|
|
|
|
2018-01-28 13:33:50 +00:00
|
|
|
/**
|
|
|
|
* The base URL to use while testing the application.
|
2021-06-26 15:23:15 +00:00
|
|
|
*
|
2018-01-28 13:33:50 +00:00
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $baseUrl = 'http://localhost';
|
|
|
|
|
2018-09-21 15:15:16 +01:00
|
|
|
/**
|
|
|
|
* Assert the session contains a specific entry.
|
2021-06-26 15:23:15 +00:00
|
|
|
*
|
2018-09-21 15:15:16 +01:00
|
|
|
* @param string $key
|
2021-06-26 15:23:15 +00:00
|
|
|
*
|
2018-09-21 15:15:16 +01:00
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
protected function assertSessionHas(string $key)
|
|
|
|
{
|
|
|
|
$this->assertTrue(session()->has($key), "Session does not contain a [{$key}] entry");
|
2021-06-26 15:23:15 +00:00
|
|
|
|
2018-09-21 15:15:16 +01:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Override of the get method so we can get visibility of custom TestResponse methods.
|
2021-06-26 15:23:15 +00:00
|
|
|
*
|
|
|
|
* @param string $uri
|
|
|
|
* @param array $headers
|
|
|
|
*
|
2018-09-21 15:15:16 +01:00
|
|
|
* @return TestResponse
|
|
|
|
*/
|
|
|
|
public function get($uri, array $headers = [])
|
|
|
|
{
|
|
|
|
return parent::get($uri, $headers);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create the test response instance from the given response.
|
|
|
|
*
|
2021-06-26 15:23:15 +00:00
|
|
|
* @param \Illuminate\Http\Response $response
|
|
|
|
*
|
2018-09-21 15:15:16 +01:00
|
|
|
* @return TestResponse
|
|
|
|
*/
|
|
|
|
protected function createTestResponse($response)
|
|
|
|
{
|
|
|
|
return TestResponse::fromBaseResponse($response);
|
2017-08-28 13:55:39 +01:00
|
|
|
}
|
2020-01-12 14:45:54 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Assert that an activity entry exists of the given key.
|
|
|
|
* Checks the activity belongs to the given entity if provided.
|
|
|
|
*/
|
2021-09-18 21:29:42 +01:00
|
|
|
protected function assertActivityExists(string $type, ?Entity $entity = null, string $detail = '')
|
2020-01-12 14:45:54 +00:00
|
|
|
{
|
2020-11-08 00:03:19 +00:00
|
|
|
$detailsToCheck = ['type' => $type];
|
2020-01-12 14:45:54 +00:00
|
|
|
|
|
|
|
if ($entity) {
|
|
|
|
$detailsToCheck['entity_type'] = $entity->getMorphClass();
|
|
|
|
$detailsToCheck['entity_id'] = $entity->id;
|
|
|
|
}
|
|
|
|
|
2021-09-15 20:55:10 +01:00
|
|
|
if ($detail) {
|
|
|
|
$detailsToCheck['detail'] = $detail;
|
|
|
|
}
|
|
|
|
|
2020-01-12 14:45:54 +00:00
|
|
|
$this->assertDatabaseHas('activities', $detailsToCheck);
|
|
|
|
}
|
2021-06-26 15:23:15 +00:00
|
|
|
}
|