2015-09-26 17:57:46 +02:00
|
|
|
<?php
|
2016-07-21 17:09:48 +02:00
|
|
|
|
|
|
|
use PrivateBin\configuration;
|
|
|
|
use PrivateBin\data\db;
|
|
|
|
use PrivateBin\model;
|
|
|
|
use PrivateBin\model\paste;
|
|
|
|
use PrivateBin\vizhash16x16;
|
|
|
|
|
2015-09-26 17:57:46 +02:00
|
|
|
class modelTest extends PHPUnit_Framework_TestCase
|
|
|
|
{
|
|
|
|
private $_conf;
|
|
|
|
|
|
|
|
private $_model;
|
|
|
|
|
|
|
|
public function setUp()
|
|
|
|
{
|
|
|
|
/* Setup Routine */
|
2016-07-18 14:47:32 +02:00
|
|
|
helper::confRestore();
|
2015-09-26 17:57:46 +02:00
|
|
|
$options = parse_ini_file(CONF, true);
|
2016-07-18 14:47:32 +02:00
|
|
|
$options['purge']['limit'] = 0;
|
2015-09-26 17:57:46 +02:00
|
|
|
$options['model'] = array(
|
2016-07-11 11:58:15 +02:00
|
|
|
'class' => 'privatebin_db',
|
2015-09-26 17:57:46 +02:00
|
|
|
);
|
|
|
|
$options['model_options'] = array(
|
|
|
|
'dsn' => 'sqlite::memory:',
|
|
|
|
'usr' => null,
|
|
|
|
'pwd' => null,
|
|
|
|
'opt' => array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION),
|
|
|
|
);
|
|
|
|
helper::confBackup();
|
|
|
|
helper::createIniFile(CONF, $options);
|
|
|
|
$this->_conf = new configuration;
|
|
|
|
$this->_model = new model($this->_conf);
|
2015-09-27 03:03:55 +02:00
|
|
|
$_SERVER['REMOTE_ADDR'] = '::1';
|
2015-09-26 17:57:46 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function tearDown()
|
|
|
|
{
|
|
|
|
/* Tear Down Routine */
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testBasicWorkflow()
|
|
|
|
{
|
|
|
|
// storing pastes
|
|
|
|
$pasteData = helper::getPaste();
|
|
|
|
$this->_model->getPaste(helper::getPasteId())->delete();
|
|
|
|
$paste = $this->_model->getPaste(helper::getPasteId());
|
|
|
|
$this->assertFalse($paste->exists(), 'paste does not yet exist');
|
|
|
|
|
|
|
|
$paste = $this->_model->getPaste();
|
|
|
|
$paste->setData($pasteData['data']);
|
|
|
|
$paste->setOpendiscussion();
|
|
|
|
$paste->setFormatter($pasteData['meta']['formatter']);
|
|
|
|
$paste->store();
|
|
|
|
|
|
|
|
$paste = $this->_model->getPaste(helper::getPasteId());
|
|
|
|
$this->assertTrue($paste->exists(), 'paste exists after storing it');
|
|
|
|
$paste = $paste->get();
|
2015-09-27 03:03:55 +02:00
|
|
|
$this->assertEquals($pasteData['data'], $paste->data);
|
|
|
|
foreach (array('opendiscussion', 'formatter') as $key) {
|
|
|
|
$this->assertEquals($pasteData['meta'][$key], $paste->meta->$key);
|
2015-09-26 17:57:46 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// storing comments
|
|
|
|
$commentData = helper::getComment();
|
2015-09-27 03:03:55 +02:00
|
|
|
$paste = $this->_model->getPaste(helper::getPasteId());
|
2015-09-26 17:57:46 +02:00
|
|
|
$comment = $paste->getComment(helper::getPasteId(), helper::getCommentId());
|
|
|
|
$this->assertFalse($comment->exists(), 'comment does not yet exist');
|
|
|
|
|
|
|
|
$comment = $paste->getComment(helper::getPasteId());
|
|
|
|
$comment->setData($commentData['data']);
|
|
|
|
$comment->setNickname($commentData['meta']['nickname']);
|
|
|
|
$comment->store();
|
|
|
|
|
|
|
|
$comment = $paste->getComment(helper::getPasteId(), helper::getCommentId());
|
|
|
|
$this->assertTrue($comment->exists(), 'comment exists after storing it');
|
|
|
|
$comment = $comment->get();
|
|
|
|
$this->assertEquals($commentData['data'], $comment->data);
|
|
|
|
$this->assertEquals($commentData['meta']['nickname'], $comment->meta->nickname);
|
|
|
|
|
|
|
|
// deleting pastes
|
|
|
|
$this->_model->getPaste(helper::getPasteId())->delete();
|
|
|
|
$paste = $this->_model->getPaste(helper::getPasteId());
|
|
|
|
$this->assertFalse($paste->exists(), 'paste successfully deleted');
|
|
|
|
$this->assertEquals(array(), $paste->getComments(), 'comment was deleted with paste');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @expectedException Exception
|
2015-09-27 03:03:55 +02:00
|
|
|
* @expectedExceptionCode 75
|
2015-09-26 17:57:46 +02:00
|
|
|
*/
|
|
|
|
public function testPasteDuplicate()
|
|
|
|
{
|
|
|
|
$pasteData = helper::getPaste();
|
|
|
|
|
|
|
|
$this->_model->getPaste(helper::getPasteId())->delete();
|
|
|
|
$paste = $this->_model->getPaste();
|
|
|
|
$paste->setData($pasteData['data']);
|
|
|
|
$paste->setOpendiscussion();
|
|
|
|
$paste->setFormatter($pasteData['meta']['formatter']);
|
|
|
|
$paste->store();
|
|
|
|
|
|
|
|
$paste = $this->_model->getPaste();
|
|
|
|
$paste->setData($pasteData['data']);
|
|
|
|
$paste->setOpendiscussion();
|
|
|
|
$paste->setFormatter($pasteData['meta']['formatter']);
|
|
|
|
$paste->store();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @expectedException Exception
|
2015-09-27 03:03:55 +02:00
|
|
|
* @expectedExceptionCode 69
|
2015-09-26 17:57:46 +02:00
|
|
|
*/
|
|
|
|
public function testCommentDuplicate()
|
|
|
|
{
|
|
|
|
$pasteData = helper::getPaste();
|
|
|
|
$commentData = helper::getComment();
|
|
|
|
$this->_model->getPaste(helper::getPasteId())->delete();
|
|
|
|
|
|
|
|
$paste = $this->_model->getPaste();
|
|
|
|
$paste->setData($pasteData['data']);
|
|
|
|
$paste->setOpendiscussion();
|
|
|
|
$paste->setFormatter($pasteData['meta']['formatter']);
|
|
|
|
$paste->store();
|
|
|
|
|
|
|
|
$comment = $paste->getComment(helper::getPasteId());
|
|
|
|
$comment->setData($commentData['data']);
|
|
|
|
$comment->setNickname($commentData['meta']['nickname']);
|
|
|
|
$comment->store();
|
|
|
|
|
|
|
|
$comment = $paste->getComment(helper::getPasteId());
|
|
|
|
$comment->setData($commentData['data']);
|
|
|
|
$comment->setNickname($commentData['meta']['nickname']);
|
|
|
|
$comment->store();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testImplicitDefaults()
|
|
|
|
{
|
|
|
|
$pasteData = helper::getPaste();
|
|
|
|
$commentData = helper::getComment();
|
|
|
|
$this->_model->getPaste(helper::getPasteId())->delete();
|
|
|
|
|
|
|
|
$paste = $this->_model->getPaste();
|
|
|
|
$paste->setData($pasteData['data']);
|
|
|
|
$paste->setBurnafterreading();
|
|
|
|
$paste->setOpendiscussion();
|
|
|
|
// not setting a formatter, should use default one
|
|
|
|
$paste->store();
|
|
|
|
|
|
|
|
$paste = $this->_model->getPaste(helper::getPasteId())->get(); // ID was set based on data
|
2015-09-27 03:03:55 +02:00
|
|
|
$this->assertEquals(true, property_exists($paste->meta, 'burnafterreading') && $paste->meta->burnafterreading, 'burn after reading takes precendence');
|
|
|
|
$this->assertEquals(false, property_exists($paste->meta, 'opendiscussion') && $paste->meta->opendiscussion, 'opendiscussion is disabled');
|
2015-09-26 17:57:46 +02:00
|
|
|
$this->assertEquals($this->_conf->getKey('defaultformatter'), $paste->meta->formatter, 'default formatter is set');
|
|
|
|
|
2015-09-27 03:03:55 +02:00
|
|
|
$this->_model->getPaste(helper::getPasteId())->delete();
|
|
|
|
$paste = $this->_model->getPaste();
|
|
|
|
$paste->setData($pasteData['data']);
|
2015-09-27 14:36:20 +02:00
|
|
|
$paste->setBurnafterreading('0');
|
2015-09-27 03:03:55 +02:00
|
|
|
$paste->setOpendiscussion();
|
|
|
|
$paste->store();
|
|
|
|
|
2015-09-26 17:57:46 +02:00
|
|
|
$vz = new vizhash16x16();
|
|
|
|
$pngdata = 'data:image/png;base64,' . base64_encode($vz->generate($_SERVER['REMOTE_ADDR']));
|
2015-09-27 03:03:55 +02:00
|
|
|
$comment = $paste->getComment(helper::getPasteId());
|
2015-09-26 17:57:46 +02:00
|
|
|
$comment->setData($commentData['data']);
|
|
|
|
$comment->setNickname($commentData['meta']['nickname']);
|
|
|
|
$comment->store();
|
|
|
|
|
2015-09-27 03:03:55 +02:00
|
|
|
$comment = $paste->getComment(helper::getPasteId(), helper::getCommentId())->get();
|
2015-09-26 17:57:46 +02:00
|
|
|
$this->assertEquals($pngdata, $comment->meta->vizhash, 'nickname triggers vizhash to be set');
|
|
|
|
}
|
2015-09-27 03:03:55 +02:00
|
|
|
|
|
|
|
public function testPasteIdValidation()
|
|
|
|
{
|
2016-07-21 17:09:48 +02:00
|
|
|
$this->assertTrue(paste::isValidId('a242ab7bdfb2581a'), 'valid paste id');
|
|
|
|
$this->assertFalse(paste::isValidId('foo'), 'invalid hex values');
|
|
|
|
$this->assertFalse(paste::isValidId('../bar/baz'), 'path attack');
|
2015-09-27 03:03:55 +02:00
|
|
|
}
|
2015-09-27 14:36:20 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @expectedException Exception
|
|
|
|
* @expectedExceptionCode 62
|
|
|
|
*/
|
|
|
|
public function testInvalidComment()
|
|
|
|
{
|
|
|
|
$paste = $this->_model->getPaste();
|
2016-07-04 20:46:45 +02:00
|
|
|
$paste->getComment(helper::getPasteId());
|
2015-09-27 14:36:20 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testExpiration()
|
|
|
|
{
|
|
|
|
$pasteData = helper::getPaste();
|
|
|
|
$this->_model->getPaste(helper::getPasteId())->delete();
|
|
|
|
$paste = $this->_model->getPaste(helper::getPasteId());
|
|
|
|
$this->assertFalse($paste->exists(), 'paste does not yet exist');
|
|
|
|
|
|
|
|
$paste = $this->_model->getPaste();
|
|
|
|
$paste->setData($pasteData['data']);
|
|
|
|
$paste->setExpiration('5min'); // = 300 seconds
|
|
|
|
$paste->store();
|
|
|
|
|
|
|
|
$paste = $paste->get();
|
|
|
|
$this->assertEquals(300, $paste->meta->remaining_time, 'remaining time is set correctly');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @expectedException Exception
|
|
|
|
* @expectedExceptionCode 64
|
|
|
|
*/
|
|
|
|
public function testCommentDeletion()
|
|
|
|
{
|
|
|
|
$pasteData = helper::getPaste();
|
|
|
|
$this->_model->getPaste(helper::getPasteId())->delete();
|
|
|
|
|
|
|
|
$paste = $this->_model->getPaste();
|
|
|
|
$paste->setData($pasteData['data']);
|
|
|
|
$paste->store();
|
|
|
|
$paste->getComment(helper::getPasteId())->delete();
|
|
|
|
}
|
2016-07-18 10:14:38 +02:00
|
|
|
|
2016-07-18 14:47:32 +02:00
|
|
|
public function testPurge()
|
|
|
|
{
|
|
|
|
$conf = new configuration;
|
2016-07-21 17:09:48 +02:00
|
|
|
$store = db::getInstance($conf->getSection('model_options'));
|
2016-07-18 14:47:32 +02:00
|
|
|
$store->delete(helper::getPasteId());
|
|
|
|
$expired = helper::getPaste(array('expire_date' => 1344803344));
|
|
|
|
$paste = helper::getPaste(array('expire_date' => time() + 3600));
|
|
|
|
$keys = array('a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'x', 'y', 'z');
|
|
|
|
$ids = array();
|
|
|
|
foreach ($keys as $key)
|
|
|
|
{
|
|
|
|
$ids[$key] = substr(md5($key), 0, 16);
|
|
|
|
$store->delete($ids[$key]);
|
|
|
|
$this->assertFalse($store->exists($ids[$key]), "paste $key does not yet exist");
|
|
|
|
if (in_array($key, array('x', 'y', 'z')))
|
|
|
|
{
|
|
|
|
$this->assertTrue($store->create($ids[$key], $paste), "store $key paste");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$this->assertTrue($store->create($ids[$key], $expired), "store $key paste");
|
|
|
|
}
|
|
|
|
$this->assertTrue($store->exists($ids[$key]), "paste $key exists after storing it");
|
|
|
|
}
|
|
|
|
$this->_model->purge(10);
|
2016-07-19 08:40:33 +02:00
|
|
|
foreach ($ids as $key => $id)
|
2016-07-18 14:47:32 +02:00
|
|
|
{
|
|
|
|
if (in_array($key, array('x', 'y', 'z')))
|
|
|
|
{
|
2016-07-19 08:40:33 +02:00
|
|
|
$this->assertTrue($this->_model->getPaste($id)->exists(), "paste $key exists after purge");
|
|
|
|
$this->_model->getPaste($id)->delete();
|
2016-07-18 14:47:32 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2016-07-19 08:40:33 +02:00
|
|
|
$this->assertFalse($this->_model->getPaste($id)->exists(), "paste $key was purged");
|
2016-07-18 14:47:32 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-07-18 10:14:38 +02:00
|
|
|
public function testCommentWithDisabledVizhash()
|
|
|
|
{
|
|
|
|
$options = parse_ini_file(CONF, true);
|
|
|
|
$options['main']['vizhash'] = false;
|
|
|
|
$options['model'] = array(
|
|
|
|
'class' => 'privatebin_db',
|
|
|
|
);
|
|
|
|
$options['model_options'] = array(
|
|
|
|
'dsn' => 'sqlite::memory:',
|
|
|
|
'usr' => null,
|
|
|
|
'pwd' => null,
|
|
|
|
'opt' => array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION),
|
|
|
|
);
|
|
|
|
helper::confBackup();
|
|
|
|
helper::createIniFile(CONF, $options);
|
|
|
|
$model = new model(new configuration);
|
|
|
|
|
|
|
|
$pasteData = helper::getPaste();
|
|
|
|
$this->_model->getPaste(helper::getPasteId())->delete();
|
|
|
|
$paste = $model->getPaste(helper::getPasteId());
|
|
|
|
$this->assertFalse($paste->exists(), 'paste does not yet exist');
|
|
|
|
|
|
|
|
$paste = $model->getPaste();
|
|
|
|
$paste->setData($pasteData['data']);
|
|
|
|
$paste->setOpendiscussion();
|
|
|
|
$paste->setFormatter($pasteData['meta']['formatter']);
|
|
|
|
$paste->store();
|
|
|
|
|
|
|
|
$paste = $model->getPaste(helper::getPasteId());
|
|
|
|
$this->assertTrue($paste->exists(), 'paste exists after storing it');
|
|
|
|
$paste = $paste->get();
|
|
|
|
$this->assertEquals($pasteData['data'], $paste->data);
|
|
|
|
foreach (array('opendiscussion', 'formatter') as $key) {
|
|
|
|
$this->assertEquals($pasteData['meta'][$key], $paste->meta->$key);
|
|
|
|
}
|
|
|
|
|
|
|
|
// storing comments
|
|
|
|
$commentData = helper::getComment();
|
|
|
|
$paste = $model->getPaste(helper::getPasteId());
|
|
|
|
$comment = $paste->getComment(helper::getPasteId(), helper::getCommentId());
|
|
|
|
$this->assertFalse($comment->exists(), 'comment does not yet exist');
|
|
|
|
|
|
|
|
$comment = $paste->getComment(helper::getPasteId());
|
|
|
|
$comment->setData($commentData['data']);
|
|
|
|
$comment->setNickname($commentData['meta']['nickname']);
|
|
|
|
$comment->store();
|
|
|
|
|
|
|
|
$comment = $paste->getComment(helper::getPasteId(), helper::getCommentId());
|
|
|
|
$this->assertTrue($comment->exists(), 'comment exists after storing it');
|
|
|
|
$comment = $comment->get();
|
|
|
|
$this->assertEquals($commentData['data'], $comment->data);
|
|
|
|
$this->assertEquals($commentData['meta']['nickname'], $comment->meta->nickname);
|
|
|
|
$this->assertFalse(property_exists($comment->meta, 'vizhash'), 'vizhash was not generated');
|
|
|
|
}
|
2016-07-11 14:15:20 +02:00
|
|
|
}
|