This repository has been archived on 2024-09-05. You can view files and clone it, but cannot push or open issues or pull requests.
shimmie2/tests/bootstrap.php

266 lines
7.5 KiB
PHP
Raw Normal View History

2020-01-30 09:01:19 +00:00
<?php declare(strict_types=1);
2020-03-13 09:23:54 +00:00
use PHPUnit\Framework\TestCase;
chdir(dirname(dirname(__FILE__)));
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 11:14:28 +00: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 11:14:28 +00:00
global $cache, $config, $database, $user, $page, $_tracer;
_sanitise_environment();
2020-01-28 23:57:43 +00:00
$tracer_enabled = true;
2020-03-13 09:23:54 +00:00
$_tracer = new EventTracer();
2020-01-28 23:57:43 +00:00
$_tracer->begin("bootstrap");
_load_core_files();
$cache = new Cache(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:");
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();
$config->set_string("thumb_engine", "static"); # GD has less overhead per-call
$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());
2020-01-28 23:57:43 +00:00
$_tracer->end();
2015-08-09 11:14:28 +00:00
2020-03-13 09:23:54 +00:00
abstract class ShimmiePHPUnitTestCase extends TestCase
{
2020-01-29 20:22:50 +00:00
protected static $anon_name = "anonymous";
protected static $admin_name = "demo";
protected static $user_name = "test";
protected $wipe_time = "test";
public static function setUpBeforeClass(): void
{
parent::setUpBeforeClass();
2020-03-13 09:23:54 +00:00
global $_tracer;
$_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-11-14 18:24:09 +00:00
public function setUp(): void
{
2020-01-29 00:37:31 +00:00
global $database, $_tracer;
2020-01-28 23:57:43 +00:00
$_tracer->begin($this->getName());
$_tracer->begin("setUp");
$class = str_replace("Test", "", get_class($this));
if (!ExtensionInfo::get_for_extension_class($class)->is_supported()) {
$this->markTestSkipped("$class not supported with this database");
}
2020-01-29 20:22:50 +00:00
// If we have a parent test, don't wipe out the state they gave us
if (!$this->getDependencyInput()) {
// things to do after bootstrap and before request
// log in as anon
self::log_out();
2020-01-27 18:24:11 +00:00
2020-01-29 20:22:50 +00:00
foreach ($database->get_col("SELECT id FROM images") as $image_id) {
2020-01-30 09:01:19 +00:00
send_event(new ImageDeletionEvent(Image::by_id((int)$image_id), true));
2020-01-29 20:22:50 +00:00
}
2020-01-29 00:37:31 +00:00
}
$_tracer->end();
2020-01-28 23:57:43 +00:00
$_tracer->begin("test");
}
2019-11-14 18:24:09 +00:00
public function tearDown(): void
{
global $_tracer;
$_tracer->end();
2020-01-28 23:57:43 +00:00
$_tracer->end();
$_tracer->clear();
$_tracer->flush("tests/trace.json");
}
2020-01-29 20:22:50 +00:00
public static function tearDownAfterClass(): void
{
parent::tearDownAfterClass();
global $_tracer;
$_tracer->end();
}
protected static function create_user(string $name)
2020-01-27 18:24:11 +00:00
{
if (is_null(User::by_name($name))) {
$userPage = new UserPage();
2020-05-19 18:33:51 +00:00
$userPage->onUserCreation(new UserCreationEvent($name, $name, "", false));
2020-01-27 18:24:11 +00:00
assert(!is_null(User::by_name($name)), "Creation of user $name failed");
}
}
protected static function get_page($page_name, $args=null): Page
{
// use a fresh page
global $page;
if (!$args) {
$args = [];
}
2020-03-27 23:35:07 +00:00
$_SERVER['REQUEST_URI'] = make_link($page_name, http_build_query($args));
$_GET = $args;
$_POST = [];
$page = new Page();
send_event(new PageRequestEvent($page_name));
2019-06-19 01:58:28 +00:00
if ($page->mode == PageMode::REDIRECT) {
$page->code = 302;
}
return $page;
}
protected static function post_page($page_name, $args=null): Page
{
// use a fresh page
global $page;
if (!$args) {
$args = [];
}
2020-03-27 23:35:07 +00:00
$_SERVER['REQUEST_URI'] = make_link($page_name);
2020-01-26 16:38:26 +00:00
foreach ($args as $k=>$v) {
2020-04-25 20:36:28 +00:00
if (is_array($v)) {
$args[$k] = $v;
2020-04-25 20:36:28 +00:00
} else {
$args[$k] = (string)$v;
}
2020-01-26 13:19:35 +00:00
}
$_GET = [];
$_POST = $args;
$page = new Page();
send_event(new PageRequestEvent($page_name));
2019-06-19 01:58:28 +00:00
if ($page->mode == PageMode::REDIRECT) {
$page->code = 302;
}
return $page;
}
// page things
protected function assert_title(string $title)
{
global $page;
2019-11-21 17:16:11 +00:00
$this->assertStringContainsString($title, $page->title);
}
2020-01-26 13:19:35 +00:00
protected function assert_title_matches($title)
{
global $page;
$this->assertStringMatchesFormat($title, $page->title);
}
protected function assert_no_title(string $title)
{
global $page;
2019-11-21 17:18:43 +00:00
$this->assertStringNotContainsString($title, $page->title);
}
protected function assert_response(int $code)
{
global $page;
$this->assertEquals($code, $page->code);
}
protected function page_to_text(string $section=null)
{
global $page;
2020-01-29 00:49:21 +00:00
if ($page->mode == PageMode::PAGE) {
$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";
}
}
return $text;
2020-01-29 00:49:21 +00:00
} elseif ($page->mode == PageMode::DATA) {
return $page->data;
2020-01-29 00:49:21 +00:00
} else {
$this->assertTrue(false, "Page mode is not PAGE or DATA");
}
}
protected function assert_text(string $text, string $section=null)
{
2019-11-21 17:16:11 +00:00
$this->assertStringContainsString($text, $this->page_to_text($section));
}
protected function assert_no_text(string $text, string $section=null)
{
2019-11-21 17:18:43 +00:00
$this->assertStringNotContainsString($text, $this->page_to_text($section));
}
protected function assert_content(string $content)
{
global $page;
2019-11-21 17:16:11 +00:00
$this->assertStringContainsString($content, $page->data);
}
protected function assert_no_content(string $content)
{
global $page;
2019-11-21 17:18:43 +00:00
$this->assertStringNotContainsString($content, $page->data);
}
2020-01-29 20:22:50 +00:00
protected function assert_search_results($tags, $results)
{
$images = Image::find_images(0, null, $tags);
$ids = [];
foreach ($images as $image) {
$ids[] = $image->id;
}
$this->assertEquals($results, $ids);
}
// user things
2020-01-29 20:22:50 +00:00
protected static function log_in_as_admin()
{
2020-01-29 20:22:50 +00:00
send_event(new UserLoginEvent(User::by_name(self::$admin_name)));
}
2020-01-29 20:22:50 +00:00
protected static function log_in_as_user()
{
2020-01-29 20:22:50 +00:00
send_event(new UserLoginEvent(User::by_name(self::$user_name)));
}
2020-01-29 20:22:50 +00:00
protected static function log_out()
{
global $config;
2020-01-29 20:22:50 +00:00
send_event(new UserLoginEvent(User::by_id($config->get_int("anon_id", 0))));
}
// post things
protected function post_image(string $filename, string $tags): int
{
$dae = new DataUploadEvent($filename, [
"filename" => $filename,
"extension" => pathinfo($filename, PATHINFO_EXTENSION),
"tags" => Tag::explode($tags),
"source" => null,
]);
send_event($dae);
return $dae->image_id;
}
protected function delete_image(int $image_id)
{
$img = Image::by_id($image_id);
if ($img) {
$ide = new ImageDeletionEvent($img, true);
send_event($ide);
}
}
2015-08-09 11:14:28 +00:00
}