1
1
Fork 0
mirror of https://code.mensbeam.com/MensBeam/Arsse.git synced 2024-12-24 09:32:40 +00:00
Arsse/tests/cases/Db/SQLite3/TestUpdate.php

120 lines
4 KiB
PHP
Raw Normal View History

2017-03-10 02:39:42 +00:00
<?php
/** @license MIT
* Copyright 2017 J. King, Dustin Wilson et al.
* See LICENSE and AUTHORS files for details */
2017-03-10 02:39:42 +00:00
declare(strict_types=1);
2017-12-22 03:47:19 +00:00
namespace JKingWeb\Arsse\TestCase\Db\SQLite3;
2017-03-10 02:39:42 +00:00
2017-12-22 03:47:19 +00:00
use JKingWeb\Arsse\Arsse;
use JKingWeb\Arsse\Conf;
use JKingWeb\Arsse\Database;
use JKingWeb\Arsse\Db\Exception;
use JKingWeb\Arsse\Db\SQLite3\Driver;
2017-08-29 14:50:31 +00:00
use org\bovigo\vfs\vfsStream;
2017-03-10 02:39:42 +00:00
2017-08-29 14:50:31 +00:00
/**
2017-07-20 22:36:03 +00:00
* @covers \JKingWeb\Arsse\Db\SQLite3\Driver<extended>
* @covers \JKingWeb\Arsse\Db\SQLite3\ExceptionBuilder */
2017-12-22 03:47:19 +00:00
class TestUpdate extends \JKingWeb\Arsse\Test\AbstractTest {
2017-03-10 02:39:42 +00:00
protected $data;
protected $drv;
protected $vfs;
protected $base;
2017-03-10 02:39:42 +00:00
const MINIMAL1 = "create table arsse_meta(key text primary key not null, value text); pragma user_version=1";
const MINIMAL2 = "pragma user_version=2";
2017-03-10 02:39:42 +00:00
2017-08-29 14:50:31 +00:00
public function setUp(Conf $conf = null) {
if (!extension_loaded("sqlite3")) {
$this->markTestSkipped("SQLite extension not loaded");
}
$this->clearData();
2017-03-10 02:39:42 +00:00
$this->vfs = vfsStream::setup("schemata", null, ['SQLite3' => []]);
2017-08-29 14:50:31 +00:00
if (!$conf) {
2017-07-21 15:13:04 +00:00
$conf = new Conf();
}
2017-12-22 03:47:19 +00:00
$conf->dbDriver = Driver::class;
$conf->dbSQLite3File = ":memory:";
Arsse::$conf = $conf;
$this->base = $this->vfs->url();
$this->path = $this->base."/SQLite3/";
2017-12-22 03:47:19 +00:00
$this->drv = new Driver();
2017-03-10 02:39:42 +00:00
}
2017-08-29 14:50:31 +00:00
public function tearDown() {
2017-03-10 02:39:42 +00:00
unset($this->drv);
unset($this->data);
unset($this->vfs);
$this->clearData();
2017-03-10 02:39:42 +00:00
}
2017-08-29 14:50:31 +00:00
public function testLoadMissingFile() {
$this->assertException("updateFileMissing", "Db");
$this->drv->schemaUpdate(1, $this->base);
}
2017-03-10 02:39:42 +00:00
2017-08-29 14:50:31 +00:00
public function testLoadUnreadableFile() {
touch($this->path."0.sql");
chmod($this->path."0.sql", 0000);
$this->assertException("updateFileUnreadable", "Db");
$this->drv->schemaUpdate(1, $this->base);
}
2017-03-10 02:39:42 +00:00
2017-08-29 14:50:31 +00:00
public function testLoadCorruptFile() {
file_put_contents($this->path."0.sql", "This is a corrupt file");
$this->assertException("updateFileError", "Db");
$this->drv->schemaUpdate(1, $this->base);
}
2017-03-10 02:39:42 +00:00
2017-08-29 14:50:31 +00:00
public function testLoadIncompleteFile() {
file_put_contents($this->path."0.sql", "create table arsse_meta(key text primary key not null, value text);");
$this->assertException("updateFileIncomplete", "Db");
$this->drv->schemaUpdate(1, $this->base);
}
2017-03-10 02:39:42 +00:00
2017-08-29 14:50:31 +00:00
public function testLoadCorrectFile() {
file_put_contents($this->path."0.sql", self::MINIMAL1);
$this->drv->schemaUpdate(1, $this->base);
$this->assertEquals(1, $this->drv->schemaVersion());
}
2017-03-10 02:39:42 +00:00
2017-08-29 14:50:31 +00:00
public function testPerformPartialUpdate() {
file_put_contents($this->path."0.sql", self::MINIMAL1);
file_put_contents($this->path."1.sql", "");
$this->assertException("updateFileIncomplete", "Db");
try {
$this->drv->schemaUpdate(2, $this->base);
2017-08-29 14:50:31 +00:00
} catch (Exception $e) {
$this->assertEquals(1, $this->drv->schemaVersion());
throw $e;
}
}
2017-03-10 02:39:42 +00:00
2017-08-29 14:50:31 +00:00
public function testPerformSequentialUpdate() {
file_put_contents($this->path."0.sql", self::MINIMAL1);
file_put_contents($this->path."1.sql", self::MINIMAL2);
$this->drv->schemaUpdate(2, $this->base);
$this->assertEquals(2, $this->drv->schemaVersion());
}
2017-03-10 02:39:42 +00:00
2017-08-29 14:50:31 +00:00
public function testPerformActualUpdate() {
$this->drv->schemaUpdate(Database::SCHEMA_VERSION);
$this->assertEquals(Database::SCHEMA_VERSION, $this->drv->schemaVersion());
}
2017-07-21 15:13:04 +00:00
2017-08-29 14:50:31 +00:00
public function testDeclineManualUpdate() {
2017-07-21 15:13:04 +00:00
// turn auto-updating off
$conf = new Conf();
$conf->dbAutoUpdate = false;
$this->setUp($conf);
$this->assertException("updateManual", "Db");
$this->drv->schemaUpdate(Database::SCHEMA_VERSION);
}
2017-08-29 14:50:31 +00:00
public function testDeclineDowngrade() {
2017-07-21 15:13:04 +00:00
$this->assertException("updateTooNew", "Db");
$this->drv->schemaUpdate(-1, $this->base);
2017-07-21 15:13:04 +00:00
}
2017-08-29 14:50:31 +00:00
}