2021-12-14 18:32:47 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
2020-03-13 09:23:54 +00:00
|
|
|
|
2023-01-10 22:44:09 +00:00
|
|
|
namespace Shimmie2;
|
|
|
|
|
2020-03-13 09:23:54 +00:00
|
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
|
2020-01-27 19:28:58 +00:00
|
|
|
chdir(dirname(dirname(__FILE__)));
|
2020-06-24 14:53:36 +01:00
|
|
|
require_once "core/sanitize_php.php";
|
2020-01-27 19:28:58 +00:00
|
|
|
require_once "vendor/autoload.php";
|
|
|
|
require_once "tests/defines.php";
|
|
|
|
require_once "core/sys_config.php";
|
|
|
|
require_once "core/polyfills.php";
|
|
|
|
require_once "core/util.php";
|
2015-08-09 12:14:28 +01:00
|
|
|
|
|
|
|
$_SERVER['QUERY_STRING'] = '/';
|
2020-01-29 00:49:21 +00:00
|
|
|
if (file_exists("tests/trace.json")) {
|
|
|
|
unlink("tests/trace.json");
|
|
|
|
}
|
2015-08-09 12:14:28 +01:00
|
|
|
|
2020-01-27 19:28:58 +00:00
|
|
|
global $cache, $config, $database, $user, $page, $_tracer;
|
2020-06-24 14:53:36 +01:00
|
|
|
_set_up_shimmie_environment();
|
2020-01-28 23:57:43 +00:00
|
|
|
$tracer_enabled = true;
|
2023-01-10 22:44:09 +00:00
|
|
|
$_tracer = new \EventTracer();
|
2020-01-28 23:57:43 +00:00
|
|
|
$_tracer->begin("bootstrap");
|
2020-01-27 19:28:58 +00:00
|
|
|
_load_core_files();
|
2023-02-02 16:04:35 +00:00
|
|
|
$cache = loadCache(CACHE_DSN);
|
2020-03-22 15:23:23 +00:00
|
|
|
$dsn = getenv("TEST_DSN");
|
2020-01-27 19:40:14 +00:00
|
|
|
$database = new Database($dsn ? $dsn : "sqlite::memory:");
|
2020-01-27 19:28:58 +00:00
|
|
|
create_dirs();
|
|
|
|
create_tables($database);
|
|
|
|
$config = new DatabaseConfig($database);
|
|
|
|
ExtensionInfo::load_all_extension_info();
|
|
|
|
Extension::determine_enabled_extensions();
|
|
|
|
require_all(zglob("ext/{".Extension::get_enabled_extensions_as_string()."}/main.php"));
|
|
|
|
_load_theme_files();
|
|
|
|
$page = new Page();
|
|
|
|
_load_event_listeners();
|
2020-01-28 22:23:03 +00:00
|
|
|
$config->set_string("thumb_engine", "static"); # GD has less overhead per-call
|
2020-02-09 16:26:57 +00:00
|
|
|
$config->set_bool("nice_urls", true);
|
2020-01-27 19:52:54 +00:00
|
|
|
send_event(new DatabaseUpgradeEvent());
|
2020-01-27 19:05:43 +00:00
|
|
|
send_event(new InitExtEvent());
|
2023-02-24 21:08:05 +00:00
|
|
|
$user = User::by_id($config->get_int("anon_id", 0));
|
2020-01-28 23:57:43 +00:00
|
|
|
$_tracer->end();
|
2015-08-09 12:14:28 +01:00
|
|
|
|
2020-03-13 09:23:54 +00:00
|
|
|
abstract class ShimmiePHPUnitTestCase extends TestCase
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2021-03-14 23:43:50 +00:00
|
|
|
protected static string $anon_name = "anonymous";
|
|
|
|
protected static string $admin_name = "demo";
|
|
|
|
protected static string $user_name = "test";
|
|
|
|
protected string $wipe_time = "test";
|
2020-01-29 20:22:50 +00:00
|
|
|
|
|
|
|
public static function setUpBeforeClass(): void
|
|
|
|
{
|
|
|
|
parent::setUpBeforeClass();
|
2020-03-13 09:23:54 +00:00
|
|
|
global $_tracer;
|
2020-01-31 01:13:49 +00:00
|
|
|
$_tracer->begin(get_called_class());
|
2020-01-29 20:22:50 +00:00
|
|
|
|
|
|
|
self::create_user(self::$admin_name);
|
|
|
|
self::create_user(self::$user_name);
|
|
|
|
}
|
2019-05-28 17:59:38 +01:00
|
|
|
|
2019-11-14 18:24:09 +00:00
|
|
|
public function setUp(): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2020-01-29 00:37:31 +00:00
|
|
|
global $database, $_tracer;
|
2020-01-28 23:57:43 +00:00
|
|
|
$_tracer->begin($this->getName());
|
2020-01-28 21:19:59 +00:00
|
|
|
$_tracer->begin("setUp");
|
2019-05-28 17:59:38 +01:00
|
|
|
$class = str_replace("Test", "", get_class($this));
|
2020-01-28 21:19:59 +00:00
|
|
|
if (!ExtensionInfo::get_for_extension_class($class)->is_supported()) {
|
2019-05-28 17:59:38 +01:00
|
|
|
$this->markTestSkipped("$class not supported with this database");
|
|
|
|
}
|
|
|
|
|
2020-10-24 18:55:07 +01:00
|
|
|
// Set up a clean environment for each test
|
|
|
|
self::log_out();
|
|
|
|
foreach ($database->get_col("SELECT id FROM images") as $image_id) {
|
|
|
|
send_event(new ImageDeletionEvent(Image::by_id((int)$image_id), true));
|
2020-01-29 00:37:31 +00:00
|
|
|
}
|
|
|
|
|
2020-10-24 18:55:07 +01:00
|
|
|
$_tracer->end(); # setUp
|
2020-01-28 23:57:43 +00:00
|
|
|
$_tracer->begin("test");
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2019-11-14 18:24:09 +00:00
|
|
|
public function tearDown(): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2020-01-28 21:19:59 +00:00
|
|
|
global $_tracer;
|
2020-10-24 18:55:07 +01:00
|
|
|
$_tracer->end(); # test
|
|
|
|
$_tracer->end(); # $this->getName()
|
2020-01-28 21:19:59 +00:00
|
|
|
$_tracer->clear();
|
|
|
|
$_tracer->flush("tests/trace.json");
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2020-01-29 20:22:50 +00:00
|
|
|
public static function tearDownAfterClass(): void
|
|
|
|
{
|
|
|
|
parent::tearDownAfterClass();
|
|
|
|
global $_tracer;
|
2020-10-24 18:55:07 +01:00
|
|
|
$_tracer->end(); # get_called_class()
|
2020-01-29 20:22:50 +00:00
|
|
|
}
|
|
|
|
|
2021-03-14 23:43:50 +00:00
|
|
|
protected static function create_user(string $name): void
|
2020-01-27 18:24:11 +00:00
|
|
|
{
|
|
|
|
if (is_null(User::by_name($name))) {
|
|
|
|
$userPage = new UserPage();
|
2023-02-24 21:08:05 +00:00
|
|
|
$userPage->onUserCreation(new UserCreationEvent($name, $name, $name, "", false));
|
2020-01-27 18:24:11 +00:00
|
|
|
assert(!is_null(User::by_name($name)), "Creation of user $name failed");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-10-28 20:51:34 +00:00
|
|
|
private static function check_args(?array $args): array
|
|
|
|
{
|
|
|
|
if (!$args) {
|
|
|
|
return [];
|
|
|
|
}
|
2020-10-27 21:19:19 +00:00
|
|
|
foreach ($args as $k=>$v) {
|
|
|
|
if (is_array($v)) {
|
|
|
|
$args[$k] = $v;
|
|
|
|
} else {
|
|
|
|
$args[$k] = (string)$v;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $args;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected static function request($page_name, $get_args=null, $post_args=null): Page
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
// use a fresh page
|
|
|
|
global $page;
|
2020-10-27 21:19:19 +00:00
|
|
|
$get_args = self::check_args($get_args);
|
|
|
|
$post_args = self::check_args($post_args);
|
|
|
|
|
|
|
|
if (str_contains($page_name, "?")) {
|
2023-01-10 22:44:09 +00:00
|
|
|
throw new \RuntimeException("Query string included in page name");
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
2020-10-27 21:19:19 +00:00
|
|
|
$_SERVER['REQUEST_URI'] = make_link($page_name, http_build_query($get_args));
|
|
|
|
$_GET = $get_args;
|
|
|
|
$_POST = $post_args;
|
2020-01-28 21:19:59 +00:00
|
|
|
$page = new Page();
|
2019-05-28 17:59:38 +01:00
|
|
|
send_event(new PageRequestEvent($page_name));
|
2019-06-18 20:58:28 -05:00
|
|
|
if ($page->mode == PageMode::REDIRECT) {
|
2019-05-28 17:59:38 +01:00
|
|
|
$page->code = 302;
|
|
|
|
}
|
2020-01-28 21:19:59 +00:00
|
|
|
return $page;
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2020-10-27 21:19:19 +00:00
|
|
|
protected static function get_page($page_name, $args=null): Page
|
|
|
|
{
|
|
|
|
return self::request($page_name, $args, null);
|
|
|
|
}
|
|
|
|
|
2020-03-27 14:41:24 +00:00
|
|
|
protected static function post_page($page_name, $args=null): Page
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2020-10-27 21:19:19 +00:00
|
|
|
return self::request($page_name, null, $args);
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// page things
|
2021-03-14 23:43:50 +00:00
|
|
|
protected function assert_title(string $title): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
global $page;
|
2019-11-21 17:16:11 +00:00
|
|
|
$this->assertStringContainsString($title, $page->title);
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2021-03-14 23:43:50 +00:00
|
|
|
protected function assert_title_matches($title): void
|
2020-01-26 13:19:35 +00:00
|
|
|
{
|
|
|
|
global $page;
|
|
|
|
$this->assertStringMatchesFormat($title, $page->title);
|
|
|
|
}
|
|
|
|
|
2021-03-14 23:43:50 +00:00
|
|
|
protected function assert_no_title(string $title): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
global $page;
|
2019-11-21 17:18:43 +00:00
|
|
|
$this->assertStringNotContainsString($title, $page->title);
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2021-03-14 23:43:50 +00:00
|
|
|
protected function assert_response(int $code): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
global $page;
|
|
|
|
$this->assertEquals($code, $page->code);
|
|
|
|
}
|
|
|
|
|
2021-03-14 23:43:50 +00:00
|
|
|
protected function page_to_text(string $section=null): string
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
global $page;
|
2020-01-29 00:49:21 +00:00
|
|
|
if ($page->mode == PageMode::PAGE) {
|
2020-01-28 21:19:59 +00:00
|
|
|
$text = $page->title . "\n";
|
|
|
|
foreach ($page->blocks as $block) {
|
|
|
|
if (is_null($section) || $section == $block->section) {
|
|
|
|
$text .= $block->header . "\n";
|
|
|
|
$text .= $block->body . "\n\n";
|
|
|
|
}
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
2020-01-28 21:19:59 +00:00
|
|
|
return $text;
|
2020-01-29 00:49:21 +00:00
|
|
|
} elseif ($page->mode == PageMode::DATA) {
|
2020-01-28 21:19:59 +00:00
|
|
|
return $page->data;
|
2020-01-29 00:49:21 +00:00
|
|
|
} else {
|
2023-01-11 11:15:26 +00:00
|
|
|
$this->fail("Page mode is not PAGE or DATA");
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-03-14 23:43:50 +00:00
|
|
|
protected function assert_text(string $text, string $section=null): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2019-11-21 17:16:11 +00:00
|
|
|
$this->assertStringContainsString($text, $this->page_to_text($section));
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2021-03-14 23:43:50 +00:00
|
|
|
protected function assert_no_text(string $text, string $section=null): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2019-11-21 17:18:43 +00:00
|
|
|
$this->assertStringNotContainsString($text, $this->page_to_text($section));
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2021-03-14 23:43:50 +00:00
|
|
|
protected function assert_content(string $content): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
global $page;
|
2019-11-21 17:16:11 +00:00
|
|
|
$this->assertStringContainsString($content, $page->data);
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2021-03-14 23:43:50 +00:00
|
|
|
protected function assert_no_content(string $content): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
global $page;
|
2019-11-21 17:18:43 +00:00
|
|
|
$this->assertStringNotContainsString($content, $page->data);
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2021-03-14 23:43:50 +00:00
|
|
|
protected function assert_search_results($tags, $results): void
|
2020-01-29 20:22:50 +00:00
|
|
|
{
|
|
|
|
$images = Image::find_images(0, null, $tags);
|
|
|
|
$ids = [];
|
|
|
|
foreach ($images as $image) {
|
|
|
|
$ids[] = $image->id;
|
|
|
|
}
|
|
|
|
$this->assertEquals($results, $ids);
|
|
|
|
}
|
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
// user things
|
2021-03-14 23:43:50 +00:00
|
|
|
protected static function log_in_as_admin(): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2020-01-29 20:22:50 +00:00
|
|
|
send_event(new UserLoginEvent(User::by_name(self::$admin_name)));
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2021-03-14 23:43:50 +00:00
|
|
|
protected static function log_in_as_user(): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2020-01-29 20:22:50 +00:00
|
|
|
send_event(new UserLoginEvent(User::by_name(self::$user_name)));
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2021-03-14 23:43:50 +00:00
|
|
|
protected static function log_out(): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2020-01-28 21:19:59 +00:00
|
|
|
global $config;
|
2020-01-29 20:22:50 +00:00
|
|
|
send_event(new UserLoginEvent(User::by_id($config->get_int("anon_id", 0))));
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// post things
|
|
|
|
protected function post_image(string $filename, string $tags): int
|
|
|
|
{
|
2023-02-04 20:50:26 +00:00
|
|
|
$dae = send_event(new DataUploadEvent($filename, [
|
2019-05-28 17:59:38 +01:00
|
|
|
"filename" => $filename,
|
|
|
|
"tags" => Tag::explode($tags),
|
|
|
|
"source" => null,
|
2023-02-04 20:50:26 +00:00
|
|
|
]));
|
2023-01-10 22:44:09 +00:00
|
|
|
// if($dae->image_id == -1) throw new \Exception("Upload failed :(");
|
2019-05-28 17:59:38 +01:00
|
|
|
return $dae->image_id;
|
|
|
|
}
|
|
|
|
|
2021-03-14 23:43:50 +00:00
|
|
|
protected function delete_image(int $image_id): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
$img = Image::by_id($image_id);
|
|
|
|
if ($img) {
|
2023-02-04 20:50:26 +00:00
|
|
|
send_event(new ImageDeletionEvent($img, true));
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
}
|
2015-08-09 12:14:28 +01:00
|
|
|
}
|