2017-07-22 15:29:12 -04:00
|
|
|
<?php
|
2017-11-16 20:23:18 -05:00
|
|
|
/** @license MIT
|
|
|
|
* Copyright 2017 J. King, Dustin Wilson et al.
|
|
|
|
* See LICENSE and AUTHORS files for details */
|
|
|
|
|
2017-07-22 15:29:12 -04:00
|
|
|
declare(strict_types=1);
|
|
|
|
namespace JKingWeb\Arsse;
|
2017-08-29 10:50:31 -04:00
|
|
|
|
2017-07-22 15:29:12 -04:00
|
|
|
use JKingWeb\Arsse\Arsse;
|
|
|
|
use org\bovigo\vfs\vfsStream;
|
|
|
|
use Phake;
|
|
|
|
|
2017-08-29 11:16:37 -04:00
|
|
|
/**
|
2017-07-22 15:29:12 -04:00
|
|
|
* @covers \JKingWeb\Arsse\Db\SQLite3\Driver<extended>
|
|
|
|
* @covers \JKingWeb\Arsse\Db\SQLite3\ExceptionBuilder */
|
|
|
|
class TestDbDriverCreationSQLite3 extends Test\AbstractTest {
|
|
|
|
protected $data;
|
|
|
|
protected $drv;
|
|
|
|
protected $ch;
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function setUp() {
|
|
|
|
if (!extension_loaded("sqlite3")) {
|
2017-07-22 15:29:12 -04:00
|
|
|
$this->markTestSkipped("SQLite extension not loaded");
|
|
|
|
}
|
|
|
|
$this->clearData();
|
|
|
|
// test files
|
|
|
|
$this->files = [
|
|
|
|
// cannot create files
|
|
|
|
'Cmain' => [],
|
|
|
|
'Cshm' => [
|
|
|
|
'arsse.db' => "",
|
|
|
|
'arsse.db-wal' => "",
|
|
|
|
],
|
|
|
|
'Cwal' => [
|
|
|
|
'arsse.db' => "",
|
|
|
|
],
|
|
|
|
// cannot write to files
|
|
|
|
'Wmain' => [
|
|
|
|
'arsse.db' => "",
|
|
|
|
'arsse.db-wal' => "",
|
|
|
|
'arsse.db-shm' => "",
|
|
|
|
],
|
|
|
|
'Wwal' => [
|
|
|
|
'arsse.db' => "",
|
|
|
|
'arsse.db-wal' => "",
|
|
|
|
'arsse.db-shm' => "",
|
|
|
|
],
|
|
|
|
'Wshm' => [
|
|
|
|
'arsse.db' => "",
|
|
|
|
'arsse.db-wal' => "",
|
|
|
|
'arsse.db-shm' => "",
|
|
|
|
],
|
|
|
|
// cannot read from files
|
|
|
|
'Rmain' => [
|
|
|
|
'arsse.db' => "",
|
|
|
|
'arsse.db-wal' => "",
|
|
|
|
'arsse.db-shm' => "",
|
|
|
|
],
|
|
|
|
'Rwal' => [
|
|
|
|
'arsse.db' => "",
|
|
|
|
'arsse.db-wal' => "",
|
|
|
|
'arsse.db-shm' => "",
|
|
|
|
],
|
|
|
|
'Rshm' => [
|
|
|
|
'arsse.db' => "",
|
|
|
|
'arsse.db-wal' => "",
|
|
|
|
'arsse.db-shm' => "",
|
|
|
|
],
|
|
|
|
// can neither read from or write to files
|
|
|
|
'Amain' => [
|
|
|
|
'arsse.db' => "",
|
|
|
|
'arsse.db-wal' => "",
|
|
|
|
'arsse.db-shm' => "",
|
|
|
|
],
|
|
|
|
'Awal' => [
|
|
|
|
'arsse.db' => "",
|
|
|
|
'arsse.db-wal' => "",
|
|
|
|
'arsse.db-shm' => "",
|
|
|
|
],
|
|
|
|
'Ashm' => [
|
|
|
|
'arsse.db' => "",
|
|
|
|
'arsse.db-wal' => "",
|
|
|
|
'arsse.db-shm' => "",
|
|
|
|
],
|
|
|
|
// non-filesystem errors
|
|
|
|
'corrupt' => [
|
|
|
|
'arsse.db' => "",
|
|
|
|
'arsse.db-wal' => "",
|
|
|
|
'arsse.db-shm' => "",
|
|
|
|
],
|
|
|
|
];
|
|
|
|
$vfs = vfsStream::setup("dbtest", 0777, $this->files);
|
|
|
|
$this->path = $path = $vfs->url()."/";
|
|
|
|
// set up access blocks
|
|
|
|
chmod($path."Cmain", 0555);
|
2017-08-29 10:50:31 -04:00
|
|
|
chmod($path."Cwal", 0555);
|
|
|
|
chmod($path."Cshm", 0555);
|
|
|
|
chmod($path."Rmain/arsse.db", 0333);
|
2017-07-22 15:29:12 -04:00
|
|
|
chmod($path."Rwal/arsse.db-wal", 0333);
|
|
|
|
chmod($path."Rshm/arsse.db-shm", 0333);
|
2017-08-29 10:50:31 -04:00
|
|
|
chmod($path."Wmain/arsse.db", 0555);
|
2017-07-22 15:29:12 -04:00
|
|
|
chmod($path."Wwal/arsse.db-wal", 0555);
|
|
|
|
chmod($path."Wshm/arsse.db-shm", 0555);
|
2017-08-29 10:50:31 -04:00
|
|
|
chmod($path."Amain/arsse.db", 0111);
|
2017-07-22 15:29:12 -04:00
|
|
|
chmod($path."Awal/arsse.db-wal", 0111);
|
|
|
|
chmod($path."Ashm/arsse.db-shm", 0111);
|
|
|
|
// set up configuration
|
|
|
|
Arsse::$conf = new Conf();
|
|
|
|
Arsse::$conf->dbSQLite3File = ":memory:";
|
|
|
|
// set up database shim
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function tearDown() {
|
2017-07-22 15:29:12 -04:00
|
|
|
$this->clearData();
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function testFailToCreateDatabase() {
|
2017-07-22 15:29:12 -04:00
|
|
|
Arsse::$conf->dbSQLite3File = $this->path."Cmain/arsse.db";
|
|
|
|
$this->assertException("fileUncreatable", "Db");
|
|
|
|
new Db\SQLite3\Driver;
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function testFailToCreateJournal() {
|
2017-07-22 15:29:12 -04:00
|
|
|
Arsse::$conf->dbSQLite3File = $this->path."Cwal/arsse.db";
|
|
|
|
$this->assertException("fileUncreatable", "Db");
|
|
|
|
new Db\SQLite3\Driver;
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function testFailToCreateSharedMmeory() {
|
2017-07-22 15:29:12 -04:00
|
|
|
Arsse::$conf->dbSQLite3File = $this->path."Cshm/arsse.db";
|
|
|
|
$this->assertException("fileUncreatable", "Db");
|
|
|
|
new Db\SQLite3\Driver;
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function testFailToReadDatabase() {
|
2017-07-22 15:29:12 -04:00
|
|
|
Arsse::$conf->dbSQLite3File = $this->path."Rmain/arsse.db";
|
|
|
|
$this->assertException("fileUnreadable", "Db");
|
|
|
|
new Db\SQLite3\Driver;
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function testFailToReadJournal() {
|
2017-07-22 15:29:12 -04:00
|
|
|
Arsse::$conf->dbSQLite3File = $this->path."Rwal/arsse.db";
|
|
|
|
$this->assertException("fileUnreadable", "Db");
|
|
|
|
new Db\SQLite3\Driver;
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function testFailToReadSharedMmeory() {
|
2017-07-22 15:29:12 -04:00
|
|
|
Arsse::$conf->dbSQLite3File = $this->path."Rshm/arsse.db";
|
|
|
|
$this->assertException("fileUnreadable", "Db");
|
|
|
|
new Db\SQLite3\Driver;
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function testFailToWriteToDatabase() {
|
2017-07-22 15:29:12 -04:00
|
|
|
Arsse::$conf->dbSQLite3File = $this->path."Wmain/arsse.db";
|
|
|
|
$this->assertException("fileUnwritable", "Db");
|
|
|
|
new Db\SQLite3\Driver;
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function testFailToWriteToJournal() {
|
2017-07-22 15:29:12 -04:00
|
|
|
Arsse::$conf->dbSQLite3File = $this->path."Wwal/arsse.db";
|
|
|
|
$this->assertException("fileUnwritable", "Db");
|
|
|
|
new Db\SQLite3\Driver;
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function testFailToWriteToSharedMmeory() {
|
2017-07-22 15:29:12 -04:00
|
|
|
Arsse::$conf->dbSQLite3File = $this->path."Wshm/arsse.db";
|
|
|
|
$this->assertException("fileUnwritable", "Db");
|
|
|
|
new Db\SQLite3\Driver;
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function testFailToAccessDatabase() {
|
2017-07-22 15:29:12 -04:00
|
|
|
Arsse::$conf->dbSQLite3File = $this->path."Amain/arsse.db";
|
|
|
|
$this->assertException("fileUnusable", "Db");
|
|
|
|
new Db\SQLite3\Driver;
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function testFailToAccessJournal() {
|
2017-07-22 15:29:12 -04:00
|
|
|
Arsse::$conf->dbSQLite3File = $this->path."Awal/arsse.db";
|
|
|
|
$this->assertException("fileUnusable", "Db");
|
|
|
|
new Db\SQLite3\Driver;
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function testFailToAccessSharedMmeory() {
|
2017-07-22 15:29:12 -04:00
|
|
|
Arsse::$conf->dbSQLite3File = $this->path."Ashm/arsse.db";
|
|
|
|
$this->assertException("fileUnusable", "Db");
|
|
|
|
new Db\SQLite3\Driver;
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function testAssumeDatabaseCorruption() {
|
2017-07-22 15:29:12 -04:00
|
|
|
Arsse::$conf->dbSQLite3File = $this->path."corrupt/arsse.db";
|
|
|
|
$this->assertException("fileCorrupt", "Db");
|
|
|
|
new Db\SQLite3\Driver;
|
|
|
|
}
|
2017-08-29 10:50:31 -04:00
|
|
|
}
|