Fix a lot of notices/warnings/deprecation notes in the test directory

This commit is contained in:
Philipp 2020-10-18 20:31:57 +02:00
parent efaec26b1d
commit d55ecb9288
No known key found for this signature in database
GPG key ID: 9A28B7D4FF5667BD
77 changed files with 428 additions and 558 deletions

View file

@ -58,6 +58,7 @@ class Database
protected $connection; protected $connection;
protected $driver; protected $driver;
protected $emulate_prepares = false; protected $emulate_prepares = false;
protected $pdo_emulate_prepares = false;
private $error = false; private $error = false;
private $errorno = 0; private $errorno = 0;
private $affected_rows = 0; private $affected_rows = 0;

View file

@ -25,6 +25,7 @@ use Dice\Dice;
use Friendica\App; use Friendica\App;
use Friendica\Core\Config; use Friendica\Core\Config;
use Friendica\DI; use Friendica\DI;
use Friendica\Network\HTTPException\InternalServerErrorException;
use Friendica\Render\FriendicaSmartyEngine; use Friendica\Render\FriendicaSmartyEngine;
use Friendica\Util\Profiler; use Friendica\Util\Profiler;
use Mockery\MockInterface; use Mockery\MockInterface;
@ -64,7 +65,9 @@ trait AppMockTrait
* Mock the App * Mock the App
* *
* @param vfsStreamDirectory $root The root directory * @param vfsStreamDirectory $root The root directory
* @param bool $raw If true, no config mocking will be done * @param bool $raw If true, no config mocking will be done
*
* @throws InternalServerErrorException
*/ */
public function mockApp(vfsStreamDirectory $root, $raw = false) public function mockApp(vfsStreamDirectory $root, $raw = false)
{ {

View file

@ -81,11 +81,11 @@ trait DBAMockTrait
/** /**
* Mocking DBA::fetchFirst() * Mocking DBA::fetchFirst()
* *
* @param string $arg The argument of fetchFirst * @param string $arg The argument of fetchFirst
* @param bool $return True, if the DB is connected, otherwise false * @param bool $return True, if the DB is connected, otherwise false
* @param null|int $times How often the method will get used * @param null|int $times How often the method will get used
*/ */
public function mockFetchFirst($arg, $return = true, $times = null) public function mockFetchFirst(string $arg, bool $return = true, int $times = null)
{ {
$this->checkMock(); $this->checkMock();
@ -139,13 +139,13 @@ trait DBAMockTrait
/** /**
* Mocking DBA::select() * Mocking DBA::select()
* *
* @param string $tableName The name of the table * @param string $tableName The name of the table
* @param array $select The Select Array (Default is []) * @param array $select The Select Array (Default is [])
* @param array $where The Where Array (Default is []) * @param array $where The Where Array (Default is [])
* @param object $return The array to return (Default is []) * @param object $return The array to return (Default is [])
* @param null|int $times How often the method will get used * @param null|int $times How often the method will get used
*/ */
public function mockSelect($tableName, $select = [], $where = [], $return = null, $times = null) public function mockSelect(string $tableName, array $select = [], array $where = [], $return = null, int $times = null)
{ {
$this->checkMock(); $this->checkMock();
@ -159,12 +159,12 @@ trait DBAMockTrait
/** /**
* Mocking DBA::delete() * Mocking DBA::delete()
* *
* @param string $tableName The name of the table * @param string $tableName The name of the table
* @param array $where The Where Array (Default is []) * @param array $where The Where Array (Default is [])
* @param bool $return The array to return (Default is true) * @param bool $return The array to return (Default is true)
* @param null|int $times How often the method will get used * @param null|int $times How often the method will get used
*/ */
public function mockDBADelete($tableName, $where = [], $return = true, $times = null) public function mockDBADelete(string $tableName, array $where = [], bool $return = true, int $times = null)
{ {
$this->checkMock(); $this->checkMock();
@ -178,14 +178,14 @@ trait DBAMockTrait
/** /**
* Mocking DBA::update() * Mocking DBA::update()
* *
* @param string $expTableName The name of the table * @param string $expTableName The name of the table
* @param array $expFields The Fields Array * @param array $expFields The Fields Array
* @param array $expCondition The Condition Array * @param array $expCondition The Condition Array
* @param array $expOld_fields The Old Fieldnames (Default is []) * @param array $expOld_fields The Old Fieldnames (Default is [])
* @param bool $return true if the update was successful * @param bool $return true if the update was successful
* @param null|int $times How often the method will get used * @param null|int $times How often the method will get used
*/ */
public function mockDBAUpdate($expTableName, $expFields, $expCondition, $expOld_fields = [], $return = true, $times = null) public function mockDBAUpdate(string $expTableName, array $expFields, array $expCondition, array $expOld_fields = [], bool $return = true, int $times = null)
{ {
$this->checkMock(); $this->checkMock();
@ -207,13 +207,13 @@ trait DBAMockTrait
/** /**
* Mocking DBA::insert() * Mocking DBA::insert()
* *
* @param string $expTableName The name of the table * @param string $expTableName The name of the table
* @param array $expParam The Parameters Array * @param array $expParam The Parameters Array
* @param bool $expOnDuplUpdate Update on a duplicated entry * @param bool $expOnDuplUpdate Update on a duplicated entry
* @param bool $return True if the insert was successful * @param bool $return True if the insert was successful
* @param null|int $times How often the method will get used * @param null|int $times How often the method will get used
*/ */
public function mockDBAInsert($expTableName, $expParam, $expOnDuplUpdate = false, $return = true, $times = null) public function mockDBAInsert(string $expTableName, array $expParam, bool $expOnDuplUpdate = false, bool $return = true, int $times = null)
{ {
$this->checkMock(); $this->checkMock();
@ -234,13 +234,13 @@ trait DBAMockTrait
/** /**
* Mocking DBA::selectFirst() * Mocking DBA::selectFirst()
* *
* @param string $expTableName The name of the table * @param string $expTableName The name of the table
* @param array $expSelect The Select Array (Default is []) * @param array $expSelect The Select Array (Default is [])
* @param array $expWhere The Where Array (Default is []) * @param array $expWhere The Where Array (Default is [])
* @param array $return The array to return (Default is []) * @param array $return The array to return (Default is [])
* @param null|int $times How often the method will get used * @param null|int $times How often the method will get used
*/ */
public function mockSelectFirst($expTableName, $expSelect = [], $expWhere = [], $return = [], $times = null) public function mockSelectFirst(string $expTableName, array $expSelect = [], array $expWhere = [], array $return = [], int $times = null)
{ {
$this->checkMock(); $this->checkMock();
@ -321,11 +321,11 @@ trait DBAMockTrait
/** /**
* Mocking DBA::lock() * Mocking DBA::lock()
* *
* @param string $table The table to lock * @param string $table The table to lock
* @param bool $return True, if the lock is set successful * @param bool $return True, if the lock is set successful
* @param null|int $times How often the method will get used * @param null|int $times How often the method will get used
*/ */
public function mockDbaLock($table, $return = true, $times = null) public function mockDbaLock(string $table, bool $return = true, int $times = null)
{ {
$this->checkMock(); $this->checkMock();

View file

@ -42,7 +42,7 @@ trait DBStructureMockTrait
* @param bool $return True, if the connect was successful, otherwise false * @param bool $return True, if the connect was successful, otherwise false
* @param null|int $times How often the method will get used * @param null|int $times How often the method will get used
*/ */
public function mockUpdate($args = [], $return = true, $times = null) public function mockUpdate(array $args = [], bool $return = true, int $times = null)
{ {
if (!isset($this->dbStructure)) { if (!isset($this->dbStructure)) {
$this->dbStructure = \Mockery::mock('alias:' . DBStructure::class); $this->dbStructure = \Mockery::mock('alias:' . DBStructure::class);
@ -58,11 +58,11 @@ trait DBStructureMockTrait
/** /**
* Mocking DBStructure::existsTable() * Mocking DBStructure::existsTable()
* *
* @param string $tableName The name of the table to check * @param string $tableName The name of the table to check
* @param bool $return True, if the connect was successful, otherwise false * @param bool $return True, if the connect was successful, otherwise false
* @param null|int $times How often the method will get used * @param null|int $times How often the method will get used
*/ */
public function mockExistsTable($tableName, $return = true, $times = null) public function mockExistsTable(string $tableName, bool $return = true, int $times = null)
{ {
if (!isset($this->dbStructure)) { if (!isset($this->dbStructure)) {
$this->dbStructure = \Mockery::mock('alias:' . DBStructure::class); $this->dbStructure = \Mockery::mock('alias:' . DBStructure::class);

View file

@ -33,7 +33,7 @@ class ExtendedPDO extends PDO
/** /**
* @var array Database drivers that support SAVEPOINT * statements. * @var array Database drivers that support SAVEPOINT * statements.
*/ */
protected static $_supportedDrivers = array("pgsql", "mysql"); protected static $_supportedDrivers = ["pgsql", "mysql"];
/** /**
* @var int the current transaction depth * @var int the current transaction depth

View file

@ -22,6 +22,7 @@
namespace Friendica\Test\Util\Database; namespace Friendica\Test\Util\Database;
use Friendica\Database\Database; use Friendica\Database\Database;
use Friendica\Database\DatabaseException;
use PDO; use PDO;
use PDOException; use PDOException;
@ -80,7 +81,7 @@ class StaticDatabase extends Database
/** /**
* Does a commit * Does a commit
* *
* @return boolean Was the command executed successfully? * @return bool Was the command executed successfully?
*/ */
public function commit() public function commit()
{ {
@ -96,6 +97,8 @@ class StaticDatabase extends Database
* Either through explicit calling or through implicit using the Database * Either through explicit calling or through implicit using the Database
* *
* @param array $server $_SERVER variables * @param array $server $_SERVER variables
*
* @throws \Exception
*/ */
public static function statConnect(array $server) public static function statConnect(array $server)
{ {
@ -119,6 +122,10 @@ class StaticDatabase extends Database
$db_data = $server['MYSQL_DATABASE']; $db_data = $server['MYSQL_DATABASE'];
} }
if (empty($db_host) || empty($db_user) || empty($db_data)) {
throw new DatabaseException('Either one of the following settings are missing: Host, User or Database', 999, 'CONNECT');
}
$port = 0; $port = 0;
$serveraddr = trim($db_host); $serveraddr = trim($db_host);
$serverdata = explode(':', $serveraddr); $serverdata = explode(':', $serveraddr);
@ -128,7 +135,7 @@ class StaticDatabase extends Database
} }
$server = trim($server); $server = trim($server);
$user = trim($db_user); $user = trim($db_user);
$pass = trim($db_pw); $pass = trim($db_pw ?? '');
$db = trim($db_data); $db = trim($db_data);
if (!(strlen($server) && strlen($user))) { if (!(strlen($server) && strlen($user))) {

View file

@ -1,103 +0,0 @@
<?php
/**
* @copyright Copyright (C) 2020, Friendica
*
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*
*/
namespace Friendica\Test\Util;
use Friendica\Core\Cache\Duration;
trait DbaCacheMockTrait
{
/**
* @var
*/
protected $dba;
public function __construct()
{
}
protected function mockDelete($key, $return = true, $times = null)
{
$this->mockDBADelete('cache', ['k' => $key], $return, $times);
}
protected function mockGet($key, $return = null, $time = null, $times = null)
{
if ($time === null) {
$time = time();
}
$value = @serialize($return);
$this->mockSelectFirst('cache', ['v'], ['`k` = ? AND (`expires` >= ? OR `expires` = -1)', $key, $time], ['v' => $value], $times);
$this->mockIsResult(['v' => $value], isset($return), $times);
}
protected function mockSet($key, $value, $ttl = Duration::FIVE_MINUTES, $time = null, $return = true, $times = null)
{
if ($time === null) {
$time = time();
}
if ($ttl > 0) {
$this->mockUtc('now + ' . $ttl . 'seconds', $time + $ttl, $times);
$fields = [
'v' => serialize($value),
'expires' => $time + $ttl,
'updated' => $time
];
} else {
$fields = [
'v' => serialize($value),
'expires' => -1,
'updated' => $time
];
}
$this->mockDBAUpdate('cache', $fields, ['k' => $key], true, $return, $times);
}
protected function mockClear($outdated = true, $return = true, $times = null)
{
if ($outdated) {
$this->mockDBADelete('cache', ['`expires` < NOW()'], $return, $times);
} else {
$this->mockDBADelete('cache', ['`k` IS NOT NULL '], $return, $times);
}
}
protected function mockGetAllKeys($prefix = null, $return = [], $time = null, $times = null)
{
if ($time === null) {
$time = time();
}
if (empty($prefix)) {
$where = ['`expires` >= ?', $time];
} else {
$where = ['`expires` >= ? AND `k` LIKE CONCAT(?, \'%\')', $time, $prefix];
}
$this->mockSelect('cache', ['k'], $where, $return, $times);
$this->mockFetchLoop($return, $times);
$this->mockDbaClose(true, $times);
}
}

View file

@ -1,136 +0,0 @@
<?php
/**
* @copyright Copyright (C) 2020, Friendica
*
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*
*/
namespace Friendica\Test\Util;
use Friendica\Core\Cache\Duration;
use Friendica\Core\Lock\DatabaseLock;
trait DbaLockMockTrait
{
use DBAMockTrait;
use DateTimeFormatMockTrait;
/**
* Mocking acquireLock with DBA-backend
*
* @param mixed $key The key to lock
* @param int $ttl The TimeToLive
*
* @param bool $locked Was the lock already set?
* @param null $pid The PID which was set
* @param bool $rowExists True, if a row already exists in the lock table
* @param null $time The current timestamp
* @param null|int $times How often the method will get used
*
*@see DatabaseLock::acquire()
*
*/
public function mockAcquireLock($key, $ttl = Duration::FIVE_MINUTES, $locked = false, $pid = null, $rowExists = true, $time = null, $times = null)
{
if ($time === null) {
$time = time();
}
if ($pid === null) {
$pid = getmypid();
}
$this->mockDbaLock('locks', true, $times);
$this->mockUtcNow($time, $times);
$result = ['locked' => $locked, 'pid' => $pid];
$this->mockSelectFirst('locks', ['locked', 'pid'], ['`name` = ? AND `expires` >= ?', $key, $time], $result, $times);
$this->mockIsResult($result, $rowExists, $times);
if ($rowExists) {
if (!$locked ) {
$this->mockUtc('now + ' . $ttl . 'seconds', $time, $times);
$this->mockDBAUpdate('locks', ['locked' => true, 'pid' => $pid, 'expires' => $time], ['name' => $key], [], true, $times);
}
} else {
$this->mockUtc('now + ' . $ttl . 'seconds', $time, $times);
$this->mockDBAInsert('locks', ['name' => $key, 'locked' => true, 'pid' => $pid, 'expires' => $time], false, true, $times);
}
$this->mockDbaUnlock($times);
}
/**
* Mocking isLocked with DBA-backend
*
* @param mixed $key The key of the lock
* @param null|bool $return True, if the key is already locked
* @param null $time The current timestamp
* @param null|int $times How often the method will get used
*
*@see DatabaseLock::isLocked()
*
*/
public function mockIsLocked($key, $return = true, $time = null, $times = null)
{
if ($time === null) {
$time = time();
}
$this->mockUtcNow($time, $times);
$return = ((isset($return)) ? ['locked' => $return] : null);
$this->mockSelectFirst('locks', ['locked'], ['`name` = ? AND `expires` >= ?', $key, $time], $return, $times);
$this->mockIsResult($return, (isset($return) && $return), $times);
}
/**
* Mocking releaseAll with DBA-backend
*
* @param null $pid The PID which was set
* @param null|int $times How often the method will get used
*
*@see DatabaseLock::releaseAll()
*
*/
public function mockReleaseAll($pid = null, $times = null)
{
if ($pid === null) {
$pid = getmypid();
}
$this->mockDBADelete('locks', ['pid' => $pid], true, $times);
}
/**
* Mocking ReleaseLock with DBA-backend
*
* @param mixed $key The key to release
* @param null|int $pid The PID which was set
* @param null|int $times How often the method will get used
*
*@see DatabaseLock::release()
*
*/
public function mockReleaseLock($key, $pid = null, $times = null)
{
if ($pid === null) {
$pid = getmypid();
}
$this->mockDBADelete('locks', ['name' => $key, 'pid' => $pid], true, $times);
}
}

View file

@ -8,6 +8,18 @@ class EmailerSpy extends Emailer
{ {
public static $MAIL_DATA; public static $MAIL_DATA;
/**
* Wrapper around the mail() method (mainly used to overwrite for tests)
* @see mail()
*
* @param string $to Recipient of this mail
* @param string $subject Subject of this mail
* @param string $body Message body of this mail
* @param string $headers Headers of this mail
* @param string $parameters Additional (sendmail) parameters of this mail
*
* @return bool true if the mail was successfully accepted for delivery, false otherwise.
*/
protected function mail(string $to, string $subject, string $body, string $headers, string $parameters) protected function mail(string $to, string $subject, string $body, string $headers, string $parameters)
{ {
self::$MAIL_DATA = [ self::$MAIL_DATA = [

View file

@ -16,6 +16,8 @@ trait HookMockTrait
/** /**
* Mocking a method 'Hook::call()' call * Mocking a method 'Hook::call()' call
* *
* @param string $name
* @param mixed $capture
*/ */
public function mockHookCallAll(string $name, &$capture) public function mockHookCallAll(string $name, &$capture)
{ {

View file

@ -36,6 +36,7 @@ class Intercept extends php_user_filter
*/ */
public static $cache = ''; public static $cache = '';
/** @noinspection PhpMissingParentCallCommonInspection */
public function filter($in, $out, &$consumed, $closing) public function filter($in, $out, &$consumed, $closing)
{ {
while ($bucket = stream_bucket_make_writeable($in)) { while ($bucket = stream_bucket_make_writeable($in)) {

View file

@ -38,7 +38,7 @@ trait RendererMockTrait
* @param string $return the return value of the mock (should be defined to have it later for followUp use) * @param string $return the return value of the mock (should be defined to have it later for followUp use)
* @param null|int $times How often the method will get used * @param null|int $times How often the method will get used
*/ */
public function mockGetMarkupTemplate($templateName, $return = '', $times = null) public function mockGetMarkupTemplate(string $templateName, string $return = '', int $times = null)
{ {
if (!isset($this->rendererMock)) { if (!isset($this->rendererMock)) {
$this->rendererMock = \Mockery::mock('alias:' . Renderer::class); $this->rendererMock = \Mockery::mock('alias:' . Renderer::class);
@ -54,12 +54,12 @@ trait RendererMockTrait
/** /**
* Mocking the method 'Renderer::replaceMacros()' * Mocking the method 'Renderer::replaceMacros()'
* *
* @param string $template The template to use (normally, it is the mock result of 'mockGetMarkupTemplate()' * @param string $template The template to use (normally, it is the mock result of 'mockGetMarkupTemplate()'
* @param array|\Closure|null $args The arguments to pass to the macro * @param array|\Closure|null $args The arguments to pass to the macro
* @param string $return the return value of the mock * @param string $return the return value of the mock
* @param null|int $times How often the method will get used * @param null|int $times How often the method will get used
*/ */
public function mockReplaceMacros($template, $args = null, $return = '', $times = null) public function mockReplaceMacros(string $template, $args = null, string $return = '', int $times = null)
{ {
if (!isset($this->rendererMock)) { if (!isset($this->rendererMock)) {
$this->rendererMock = \Mockery::mock('alias:' . Renderer::class); $this->rendererMock = \Mockery::mock('alias:' . Renderer::class);

View file

@ -33,6 +33,20 @@ class StaticCookie extends Cookie
/** @var int The last expire time set */ /** @var int The last expire time set */
public static $_EXPIRE; public static $_EXPIRE;
/**
* Send a cookie - protected, internal function for test-mocking possibility
* @see Cookie::setCookie()
*
* @link https://php.net/manual/en/function.setcookie.php
*
* @param string $name
* @param string $value [optional]
* @param int $expire [optional]
* @param bool $secure [optional]
*
* @noinspection PhpMissingParentCallCommonInspection
*
*/
protected function setCookie(string $name, string $value = null, int $expire = null, bool $secure = null) protected function setCookie(string $name, string $value = null, int $expire = null, bool $secure = null)
{ {
self::$_COOKIE[$name] = $value; self::$_COOKIE[$name] = $value;

View file

@ -58,9 +58,9 @@ trait VFSTrait
* Copying a config file from the file system to the Virtual File System * Copying a config file from the file system to the Virtual File System
* *
* @param string $filename The filename of the config file * @param string $filename The filename of the config file
* @param bool $static True, if the folder `static` instead of `config` should be used * @param bool $static True, if the folder `static` instead of `config` should be used
*/ */
protected function setConfigFile($filename, bool $static = false) protected function setConfigFile(string $filename, bool $static = false)
{ {
$file = dirname(__DIR__) . DIRECTORY_SEPARATOR . $file = dirname(__DIR__) . DIRECTORY_SEPARATOR .
'..' . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR .
@ -78,9 +78,9 @@ trait VFSTrait
* Delets a config file from the Virtual File System * Delets a config file from the Virtual File System
* *
* @param string $filename The filename of the config file * @param string $filename The filename of the config file
* @param bool $static True, if the folder `static` instead of `config` should be used * @param bool $static True, if the folder `static` instead of `config` should be used
*/ */
protected function delConfigFile($filename, bool $static = false) protected function delConfigFile(string $filename, bool $static = false)
{ {
if ($this->root->hasChild(($static ? 'static' : 'config') . '/' . $filename)) { if ($this->root->hasChild(($static ? 'static' : 'config') . '/' . $filename)) {
$this->root->getChild(($static ? 'static' : 'config'))->removeChild($filename); $this->root->getChild(($static ? 'static' : 'config'))->removeChild($filename);

View file

@ -36,7 +36,7 @@ use Friendica\Util\Profiler;
use PHPUnit\Framework\TestCase; use PHPUnit\Framework\TestCase;
use Psr\Log\LoggerInterface; use Psr\Log\LoggerInterface;
class dependencyCheck extends TestCase class DependencyCheckTest extends TestCase
{ {
use VFSTrait; use VFSTrait;

View file

@ -24,12 +24,13 @@ namespace Friendica\Test\src\App;
use Detection\MobileDetect; use Detection\MobileDetect;
use Friendica\App\Mode; use Friendica\App\Mode;
use Friendica\App\Module; use Friendica\App\Module;
use Friendica\Core\Config; use Friendica\Core\Config\Cache;
use Friendica\Database\Database; use Friendica\Database\Database;
use Friendica\Test\MockedTest; use Friendica\Test\MockedTest;
use Friendica\Test\Util\DBAMockTrait; use Friendica\Test\Util\DBAMockTrait;
use Friendica\Test\Util\VFSTrait; use Friendica\Test\Util\VFSTrait;
use Friendica\Util\BasePath; use Friendica\Util\BasePath;
use Mockery;
use Mockery\MockInterface; use Mockery\MockInterface;
class ModeTest extends MockedTest class ModeTest extends MockedTest
@ -48,19 +49,19 @@ class ModeTest extends MockedTest
private $databaseMock; private $databaseMock;
/** /**
* @var \Friendica\Core\Config\Cache|MockInterface * @var Cache|MockInterface
*/ */
private $configCacheMock; private $configCacheMock;
public function setUp() protected function setUp()
{ {
parent::setUp(); parent::setUp();
$this->setUpVfsDir(); $this->setUpVfsDir();
$this->basePathMock = \Mockery::mock(BasePath::class); $this->basePathMock = Mockery::mock(BasePath::class);
$this->databaseMock = \Mockery::mock(Database::class); $this->databaseMock = Mockery::mock(Database::class);
$this->configCacheMock = \Mockery::mock(Config\Cache::class); $this->configCacheMock = Mockery::mock(Cache::class);
} }
public function testItEmpty() public function testItEmpty()
@ -280,7 +281,7 @@ class ModeTest extends MockedTest
{ {
$server = []; $server = [];
$module = new Module(Module::DEFAULT, Module::DEFAULT_CLASS, [], false); $module = new Module(Module::DEFAULT, Module::DEFAULT_CLASS, [], false);
$mobileDetect = \Mockery::mock(MobileDetect::class); $mobileDetect = Mockery::mock(MobileDetect::class);
$mobileDetect->shouldReceive('isMobile')->andReturn(true); $mobileDetect->shouldReceive('isMobile')->andReturn(true);
$mobileDetect->shouldReceive('isTablet')->andReturn(true); $mobileDetect->shouldReceive('isTablet')->andReturn(true);
@ -298,7 +299,7 @@ class ModeTest extends MockedTest
{ {
$server = []; $server = [];
$module = new Module(Module::DEFAULT, Module::DEFAULT_CLASS, [], false); $module = new Module(Module::DEFAULT, Module::DEFAULT_CLASS, [], false);
$mobileDetect = \Mockery::mock(MobileDetect::class); $mobileDetect = Mockery::mock(MobileDetect::class);
$mobileDetect->shouldReceive('isMobile')->andReturn(false); $mobileDetect->shouldReceive('isMobile')->andReturn(false);
$mobileDetect->shouldReceive('isTablet')->andReturn(false); $mobileDetect->shouldReceive('isTablet')->andReturn(false);

View file

@ -29,6 +29,7 @@ use Friendica\LegacyModule;
use Friendica\Module\HTTPException\PageNotFound; use Friendica\Module\HTTPException\PageNotFound;
use Friendica\Module\WellKnown\HostMeta; use Friendica\Module\WellKnown\HostMeta;
use Friendica\Test\DatabaseTest; use Friendica\Test\DatabaseTest;
use Mockery;
class ModuleTest extends DatabaseTest class ModuleTest extends DatabaseTest
{ {
@ -170,13 +171,13 @@ class ModuleTest extends DatabaseTest
*/ */
public function testModuleClass($assert, string $name, string $command, bool $privAdd) public function testModuleClass($assert, string $name, string $command, bool $privAdd)
{ {
$config = \Mockery::mock(IConfig::class); $config = Mockery::mock(IConfig::class);
$config->shouldReceive('get')->with('config', 'private_addons', false)->andReturn($privAdd)->atMost()->once(); $config->shouldReceive('get')->with('config', 'private_addons', false)->andReturn($privAdd)->atMost()->once();
$l10n = \Mockery::mock(L10n::class); $l10n = Mockery::mock(L10n::class);
$l10n->shouldReceive('t')->andReturnUsing(function ($args) { return $args; }); $l10n->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
$cache = \Mockery::mock(ICache::class); $cache = Mockery::mock(ICache::class);
$cache->shouldReceive('get')->with('routerDispatchData')->andReturn('')->atMost()->once(); $cache->shouldReceive('get')->with('routerDispatchData')->andReturn('')->atMost()->once();
$cache->shouldReceive('get')->with('lastRoutesFileModifiedTime')->andReturn('')->atMost()->once(); $cache->shouldReceive('get')->with('lastRoutesFileModifiedTime')->andReturn('')->atMost()->once();
$cache->shouldReceive('set')->withAnyArgs()->andReturn(false)->atMost()->twice(); $cache->shouldReceive('set')->withAnyArgs()->andReturn(false)->atMost()->twice();

View file

@ -27,6 +27,7 @@ use Friendica\Core\L10n;
use Friendica\Module; use Friendica\Module;
use Friendica\Network\HTTPException\MethodNotAllowedException; use Friendica\Network\HTTPException\MethodNotAllowedException;
use Friendica\Network\HTTPException\NotFoundException; use Friendica\Network\HTTPException\NotFoundException;
use Mockery;
use Mockery\MockInterface; use Mockery\MockInterface;
use PHPUnit\Framework\TestCase; use PHPUnit\Framework\TestCase;
@ -43,10 +44,10 @@ class RouterTest extends TestCase
{ {
parent::setUp(); parent::setUp();
$this->l10n = \Mockery::mock(L10n::class); $this->l10n = Mockery::mock(L10n::class);
$this->l10n->shouldReceive('t')->andReturnUsing(function ($args) { return $args; }); $this->l10n->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
$this->cache = \Mockery::mock(ICache::class); $this->cache = Mockery::mock(ICache::class);
$this->cache->shouldReceive('get')->andReturn(null); $this->cache->shouldReceive('get')->andReturn(null);
$this->cache->shouldReceive('set')->andReturn(false); $this->cache->shouldReceive('set')->andReturn(false);
} }

View file

@ -35,6 +35,7 @@ use Friendica\Test\Util\DBStructureMockTrait;
use Friendica\Test\Util\RendererMockTrait; use Friendica\Test\Util\RendererMockTrait;
use Friendica\Test\Util\VFSTrait; use Friendica\Test\Util\VFSTrait;
use Friendica\Util\Logger\VoidLogger; use Friendica\Util\Logger\VoidLogger;
use Mockery;
use Mockery\MockInterface; use Mockery\MockInterface;
use org\bovigo\vfs\vfsStream; use org\bovigo\vfs\vfsStream;
use org\bovigo\vfs\vfsStreamFile; use org\bovigo\vfs\vfsStreamFile;
@ -77,7 +78,7 @@ class AutomaticInstallationConsoleTest extends ConsoleTest
public function setUp() public function setUp()
{ {
$this->markTestSkipped('Needs class \'Installer\' as constructing argument for console tests'); static::markTestSkipped('Needs class \'Installer\' as constructing argument for console tests');
parent::setUp(); parent::setUp();
@ -87,9 +88,9 @@ class AutomaticInstallationConsoleTest extends ConsoleTest
$this->root->getChild('config') $this->root->getChild('config')
->removeChild('local.config.php'); ->removeChild('local.config.php');
} }
$this->dice = \Mockery::mock(Dice::class)->makePartial(); $this->dice = Mockery::mock(Dice::class)->makePartial();
$l10nMock = \Mockery::mock(L10n::class); $l10nMock = Mockery::mock(L10n::class);
$l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; }); $l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
$this->dice->shouldReceive('create') $this->dice->shouldReceive('create')
@ -400,7 +401,7 @@ FIN;
$this->mockUpdate([$this->root->url(), false, true, true], null, 1); $this->mockUpdate([$this->root->url(), false, true, true], null, 1);
$this->mockGetMarkupTemplate('local.config.tpl', 'testTemplate', 1); $this->mockGetMarkupTemplate('local.config.tpl', 'testTemplate', 1);
$this->mockReplaceMacros('testTemplate', \Mockery::any(), '', 1); $this->mockReplaceMacros('testTemplate', Mockery::any(), '', 1);
$console = new AutomaticInstallation($this->consoleArgv); $console = new AutomaticInstallation($this->consoleArgv);
$console->setOption('url', 'http://friendica.local'); $console->setOption('url', 'http://friendica.local');
@ -502,7 +503,7 @@ CONF;
$this->mockUpdate([$this->root->url(), false, true, true], null, 1); $this->mockUpdate([$this->root->url(), false, true, true], null, 1);
$this->mockGetMarkupTemplate('local.config.tpl', 'testTemplate', 1); $this->mockGetMarkupTemplate('local.config.tpl', 'testTemplate', 1);
$this->mockReplaceMacros('testTemplate', \Mockery::any(), '', 1); $this->mockReplaceMacros('testTemplate', Mockery::any(), '', 1);
self::assertTrue(putenv('MYSQL_HOST=' . $data['database']['hostname'])); self::assertTrue(putenv('MYSQL_HOST=' . $data['database']['hostname']));
self::assertTrue(putenv('MYSQL_PORT=' . $data['database']['port'])); self::assertTrue(putenv('MYSQL_PORT=' . $data['database']['port']));
@ -540,7 +541,7 @@ CONF;
$this->mockUpdate([$this->root->url(), false, true, true], null, 1); $this->mockUpdate([$this->root->url(), false, true, true], null, 1);
$this->mockGetMarkupTemplate('local.config.tpl', 'testTemplate', 1); $this->mockGetMarkupTemplate('local.config.tpl', 'testTemplate', 1);
$this->mockReplaceMacros('testTemplate', \Mockery::any(), '', 1); $this->mockReplaceMacros('testTemplate', Mockery::any(), '', 1);
self::assertTrue(putenv('MYSQL_HOST=' . $data['database']['hostname'])); self::assertTrue(putenv('MYSQL_HOST=' . $data['database']['hostname']));
self::assertTrue(putenv('MYSQL_PORT=' . $data['database']['port'])); self::assertTrue(putenv('MYSQL_PORT=' . $data['database']['port']));
@ -576,7 +577,7 @@ CONF;
$this->mockUpdate([$this->root->url(), false, true, true], null, 1); $this->mockUpdate([$this->root->url(), false, true, true], null, 1);
$this->mockGetMarkupTemplate('local.config.tpl', 'testTemplate', 1); $this->mockGetMarkupTemplate('local.config.tpl', 'testTemplate', 1);
$this->mockReplaceMacros('testTemplate', \Mockery::any(), '', 1); $this->mockReplaceMacros('testTemplate', Mockery::any(), '', 1);
$console = new AutomaticInstallation($this->consoleArgv); $console = new AutomaticInstallation($this->consoleArgv);
@ -611,7 +612,7 @@ CONF;
$this->mockConnect(false, 1); $this->mockConnect(false, 1);
$this->mockGetMarkupTemplate('local.config.tpl', 'testTemplate', 1); $this->mockGetMarkupTemplate('local.config.tpl', 'testTemplate', 1);
$this->mockReplaceMacros('testTemplate', \Mockery::any(), '', 1); $this->mockReplaceMacros('testTemplate', Mockery::any(), '', 1);
$console = new AutomaticInstallation($this->consoleArgv); $console = new AutomaticInstallation($this->consoleArgv);
$console->setOption('url', 'http://friendica.local'); $console->setOption('url', 'http://friendica.local');

View file

@ -25,6 +25,8 @@ use Friendica\App;
use Friendica\App\Mode; use Friendica\App\Mode;
use Friendica\Console\Config; use Friendica\Console\Config;
use Friendica\Core\Config\IConfig; use Friendica\Core\Config\IConfig;
use Mockery;
use Mockery\LegacyMockInterface;
use Mockery\MockInterface; use Mockery\MockInterface;
class ConfigConsoleTest extends ConsoleTest class ConfigConsoleTest extends ConsoleTest
@ -33,27 +35,27 @@ class ConfigConsoleTest extends ConsoleTest
* @var App\Mode|MockInterface $appMode * @var App\Mode|MockInterface $appMode
*/ */
private $appMode; private $appMode;
/** @var IConfig|\Mockery\LegacyMockInterface|MockInterface */ /** @var IConfig|LegacyMockInterface|MockInterface */
private $configMock; private $configMock;
protected function setUp() protected function setUp()
{ {
parent::setUp(); parent::setUp();
\Mockery::getConfiguration()->setConstantsMap([ Mockery::getConfiguration()->setConstantsMap([
Mode::class => [ Mode::class => [
'DBCONFIGAVAILABLE' => 0 'DBCONFIGAVAILABLE' => 0,
] ],
]); ]);
$this->appMode = \Mockery::mock(App\Mode::class); $this->appMode = Mockery::mock(App\Mode::class);
$this->appMode->shouldReceive('has') $this->appMode->shouldReceive('has')
->andReturn(true); ->andReturn(true);
$this->configMock = \Mockery::mock(IConfig::class); $this->configMock = Mockery::mock(IConfig::class);
} }
function testSetGetKeyValue() public function testSetGetKeyValue()
{ {
$this->configMock $this->configMock
->shouldReceive('set') ->shouldReceive('set')
@ -98,7 +100,8 @@ class ConfigConsoleTest extends ConsoleTest
self::assertEquals("config.test => \n", $txt); self::assertEquals("config.test => \n", $txt);
} }
function testSetArrayValue() { public function testSetArrayValue()
{
$testArray = [1, 2, 3]; $testArray = [1, 2, 3];
$this->configMock $this->configMock
->shouldReceive('get') ->shouldReceive('get')
@ -115,19 +118,21 @@ class ConfigConsoleTest extends ConsoleTest
self::assertEquals("[Error] config.test is an array and can't be set using this command.\n", $txt); self::assertEquals("[Error] config.test is an array and can't be set using this command.\n", $txt);
} }
function testTooManyArguments() { public function testTooManyArguments()
{
$console = new Config($this->appMode, $this->configMock, $this->consoleArgv); $console = new Config($this->appMode, $this->configMock, $this->consoleArgv);
$console->setArgument(0, 'config'); $console->setArgument(0, 'config');
$console->setArgument(1, 'test'); $console->setArgument(1, 'test');
$console->setArgument(2, 'it'); $console->setArgument(2, 'it');
$console->setArgument(3, 'now'); $console->setArgument(3, 'now');
$txt = $this->dumpExecute($console); $txt = $this->dumpExecute($console);
$assertion = '[Warning] Too many arguments'; $assertion = '[Warning] Too many arguments';
$firstline = substr($txt, 0, strlen($assertion)); $firstline = substr($txt, 0, strlen($assertion));
self::assertEquals($assertion, $firstline); self::assertEquals($assertion, $firstline);
} }
function testVerbose() { public function testVerbose()
{
$this->configMock $this->configMock
->shouldReceive('get') ->shouldReceive('get')
->with('test', 'it') ->with('test', 'it')
@ -138,7 +143,7 @@ class ConfigConsoleTest extends ConsoleTest
$console->setArgument(1, 'it'); $console->setArgument(1, 'it');
$console->setOption('v', 1); $console->setOption('v', 1);
$executable = $this->consoleArgv[0]; $executable = $this->consoleArgv[0];
$assertion = <<<CONF $assertion = <<<CONF
Executable: {$executable} Executable: {$executable}
Class: Friendica\Console\Config Class: Friendica\Console\Config
Arguments: array ( Arguments: array (
@ -151,11 +156,12 @@ Options: array (
test.it => now test.it => now
CONF; CONF;
$txt = $this->dumpExecute($console); $txt = $this->dumpExecute($console);
self::assertEquals($assertion, $txt); self::assertEquals($assertion, $txt);
} }
function testUnableToSet() { public function testUnableToSet()
{
$this->configMock $this->configMock
->shouldReceive('set') ->shouldReceive('set')
->with('test', 'it', 'now') ->with('test', 'it', 'now')
@ -164,7 +170,7 @@ CONF;
$this->configMock $this->configMock
->shouldReceive('get') ->shouldReceive('get')
->with('test', 'it') ->with('test', 'it')
->andReturn(NULL) ->andReturn(null)
->once(); ->once();
$console = new Config($this->appMode, $this->configMock, [$this->consoleArgv]); $console = new Config($this->appMode, $this->configMock, [$this->consoleArgv]);
$console->setArgument(0, 'test'); $console->setArgument(0, 'test');

View file

@ -46,7 +46,7 @@ abstract class ConsoleTest extends MockedTest
* *
* @return string the output of the execution * @return string the output of the execution
*/ */
protected function dumpExecute($console) protected function dumpExecute(Console $console)
{ {
Intercept::reset(); Intercept::reset();
$console->execute(); $console->execute();

View file

@ -25,6 +25,7 @@ use Friendica\App;
use Friendica\App\Mode; use Friendica\App\Mode;
use Friendica\Console\Lock; use Friendica\Console\Lock;
use Friendica\Core\Lock\ILock; use Friendica\Core\Lock\ILock;
use Mockery;
use Mockery\MockInterface; use Mockery\MockInterface;
class LockConsoleTest extends ConsoleTest class LockConsoleTest extends ConsoleTest
@ -43,17 +44,17 @@ class LockConsoleTest extends ConsoleTest
{ {
parent::setUp(); parent::setUp();
\Mockery::getConfiguration()->setConstantsMap([ Mockery::getConfiguration()->setConstantsMap([
Mode::class => [ Mode::class => [
'DBCONFIGAVAILABLE' => 0 'DBCONFIGAVAILABLE' => 0
] ]
]); ]);
$this->appMode = \Mockery::mock(App\Mode::class); $this->appMode = Mockery::mock(App\Mode::class);
$this->appMode->shouldReceive('has') $this->appMode->shouldReceive('has')
->andReturn(true); ->andReturn(true);
$this->lockMock = \Mockery::mock(ILock::class); $this->lockMock = Mockery::mock(ILock::class);
} }
public function testList() public function testList()

View file

@ -23,6 +23,7 @@ namespace Friendica\Test\src\Console;
use Friendica\Console\ServerBlock; use Friendica\Console\ServerBlock;
use Friendica\Core\Config\IConfig; use Friendica\Core\Config\IConfig;
use Mockery;
class ServerBlockConsoleTest extends ConsoleTest class ServerBlockConsoleTest extends ConsoleTest
{ {
@ -36,12 +37,16 @@ class ServerBlockConsoleTest extends ConsoleTest
'reason' => 'Illegal content', 'reason' => 'Illegal content',
] ]
]; ];
/**
* @var IConfig|Mockery\LegacyMockInterface|Mockery\MockInterface
*/
private $configMock;
protected function setUp() protected function setUp()
{ {
parent::setUp(); parent::setUp();
$this->configMock = \Mockery::mock(IConfig::class); $this->configMock = Mockery::mock(IConfig::class);
} }
/** /**

View file

@ -27,6 +27,6 @@ class ItemTest extends MockedTest
{ {
public function testDetermineCategoriesTerms() public function testDetermineCategoriesTerms()
{ {
$this->markTestIncomplete('Test data needed.'); static::markTestIncomplete('Test data needed.');
} }
} }

View file

@ -21,6 +21,8 @@
namespace Friendica\Test\src\Content; namespace Friendica\Test\src\Content;
use Friendica\Content\PageInfo;
/** /**
* Class PageInfoMock * Class PageInfoMock
* *
@ -29,7 +31,7 @@ namespace Friendica\Test\src\Content;
* @method static string|null getRelevantUrlFromBody(string $body, $searchNakedUrls = false) * @method static string|null getRelevantUrlFromBody(string $body, $searchNakedUrls = false)
* @method static string stripTrailingUrlFromBody(string $body, string $url) * @method static string stripTrailingUrlFromBody(string $body, string $url)
*/ */
class PageInfoMock extends \Friendica\Content\PageInfo class PageInfoMock extends PageInfo
{ {
public static function __callStatic($name, $arguments) public static function __callStatic($name, $arguments)
{ {

View file

@ -9,6 +9,7 @@
namespace Friendica\Test\src\Content; namespace Friendica\Test\src\Content;
use Friendica\Content\Smilies; use Friendica\Content\Smilies;
use Friendica\Network\HTTPException\InternalServerErrorException;
use Friendica\Test\MockedTest; use Friendica\Test\MockedTest;
use Friendica\Test\Util\AppMockTrait; use Friendica\Test\Util\AppMockTrait;
use Friendica\Test\Util\VFSTrait; use Friendica\Test\Util\VFSTrait;
@ -52,14 +53,16 @@ class SmiliesTest extends MockedTest
/** /**
* Test replace smilies in different texts * Test replace smilies in different texts
*
* @dataProvider dataLinks * @dataProvider dataLinks
* *
* @param string $text Test string * @param string $text Test string
* @param array $smilies List of smilies to replace * @param array $smilies List of smilies to replace
* @param string $expected Expected result * @param string $expected Expected result
* @throws \Friendica\Network\HTTPException\InternalServerErrorException *
* @throws InternalServerErrorException
*/ */
public function testReplaceFromArray($text, $smilies, $expected) public function testReplaceFromArray(string $text, array $smilies, string $expected)
{ {
$output = Smilies::replaceFromArray($text, $smilies); $output = Smilies::replaceFromArray($text, $smilies);
self::assertEquals($expected, $output); self::assertEquals($expected, $output);

View file

@ -24,9 +24,11 @@ namespace Friendica\Test\src\Content\Text;
use Friendica\App\BaseURL; use Friendica\App\BaseURL;
use Friendica\Content\Text\BBCode; use Friendica\Content\Text\BBCode;
use Friendica\Core\L10n; use Friendica\Core\L10n;
use Friendica\Network\HTTPException\InternalServerErrorException;
use Friendica\Test\MockedTest; use Friendica\Test\MockedTest;
use Friendica\Test\Util\AppMockTrait; use Friendica\Test\Util\AppMockTrait;
use Friendica\Test\Util\VFSTrait; use Friendica\Test\Util\VFSTrait;
use Mockery;
class BBCodeTest extends MockedTest class BBCodeTest extends MockedTest
{ {
@ -62,13 +64,13 @@ class BBCodeTest extends MockedTest
->with('system', 'big_emojis') ->with('system', 'big_emojis')
->andReturn(false); ->andReturn(false);
$l10nMock = \Mockery::mock(L10n::class); $l10nMock = Mockery::mock(L10n::class);
$l10nMock->shouldReceive('t')->withAnyArgs()->andReturnUsing(function ($args) { return $args; }); $l10nMock->shouldReceive('t')->withAnyArgs()->andReturnUsing(function ($args) { return $args; });
$this->dice->shouldReceive('create') $this->dice->shouldReceive('create')
->with(L10n::class) ->with(L10n::class)
->andReturn($l10nMock); ->andReturn($l10nMock);
$baseUrlMock = \Mockery::mock(BaseURL::class); $baseUrlMock = Mockery::mock(BaseURL::class);
$baseUrlMock->shouldReceive('get')->withAnyArgs()->andReturn('friendica.local'); $baseUrlMock->shouldReceive('get')->withAnyArgs()->andReturn('friendica.local');
$this->dice->shouldReceive('create') $this->dice->shouldReceive('create')
->with(BaseURL::class) ->with(BaseURL::class)
@ -158,13 +160,15 @@ class BBCodeTest extends MockedTest
/** /**
* Test convert different links inside a text * Test convert different links inside a text
*
* @dataProvider dataLinks * @dataProvider dataLinks
* *
* @param string $data The data to text * @param string $data The data to text
* @param bool $assertHTML True, if the link is a HTML link (<a href...>...</a>) * @param bool $assertHTML True, if the link is a HTML link (<a href...>...</a>)
* @throws \Friendica\Network\HTTPException\InternalServerErrorException *
* @throws InternalServerErrorException
*/ */
public function testAutoLinking($data, $assertHTML) public function testAutoLinking(string $data, bool $assertHTML)
{ {
$output = BBCode::convert($data); $output = BBCode::convert($data);
$assert = '<a href="' . $data . '" target="_blank" rel="noopener noreferrer">' . $data . '</a>'; $assert = '<a href="' . $data . '" target="_blank" rel="noopener noreferrer">' . $data . '</a>';
@ -258,9 +262,10 @@ class BBCodeTest extends MockedTest
* @param bool $try_oembed Whether to convert multimedia BBCode tag * @param bool $try_oembed Whether to convert multimedia BBCode tag
* @param int $simpleHtml BBCode::convert method $simple_html parameter value, optional. * @param int $simpleHtml BBCode::convert method $simple_html parameter value, optional.
* @param bool $forPlaintext BBCode::convert method $for_plaintext parameter value, optional. * @param bool $forPlaintext BBCode::convert method $for_plaintext parameter value, optional.
* @throws \Friendica\Network\HTTPException\InternalServerErrorException *
* @throws InternalServerErrorException
*/ */
public function testConvert($expectedHtml, $text, $try_oembed = false, $simpleHtml = 0, $forPlaintext = false) public function testConvert(string $expectedHtml, string $text, $try_oembed = false, int $simpleHtml = 0, bool $forPlaintext = false)
{ {
$actual = BBCode::convert($text, $try_oembed, $simpleHtml, $forPlaintext); $actual = BBCode::convert($text, $try_oembed, $simpleHtml, $forPlaintext);
@ -290,12 +295,13 @@ class BBCodeTest extends MockedTest
* *
* @dataProvider dataBBCodesToMarkdown * @dataProvider dataBBCodesToMarkdown
* *
* @param string $expected Expected Markdown output * @param string $expected Expected Markdown output
* @param string $text BBCode text * @param string $text BBCode text
* @param bool $for_diaspora * @param bool $for_diaspora
* @throws \Friendica\Network\HTTPException\InternalServerErrorException *
* @throws InternalServerErrorException
*/ */
public function testToMarkdown($expected, $text, $for_diaspora = false) public function testToMarkdown(string $expected, string $text, $for_diaspora = false)
{ {
$actual = BBCode::toMarkdown($text, $for_diaspora); $actual = BBCode::toMarkdown($text, $for_diaspora);

View file

@ -21,7 +21,9 @@
namespace Friendica\Test\src\Content\Text; namespace Friendica\Test\src\Content\Text;
use Exception;
use Friendica\Content\Text\HTML; use Friendica\Content\Text\HTML;
use Friendica\Network\HTTPException\InternalServerErrorException;
use Friendica\Test\MockedTest; use Friendica\Test\MockedTest;
use Friendica\Test\Util\AppMockTrait; use Friendica\Test\Util\AppMockTrait;
use Friendica\Test\Util\VFSTrait; use Friendica\Test\Util\VFSTrait;
@ -61,9 +63,10 @@ class HTMLTest extends MockedTest
* *
* @param string $input The Markdown text to test * @param string $input The Markdown text to test
* @param string $expected The expected HTML output * @param string $expected The expected HTML output
* @throws \Exception *
* @throws Exception
*/ */
public function testToPlaintext($input, $expected) public function testToPlaintext(string $input, string $expected)
{ {
$output = HTML::toPlaintext($input, 0); $output = HTML::toPlaintext($input, 0);
@ -91,9 +94,10 @@ class HTMLTest extends MockedTest
* *
* @param string $expectedBBCode Expected BBCode output * @param string $expectedBBCode Expected BBCode output
* @param string $html HTML text * @param string $html HTML text
* @throws \Friendica\Network\HTTPException\InternalServerErrorException *
* @throws InternalServerErrorException
*/ */
public function testToBBCode($expectedBBCode, $html) public function testToBBCode(string $expectedBBCode, string $html)
{ {
$actual = HTML::toBBCode($html); $actual = HTML::toBBCode($html);

View file

@ -21,7 +21,7 @@
namespace Friendica\Test\src\Content\Text; namespace Friendica\Test\src\Content\Text;
use Friendica\Content\Text\HTML; use Exception;
use Friendica\Content\Text\Markdown; use Friendica\Content\Text\Markdown;
use Friendica\Test\MockedTest; use Friendica\Test\MockedTest;
use Friendica\Test\Util\AppMockTrait; use Friendica\Test\Util\AppMockTrait;
@ -57,13 +57,15 @@ class MarkdownTest extends MockedTest
/** /**
* Test convert different input Markdown text into HTML * Test convert different input Markdown text into HTML
*
* @dataProvider dataMarkdown * @dataProvider dataMarkdown
* *
* @param string $input The Markdown text to test * @param string $input The Markdown text to test
* @param string $expected The expected HTML output * @param string $expected The expected HTML output
* @throws \Exception *
* @throws Exception
*/ */
public function testConvert($input, $expected) public function testConvert(string $input, string $expected)
{ {
$output = Markdown::convert($input); $output = Markdown::convert($input);
@ -87,9 +89,8 @@ class MarkdownTest extends MockedTest
* *
* @param string $expectedBBCode Expected BBCode output * @param string $expectedBBCode Expected BBCode output
* @param string $html Markdown text * @param string $html Markdown text
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
*/ */
public function testToBBCode($expectedBBCode, $html) public function testToBBCode(string $expectedBBCode, string $html)
{ {
$actual = Markdown::toBBCode($html); $actual = Markdown::toBBCode($html);

View file

@ -31,7 +31,7 @@ class APCuCacheTest extends MemoryCacheTest
protected function setUp() protected function setUp()
{ {
if (!APCuCache::isAvailable()) { if (!APCuCache::isAvailable()) {
$this->markTestSkipped('APCu is not available'); static::markTestSkipped('APCu is not available');
} }
parent::setUp(); parent::setUp();
@ -43,7 +43,7 @@ class APCuCacheTest extends MemoryCacheTest
return $this->cache; return $this->cache;
} }
public function tearDown() protected function tearDown()
{ {
$this->cache->clear(false); $this->cache->clear(false);
parent::tearDown(); parent::tearDown();

View file

@ -31,7 +31,7 @@ class ArrayCacheTest extends MemoryCacheTest
return $this->cache; return $this->cache;
} }
public function tearDown() protected function tearDown()
{ {
$this->cache->clear(false); $this->cache->clear(false);
parent::tearDown(); parent::tearDown();

View file

@ -21,6 +21,8 @@
namespace Friendica\Test\src\Core\Cache; namespace Friendica\Test\src\Core\Cache;
use Friendica\Core\Cache\ICache;
use Friendica\Core\Cache\IMemoryCache;
use Friendica\Test\MockedTest; use Friendica\Test\MockedTest;
use Friendica\Util\PidFile; use Friendica\Util\PidFile;
@ -32,12 +34,12 @@ abstract class CacheTest extends MockedTest
protected $startTime = 1417011228; protected $startTime = 1417011228;
/** /**
* @var \Friendica\Core\Cache\ICache * @var ICache
*/ */
protected $instance; protected $instance;
/** /**
* @var \Friendica\Core\Cache\IMemoryCache * @var IMemoryCache
*/ */
protected $cache; protected $cache;
@ -95,7 +97,7 @@ abstract class CacheTest extends MockedTest
* @param mixed $value1 a first * @param mixed $value1 a first
* @param mixed $value2 a second * @param mixed $value2 a second
*/ */
function testSimple($value1, $value2) public function testSimple($value1, $value2)
{ {
self::assertNull($this->instance->get('value1')); self::assertNull($this->instance->get('value1'));
@ -127,9 +129,8 @@ abstract class CacheTest extends MockedTest
* @param mixed $value3 a third * @param mixed $value3 a third
* @param mixed $value4 a fourth * @param mixed $value4 a fourth
*/ */
function testClear($value1, $value2, $value3, $value4) public function testClear($value1, $value2, $value3, $value4)
{ {
$value = 'ipsum lorum';
$this->instance->set('1_value1', $value1); $this->instance->set('1_value1', $value1);
$this->instance->set('1_value2', $value2); $this->instance->set('1_value2', $value2);
$this->instance->set('2_value1', $value3); $this->instance->set('2_value1', $value3);
@ -179,9 +180,9 @@ abstract class CacheTest extends MockedTest
/** /**
* @medium * @medium
*/ */
function testTTL() public function testTTL()
{ {
$this->markTestSkipped('taking too much time without mocking'); static::markTestSkipped('taking too much time without mocking');
self::assertNull($this->instance->get('value1')); self::assertNull($this->instance->get('value1'));
@ -198,11 +199,11 @@ abstract class CacheTest extends MockedTest
/** /**
* @small * @small
* *
* @param $data mixed the data to store in the cache * @param mixed $data the data to store in the cache
* *
* @dataProvider dataTypesInCache * @dataProvider dataTypesInCache
*/ */
function testDifferentTypesInCache($data) public function testDifferentTypesInCache($data)
{ {
$this->instance->set('val', $data); $this->instance->set('val', $data);
$received = $this->instance->get('val'); $received = $this->instance->get('val');

View file

@ -28,6 +28,7 @@ use Friendica\Test\Util\Database\StaticDatabase;
use Friendica\Test\Util\VFSTrait; use Friendica\Test\Util\VFSTrait;
use Friendica\Util\ConfigFileLoader; use Friendica\Util\ConfigFileLoader;
use Friendica\Util\Profiler; use Friendica\Util\Profiler;
use Mockery;
use Psr\Log\NullLogger; use Psr\Log\NullLogger;
class DatabaseCacheTest extends CacheTest class DatabaseCacheTest extends CacheTest
@ -45,7 +46,7 @@ class DatabaseCacheTest extends CacheTest
protected function getInstance() protected function getInstance()
{ {
$logger = new NullLogger(); $logger = new NullLogger();
$profiler = \Mockery::mock(Profiler::class); $profiler = Mockery::mock(Profiler::class);
$profiler->shouldReceive('saveTimestamp')->withAnyArgs()->andReturn(true); $profiler->shouldReceive('saveTimestamp')->withAnyArgs()->andReturn(true);
// load real config to avoid mocking every config-entry which is related to the Database class // load real config to avoid mocking every config-entry which is related to the Database class
@ -59,7 +60,7 @@ class DatabaseCacheTest extends CacheTest
return $this->cache; return $this->cache;
} }
public function tearDown() protected function tearDown()
{ {
$this->cache->clear(false); $this->cache->clear(false);
parent::tearDown(); parent::tearDown();

View file

@ -21,8 +21,10 @@
namespace Friendica\Test\src\Core\Cache; namespace Friendica\Test\src\Core\Cache;
use Exception;
use Friendica\Core\Cache\MemcacheCache; use Friendica\Core\Cache\MemcacheCache;
use Friendica\Core\Config\IConfig; use Friendica\Core\Config\IConfig;
use Mockery;
/** /**
* @requires extension memcache * @requires extension memcache
@ -32,7 +34,7 @@ class MemcacheCacheTest extends MemoryCacheTest
{ {
protected function getInstance() protected function getInstance()
{ {
$configMock = \Mockery::mock(IConfig::class); $configMock = Mockery::mock(IConfig::class);
$host = $_SERVER['MEMCACHE_HOST'] ?? 'localhost'; $host = $_SERVER['MEMCACHE_HOST'] ?? 'localhost';
$port = $_SERVER['MEMCACHE_PORT'] ?? '11211'; $port = $_SERVER['MEMCACHE_PORT'] ?? '11211';
@ -48,13 +50,13 @@ class MemcacheCacheTest extends MemoryCacheTest
try { try {
$this->cache = new MemcacheCache($host, $configMock); $this->cache = new MemcacheCache($host, $configMock);
} catch (\Exception $e) { } catch (Exception $e) {
$this->markTestSkipped('Memcache is not available'); static::markTestSkipped('Memcache is not available');
} }
return $this->cache; return $this->cache;
} }
public function tearDown() protected function tearDown()
{ {
$this->cache->clear(false); $this->cache->clear(false);
parent::tearDown(); parent::tearDown();
@ -67,6 +69,6 @@ class MemcacheCacheTest extends MemoryCacheTest
*/ */
public function testGetAllKeys($value1, $value2, $value3) public function testGetAllKeys($value1, $value2, $value3)
{ {
$this->markTestIncomplete('Race condition because of too fast getAllKeys() which uses a workaround'); static::markTestIncomplete('Race condition because of too fast getAllKeys() which uses a workaround');
} }
} }

View file

@ -21,8 +21,10 @@
namespace Friendica\Test\src\Core\Cache; namespace Friendica\Test\src\Core\Cache;
use Exception;
use Friendica\Core\Cache\MemcachedCache; use Friendica\Core\Cache\MemcachedCache;
use Friendica\Core\Config\IConfig; use Friendica\Core\Config\IConfig;
use Mockery;
use Psr\Log\NullLogger; use Psr\Log\NullLogger;
/** /**
@ -33,7 +35,7 @@ class MemcachedCacheTest extends MemoryCacheTest
{ {
protected function getInstance() protected function getInstance()
{ {
$configMock = \Mockery::mock(IConfig::class); $configMock = Mockery::mock(IConfig::class);
$host = $_SERVER['MEMCACHED_HOST'] ?? 'localhost'; $host = $_SERVER['MEMCACHED_HOST'] ?? 'localhost';
$port = $_SERVER['MEMCACHED_PORT'] ?? '11211'; $port = $_SERVER['MEMCACHED_PORT'] ?? '11211';
@ -47,13 +49,13 @@ class MemcachedCacheTest extends MemoryCacheTest
try { try {
$this->cache = new MemcachedCache($host, $configMock, $logger); $this->cache = new MemcachedCache($host, $configMock, $logger);
} catch (\Exception $exception) { } catch (Exception $exception) {
$this->markTestSkipped('Memcached is not available'); static::markTestSkipped('Memcached is not available');
} }
return $this->cache; return $this->cache;
} }
public function tearDown() protected function tearDown()
{ {
$this->cache->clear(false); $this->cache->clear(false);
parent::tearDown(); parent::tearDown();
@ -66,6 +68,6 @@ class MemcachedCacheTest extends MemoryCacheTest
*/ */
public function testGetAllKeys($value1, $value2, $value3) public function testGetAllKeys($value1, $value2, $value3)
{ {
$this->markTestIncomplete('Race condition because of too fast getAllKeys() which uses a workaround'); static::markTestIncomplete('Race condition because of too fast getAllKeys() which uses a workaround');
} }
} }

View file

@ -21,12 +21,13 @@
namespace Friendica\Test\src\Core\Cache; namespace Friendica\Test\src\Core\Cache;
use Exception;
use Friendica\Core\Cache\IMemoryCache; use Friendica\Core\Cache\IMemoryCache;
abstract class MemoryCacheTest extends CacheTest abstract class MemoryCacheTest extends CacheTest
{ {
/** /**
* @var \Friendica\Core\Cache\IMemoryCache * @var IMemoryCache
*/ */
protected $instance; protected $instance;
@ -35,7 +36,7 @@ abstract class MemoryCacheTest extends CacheTest
parent::setUp(); parent::setUp();
if (!($this->instance instanceof IMemoryCache)) { if (!($this->instance instanceof IMemoryCache)) {
throw new \Exception('MemoryCacheTest unsupported'); throw new Exception('MemoryCacheTest unsupported');
} }
} }
@ -43,7 +44,7 @@ abstract class MemoryCacheTest extends CacheTest
* @small * @small
* @dataProvider dataSimple * @dataProvider dataSimple
*/ */
function testCompareSet($value1, $value2) public function testCompareSet($value1, $value2)
{ {
self::assertNull($this->instance->get('value1')); self::assertNull($this->instance->get('value1'));
@ -60,7 +61,7 @@ abstract class MemoryCacheTest extends CacheTest
* @small * @small
* @dataProvider dataSimple * @dataProvider dataSimple
*/ */
function testNegativeCompareSet($value1, $value2) public function testNegativeCompareSet($value1, $value2)
{ {
self::assertNull($this->instance->get('value1')); self::assertNull($this->instance->get('value1'));
@ -78,7 +79,7 @@ abstract class MemoryCacheTest extends CacheTest
* @small * @small
* @dataProvider dataSimple * @dataProvider dataSimple
*/ */
function testCompareDelete($data) public function testCompareDelete($data)
{ {
self::assertNull($this->instance->get('value1')); self::assertNull($this->instance->get('value1'));
@ -93,7 +94,7 @@ abstract class MemoryCacheTest extends CacheTest
* @small * @small
* @dataProvider dataSimple * @dataProvider dataSimple
*/ */
function testNegativeCompareDelete($data) public function testNegativeCompareDelete($data)
{ {
self::assertNull($this->instance->get('value1')); self::assertNull($this->instance->get('value1'));
@ -111,7 +112,7 @@ abstract class MemoryCacheTest extends CacheTest
* @small * @small
* @dataProvider dataSimple * @dataProvider dataSimple
*/ */
function testAdd($value1, $value2) public function testAdd($value1, $value2)
{ {
self::assertNull($this->instance->get('value1')); self::assertNull($this->instance->get('value1'));

View file

@ -21,8 +21,10 @@
namespace Friendica\Test\src\Core\Cache; namespace Friendica\Test\src\Core\Cache;
use Exception;
use Friendica\Core\Cache\RedisCache; use Friendica\Core\Cache\RedisCache;
use Friendica\Core\Config\IConfig; use Friendica\Core\Config\IConfig;
use Mockery;
/** /**
* @requires extension redis * @requires extension redis
@ -32,7 +34,7 @@ class RedisCacheTest extends MemoryCacheTest
{ {
protected function getInstance() protected function getInstance()
{ {
$configMock = \Mockery::mock(IConfig::class); $configMock = Mockery::mock(IConfig::class);
$host = $_SERVER['REDIS_HOST'] ?? 'localhost'; $host = $_SERVER['REDIS_HOST'] ?? 'localhost';
$port = $_SERVER['REDIS_PORT'] ?? null; $port = $_SERVER['REDIS_PORT'] ?? null;
@ -57,13 +59,13 @@ class RedisCacheTest extends MemoryCacheTest
try { try {
$this->cache = new RedisCache($host, $configMock); $this->cache = new RedisCache($host, $configMock);
} catch (\Exception $e) { } catch (Exception $e) {
$this->markTestSkipped('Redis is not available.'); static::markTestSkipped('Redis is not available.');
} }
return $this->cache; return $this->cache;
} }
public function tearDown() protected function tearDown()
{ {
$this->cache->clear(false); $this->cache->clear(false);
parent::tearDown(); parent::tearDown();

View file

@ -24,6 +24,7 @@ namespace Friendica\Test\src\Core\Config;
use Friendica\Core\Config\Cache; use Friendica\Core\Config\Cache;
use Friendica\Test\MockedTest; use Friendica\Test\MockedTest;
use ParagonIE\HiddenString\HiddenString; use ParagonIE\HiddenString\HiddenString;
use stdClass;
class CacheTest extends MockedTest class CacheTest extends MockedTest
{ {
@ -300,7 +301,7 @@ class CacheTest extends MockedTest
{ {
$configCache = new Cache([ $configCache = new Cache([
'database' => [ 'database' => [
'password' => new \stdClass(), 'password' => new stdClass(),
'username' => '', 'username' => '',
] ]
]); ]);

View file

@ -67,7 +67,7 @@ abstract class ConfigTest extends MockedTest
/** /**
* @return IConfig * @return IConfig
*/ */
public abstract function getInstance(); abstract public function getInstance();
public function dataTests() public function dataTests()
{ {
@ -169,8 +169,11 @@ abstract class ConfigTest extends MockedTest
/** /**
* Test the configuration load() method * Test the configuration load() method
*
* @param array $data
* @param array $load
*/ */
public function testLoad(array $data, array $possibleCats, array $load) public function testLoad(array $data, array $load)
{ {
$this->testedConfig = $this->getInstance(); $this->testedConfig = $this->getInstance();
self::assertInstanceOf(Cache::class, $this->testedConfig->getCache()); self::assertInstanceOf(Cache::class, $this->testedConfig->getCache());
@ -251,7 +254,7 @@ abstract class ConfigTest extends MockedTest
/** /**
* Test the configuration load() method with overwrite * Test the configuration load() method with overwrite
*/ */
public function testCacheLoadDouble(array $data1, array $data2, array $expect) public function testCacheLoadDouble(array $data1, array $data2, array $expect = [])
{ {
$this->testedConfig = $this->getInstance(); $this->testedConfig = $this->getInstance();
self::assertInstanceOf(Cache::class, $this->testedConfig->getCache()); self::assertInstanceOf(Cache::class, $this->testedConfig->getCache());

View file

@ -45,8 +45,11 @@ class JitConfigTest extends ConfigTest
/** /**
* @dataProvider dataConfigLoad * @dataProvider dataConfigLoad
*
* @param array $data
* @param array $load
*/ */
public function testLoad(array $data, array $possibleCats, array $load) public function testLoad(array $data, array $load)
{ {
$this->configModel->shouldReceive('isConnected') $this->configModel->shouldReceive('isConnected')
->andReturn(true) ->andReturn(true)
@ -64,13 +67,13 @@ class JitConfigTest extends ConfigTest
->once(); ->once();
} }
parent::testLoad($data, $possibleCats, $load); parent::testLoad($data, $load);
} }
/** /**
* @dataProvider dataDoubleLoad * @dataProvider dataDoubleLoad
*/ */
public function testCacheLoadDouble(array $data1, array $data2, array $expect) public function testCacheLoadDouble(array $data1, array $data2, array $expect = [])
{ {
$this->configModel->shouldReceive('isConnected') $this->configModel->shouldReceive('isConnected')
->andReturn(true) ->andReturn(true)
@ -96,7 +99,7 @@ class JitConfigTest extends ConfigTest
->once(); ->once();
} }
parent::testCacheLoadDouble($data1, $data2, $expect); parent::testCacheLoadDouble($data1, $data2);
// Assert the expected categories // Assert the expected categories
foreach ($data2 as $cat => $data) { foreach ($data2 as $cat => $data) {

View file

@ -44,8 +44,11 @@ class PreloadConfigTest extends ConfigTest
/** /**
* @dataProvider dataConfigLoad * @dataProvider dataConfigLoad
*
* @param array $data
* @param array $load
*/ */
public function testLoad(array $data, array $possibleCats, array $load) public function testLoad(array $data, array $load)
{ {
$this->configModel->shouldReceive('isConnected') $this->configModel->shouldReceive('isConnected')
->andReturn(true) ->andReturn(true)
@ -55,7 +58,7 @@ class PreloadConfigTest extends ConfigTest
->andReturn($data) ->andReturn($data)
->once(); ->once();
parent::testLoad($data, $possibleCats, $load); parent::testLoad($data, $load);
// Assert that every category is loaded everytime // Assert that every category is loaded everytime
foreach ($data as $cat => $values) { foreach ($data as $cat => $values) {
@ -65,8 +68,11 @@ class PreloadConfigTest extends ConfigTest
/** /**
* @dataProvider dataDoubleLoad * @dataProvider dataDoubleLoad
*
* @param array $data1
* @param array $data2
*/ */
public function testCacheLoadDouble(array $data1, array $data2, array $expect) public function testCacheLoadDouble(array $data1, array $data2, array $expect = [])
{ {
$this->configModel->shouldReceive('isConnected') $this->configModel->shouldReceive('isConnected')
->andReturn(true) ->andReturn(true)
@ -76,7 +82,7 @@ class PreloadConfigTest extends ConfigTest
->andReturn($data1) ->andReturn($data1)
->once(); ->once();
parent::testCacheLoadDouble($data1, $data2, $expect); parent::testCacheLoadDouble($data1, $data2);
// Assert that every category is loaded everytime and is NOT overwritten // Assert that every category is loaded everytime and is NOT overwritten
foreach ($data1 as $cat => $values) { foreach ($data1 as $cat => $values) {

View file

@ -19,7 +19,7 @@
* *
*/ */
// this is in the same namespace as Install for mocking 'function_exists' /// @todo this is in the same namespace as Install for mocking 'function_exists'
namespace Friendica\Core; namespace Friendica\Core;
use Dice\Dice; use Dice\Dice;
@ -29,6 +29,7 @@ use Friendica\Network\CurlResult;
use Friendica\Network\IHTTPRequest; use Friendica\Network\IHTTPRequest;
use Friendica\Test\MockedTest; use Friendica\Test\MockedTest;
use Friendica\Test\Util\VFSTrait; use Friendica\Test\Util\VFSTrait;
use Mockery;
use Mockery\MockInterface; use Mockery\MockInterface;
class InstallerTest extends MockedTest class InstallerTest extends MockedTest
@ -36,7 +37,7 @@ class InstallerTest extends MockedTest
use VFSTrait; use VFSTrait;
/** /**
* @var \Friendica\Core\L10n|MockInterface * @var L10n|MockInterface
*/ */
private $l10nMock; private $l10nMock;
/** /**
@ -44,20 +45,20 @@ class InstallerTest extends MockedTest
*/ */
private $dice; private $dice;
public function setUp() protected function setUp()
{ {
parent::setUp(); parent::setUp();
$this->setUpVfsDir(); $this->setUpVfsDir();
$this->l10nMock = \Mockery::mock(\Friendica\Core\L10n::class); $this->l10nMock = Mockery::mock(L10n::class);
/** @var Dice|MockInterface $dice */ /** @var Dice|MockInterface $dice */
$this->dice = \Mockery::mock(Dice::class)->makePartial(); $this->dice = Mockery::mock(Dice::class)->makePartial();
$this->dice = $this->dice->addRules(include __DIR__ . '/../../../static/dependencies.config.php'); $this->dice = $this->dice->addRules(include __DIR__ . '/../../../static/dependencies.config.php');
$this->dice->shouldReceive('create') $this->dice->shouldReceive('create')
->with(\Friendica\Core\L10n::class) ->with(L10n::class)
->andReturn($this->l10nMock); ->andReturn($this->l10nMock);
DI::init($this->dice); DI::init($this->dice);
@ -112,7 +113,7 @@ class InstallerTest extends MockedTest
* *
* @param array $functions a list from function names and their result * @param array $functions a list from function names and their result
*/ */
private function setFunctions($functions) private function setFunctions(array $functions)
{ {
global $phpMock; global $phpMock;
$phpMock['function_exists'] = function($function) use ($functions) { $phpMock['function_exists'] = function($function) use ($functions) {
@ -130,7 +131,7 @@ class InstallerTest extends MockedTest
* *
* @param array $classes a list from class names and their results * @param array $classes a list from class names and their results
*/ */
private function setClasses($classes) private function setClasses(array $classes)
{ {
global $phpMock; global $phpMock;
$phpMock['class_exists'] = function($class) use ($classes) { $phpMock['class_exists'] = function($class) use ($classes) {
@ -297,7 +298,7 @@ class InstallerTest extends MockedTest
$this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; }); $this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
// Mocking the CURL Response // Mocking the CURL Response
$curlResult = \Mockery::mock(CurlResult::class); $curlResult = Mockery::mock(CurlResult::class);
$curlResult $curlResult
->shouldReceive('getReturnCode') ->shouldReceive('getReturnCode')
->andReturn('404'); ->andReturn('404');
@ -309,7 +310,7 @@ class InstallerTest extends MockedTest
->andReturn('test Error'); ->andReturn('test Error');
// Mocking the CURL Request // Mocking the CURL Request
$networkMock = \Mockery::mock(IHTTPRequest::class); $networkMock = Mockery::mock(IHTTPRequest::class);
$networkMock $networkMock
->shouldReceive('fetchFull') ->shouldReceive('fetchFull')
->with('https://test/install/testrewrite') ->with('https://test/install/testrewrite')
@ -344,19 +345,19 @@ class InstallerTest extends MockedTest
$this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; }); $this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
// Mocking the failed CURL Response // Mocking the failed CURL Response
$curlResultF = \Mockery::mock(CurlResult::class); $curlResultF = Mockery::mock(CurlResult::class);
$curlResultF $curlResultF
->shouldReceive('getReturnCode') ->shouldReceive('getReturnCode')
->andReturn('404'); ->andReturn('404');
// Mocking the working CURL Response // Mocking the working CURL Response
$curlResultW = \Mockery::mock(CurlResult::class); $curlResultW = Mockery::mock(CurlResult::class);
$curlResultW $curlResultW
->shouldReceive('getReturnCode') ->shouldReceive('getReturnCode')
->andReturn('204'); ->andReturn('204');
// Mocking the CURL Request // Mocking the CURL Request
$networkMock = \Mockery::mock(IHTTPRequest::class); $networkMock = Mockery::mock(IHTTPRequest::class);
$networkMock $networkMock
->shouldReceive('fetchFull') ->shouldReceive('fetchFull')
->with('https://test/install/testrewrite') ->with('https://test/install/testrewrite')
@ -387,7 +388,7 @@ class InstallerTest extends MockedTest
*/ */
public function testImagick() public function testImagick()
{ {
$this->markTestIncomplete('needs adapted class_exists() mock'); static::markTestIncomplete('needs adapted class_exists() mock');
$this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; }); $this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
@ -413,7 +414,7 @@ class InstallerTest extends MockedTest
*/ */
public function testImagickNotFound() public function testImagickNotFound()
{ {
$this->markTestIncomplete('Disabled due not working/difficult mocking global functions - needs more care!'); static::markTestIncomplete('Disabled due not working/difficult mocking global functions - needs more care!');
$this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; }); $this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
@ -456,8 +457,8 @@ class InstallerTest extends MockedTest
$this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; }); $this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
$install = new Installer(); $install = new Installer();
$configCache = \Mockery::mock(Cache::class); $configCache = Mockery::mock(Cache::class);
$configCache->shouldReceive('set')->with('config', 'php_path', \Mockery::any())->once(); $configCache->shouldReceive('set')->with('config', 'php_path', Mockery::any())->once();
$configCache->shouldReceive('set')->with('system', 'basepath', '/test/')->once(); $configCache->shouldReceive('set')->with('system', 'basepath', '/test/')->once();
$install->setUpCache($configCache, '/test/'); $install->setUpCache($configCache, '/test/');
@ -471,7 +472,7 @@ class InstallerTest extends MockedTest
* *
* @return bool true or false * @return bool true or false
*/ */
function function_exists($function_name) function function_exists(string $function_name)
{ {
global $phpMock; global $phpMock;
if (isset($phpMock['function_exists'])) { if (isset($phpMock['function_exists'])) {

View file

@ -32,7 +32,7 @@ class APCuCacheLockTest extends LockTest
protected function setUp() protected function setUp()
{ {
if (!APCuCache::isAvailable()) { if (!APCuCache::isAvailable()) {
$this->markTestSkipped('APCu is not available'); static::markTestSkipped('APCu is not available');
} }
parent::setUp(); parent::setUp();

View file

@ -28,6 +28,7 @@ use Friendica\Test\Util\Database\StaticDatabase;
use Friendica\Test\Util\VFSTrait; use Friendica\Test\Util\VFSTrait;
use Friendica\Util\ConfigFileLoader; use Friendica\Util\ConfigFileLoader;
use Friendica\Util\Profiler; use Friendica\Util\Profiler;
use Mockery;
use Psr\Log\NullLogger; use Psr\Log\NullLogger;
class DatabaseLockDriverTest extends LockTest class DatabaseLockDriverTest extends LockTest
@ -47,7 +48,7 @@ class DatabaseLockDriverTest extends LockTest
protected function getInstance() protected function getInstance()
{ {
$logger = new NullLogger(); $logger = new NullLogger();
$profiler = \Mockery::mock(Profiler::class); $profiler = Mockery::mock(Profiler::class);
$profiler->shouldReceive('saveTimestamp')->withAnyArgs()->andReturn(true); $profiler->shouldReceive('saveTimestamp')->withAnyArgs()->andReturn(true);
// load real config to avoid mocking every config-entry which is related to the Database class // load real config to avoid mocking every config-entry which is related to the Database class

View file

@ -21,6 +21,7 @@
namespace Friendica\Test\src\Core\Lock; namespace Friendica\Test\src\Core\Lock;
use Friendica\Core\Lock\ILock;
use Friendica\Test\MockedTest; use Friendica\Test\MockedTest;
abstract class LockTest extends MockedTest abstract class LockTest extends MockedTest
@ -31,7 +32,7 @@ abstract class LockTest extends MockedTest
protected $startTime = 1417011228; protected $startTime = 1417011228;
/** /**
* @var \Friendica\Core\Lock\ILock * @var ILock
*/ */
protected $instance; protected $instance;
@ -185,9 +186,9 @@ abstract class LockTest extends MockedTest
/** /**
* @medium * @medium
*/ */
function testLockTTL() public function testLockTTL()
{ {
$this->markTestSkipped('taking too much time without mocking'); static::markTestSkipped('taking too much time without mocking');
self::assertFalse($this->instance->isLocked('foo')); self::assertFalse($this->instance->isLocked('foo'));
self::assertFalse($this->instance->isLocked('bar')); self::assertFalse($this->instance->isLocked('bar'));

View file

@ -21,9 +21,11 @@
namespace Friendica\Test\src\Core\Lock; namespace Friendica\Test\src\Core\Lock;
use Exception;
use Friendica\Core\Cache\MemcacheCache; use Friendica\Core\Cache\MemcacheCache;
use Friendica\Core\Config\IConfig; use Friendica\Core\Config\IConfig;
use Friendica\Core\Lock\CacheLock; use Friendica\Core\Lock\CacheLock;
use Mockery;
/** /**
* @requires extension Memcache * @requires extension Memcache
@ -33,7 +35,7 @@ class MemcacheCacheLockTest extends LockTest
{ {
protected function getInstance() protected function getInstance()
{ {
$configMock = \Mockery::mock(IConfig::class); $configMock = Mockery::mock(IConfig::class);
$host = $_SERVER['MEMCACHE_HOST'] ?? 'localhost'; $host = $_SERVER['MEMCACHE_HOST'] ?? 'localhost';
$port = $_SERVER['MEMCACHE_PORT'] ?? '11211'; $port = $_SERVER['MEMCACHE_PORT'] ?? '11211';
@ -52,8 +54,8 @@ class MemcacheCacheLockTest extends LockTest
try { try {
$cache = new MemcacheCache($host, $configMock); $cache = new MemcacheCache($host, $configMock);
$lock = new CacheLock($cache); $lock = new CacheLock($cache);
} catch (\Exception $e) { } catch (Exception $e) {
$this->markTestSkipped('Memcache is not available'); static::markTestSkipped('Memcache is not available');
} }
return $lock; return $lock;
@ -64,7 +66,7 @@ class MemcacheCacheLockTest extends LockTest
*/ */
public function testGetLocks() public function testGetLocks()
{ {
$this->markTestIncomplete('Race condition because of too fast getAllKeys() which uses a workaround'); static::markTestIncomplete('Race condition because of too fast getAllKeys() which uses a workaround');
} }
/** /**
@ -72,6 +74,6 @@ class MemcacheCacheLockTest extends LockTest
*/ */
public function testGetLocksWithPrefix() public function testGetLocksWithPrefix()
{ {
$this->markTestIncomplete('Race condition because of too fast getAllKeys() which uses a workaround'); static::markTestIncomplete('Race condition because of too fast getAllKeys() which uses a workaround');
} }
} }

View file

@ -21,9 +21,11 @@
namespace Friendica\Test\src\Core\Lock; namespace Friendica\Test\src\Core\Lock;
use Exception;
use Friendica\Core\Cache\MemcachedCache; use Friendica\Core\Cache\MemcachedCache;
use Friendica\Core\Config\IConfig; use Friendica\Core\Config\IConfig;
use Friendica\Core\Lock\CacheLock; use Friendica\Core\Lock\CacheLock;
use Mockery;
use Psr\Log\NullLogger; use Psr\Log\NullLogger;
/** /**
@ -34,7 +36,7 @@ class MemcachedCacheLockTest extends LockTest
{ {
protected function getInstance() protected function getInstance()
{ {
$configMock = \Mockery::mock(IConfig::class); $configMock = Mockery::mock(IConfig::class);
$host = $_SERVER['MEMCACHED_HOST'] ?? 'localhost'; $host = $_SERVER['MEMCACHED_HOST'] ?? 'localhost';
$port = $_SERVER['MEMCACHED_PORT'] ?? '11211'; $port = $_SERVER['MEMCACHED_PORT'] ?? '11211';
@ -51,8 +53,8 @@ class MemcachedCacheLockTest extends LockTest
try { try {
$cache = new MemcachedCache($host, $configMock, $logger); $cache = new MemcachedCache($host, $configMock, $logger);
$lock = new CacheLock($cache); $lock = new CacheLock($cache);
} catch (\Exception $e) { } catch (Exception $e) {
$this->markTestSkipped('Memcached is not available'); static::markTestSkipped('Memcached is not available');
} }
return $lock; return $lock;
@ -60,11 +62,11 @@ class MemcachedCacheLockTest extends LockTest
public function testGetLocks() public function testGetLocks()
{ {
$this->markTestIncomplete('Race condition because of too fast getLocks() which uses a workaround'); static::markTestIncomplete('Race condition because of too fast getLocks() which uses a workaround');
} }
public function testGetLocksWithPrefix() public function testGetLocksWithPrefix()
{ {
$this->markTestIncomplete('Race condition because of too fast getLocks() which uses a workaround'); static::markTestIncomplete('Race condition because of too fast getLocks() which uses a workaround');
} }
} }

View file

@ -21,9 +21,11 @@
namespace Friendica\Test\src\Core\Lock; namespace Friendica\Test\src\Core\Lock;
use Exception;
use Friendica\Core\Cache\RedisCache; use Friendica\Core\Cache\RedisCache;
use Friendica\Core\Config\IConfig; use Friendica\Core\Config\IConfig;
use Friendica\Core\Lock\CacheLock; use Friendica\Core\Lock\CacheLock;
use Mockery;
/** /**
* @requires extension redis * @requires extension redis
@ -33,7 +35,7 @@ class RedisCacheLockTest extends LockTest
{ {
protected function getInstance() protected function getInstance()
{ {
$configMock = \Mockery::mock(IConfig::class); $configMock = Mockery::mock(IConfig::class);
$host = $_SERVER['REDIS_HOST'] ?? 'localhost'; $host = $_SERVER['REDIS_HOST'] ?? 'localhost';
$port = $_SERVER['REDIS_PORT'] ?? null; $port = $_SERVER['REDIS_PORT'] ?? null;
@ -61,8 +63,8 @@ class RedisCacheLockTest extends LockTest
try { try {
$cache = new RedisCache($host, $configMock); $cache = new RedisCache($host, $configMock);
$lock = new CacheLock($cache); $lock = new CacheLock($cache);
} catch (\Exception $e) { } catch (Exception $e) {
$this->markTestSkipped('Redis is not available'); static::markTestSkipped('Redis is not available');
} }
return $lock; return $lock;

View file

@ -27,20 +27,21 @@ use Friendica\Core\Config\IConfig;
use Friendica\Core\Config\JitConfig; use Friendica\Core\Config\JitConfig;
use Friendica\Core\Lock\SemaphoreLock; use Friendica\Core\Lock\SemaphoreLock;
use Friendica\DI; use Friendica\DI;
use Mockery;
use Mockery\MockInterface; use Mockery\MockInterface;
class SemaphoreLockTest extends LockTest class SemaphoreLockTest extends LockTest
{ {
public function setUp() protected function setUp()
{ {
/** @var MockInterface|Dice $dice */ /** @var MockInterface|Dice $dice */
$dice = \Mockery::mock(Dice::class)->makePartial(); $dice = Mockery::mock(Dice::class)->makePartial();
$app = \Mockery::mock(App::class); $app = Mockery::mock(App::class);
$app->shouldReceive('getHostname')->andReturn('friendica.local'); $app->shouldReceive('getHostname')->andReturn('friendica.local');
$dice->shouldReceive('create')->with(App::class)->andReturn($app); $dice->shouldReceive('create')->with(App::class)->andReturn($app);
$configMock = \Mockery::mock(JitConfig::class); $configMock = Mockery::mock(JitConfig::class);
$configMock $configMock
->shouldReceive('get') ->shouldReceive('get')
->with('system', 'temppath') ->with('system', 'temppath')
@ -58,7 +59,7 @@ class SemaphoreLockTest extends LockTest
return new SemaphoreLock(); return new SemaphoreLock();
} }
function testLockTTL() public function testLockTTL()
{ {
// Semaphore doesn't work with TTL // Semaphore doesn't work with TTL
return true; return true;
@ -83,6 +84,7 @@ class SemaphoreLockTest extends LockTest
* This test proves that semaphore locks cannot get released by other instances except themselves * This test proves that semaphore locks cannot get released by other instances except themselves
* *
* Check for Bug https://github.com/friendica/friendica/issues/7298#issuecomment-521996540 * Check for Bug https://github.com/friendica/friendica/issues/7298#issuecomment-521996540
*
* @see https://github.com/friendica/friendica/issues/7298#issuecomment-521996540 * @see https://github.com/friendica/friendica/issues/7298#issuecomment-521996540
*/ */
public function testMissingFileOverriding() public function testMissingFileOverriding()

View file

@ -133,10 +133,8 @@ class CacheTest extends MockedTest
/** /**
* Test the keyDiff() method with result * Test the keyDiff() method with result
*
* @dataProvider dataTests
*/ */
public function testKeyDiffWithResult($data) public function testKeyDiffWithResult()
{ {
$configCache = new Cache(); $configCache = new Cache();

View file

@ -22,7 +22,6 @@
namespace Friendica\Test\src\Core\PConfig; namespace Friendica\Test\src\Core\PConfig;
use Friendica\Core\PConfig\JitPConfig; use Friendica\Core\PConfig\JitPConfig;
use Friendica\Test\src\Core\PConfig\PConfigTest;
class JitPConfigTest extends PConfigTest class JitPConfigTest extends PConfigTest
{ {

View file

@ -69,7 +69,7 @@ abstract class PConfigTest extends MockedTest
/** /**
* @return BasePConfig * @return BasePConfig
*/ */
public abstract function getInstance(); abstract public function getInstance();
public function dataTests() public function dataTests()
{ {
@ -159,9 +159,8 @@ abstract class PConfigTest extends MockedTest
/** /**
* Test the configuration initialization * Test the configuration initialization
* @dataProvider dataConfigLoad
*/ */
public function testSetUp(int $uid, array $data) public function testSetUp()
{ {
$this->testedConfig = $this->getInstance(); $this->testedConfig = $this->getInstance();
self::assertInstanceOf(Cache::class, $this->testedConfig->getCache()); self::assertInstanceOf(Cache::class, $this->testedConfig->getCache());

View file

@ -22,7 +22,6 @@
namespace Friendica\Test\src\Core\PConfig; namespace Friendica\Test\src\Core\PConfig;
use Friendica\Core\PConfig\PreloadPConfig; use Friendica\Core\PConfig\PreloadPConfig;
use Friendica\Test\src\Core\PConfig\PConfigTest;
class PreloadPConfigTest extends PConfigTest class PreloadPConfigTest extends PConfigTest
{ {

View file

@ -34,6 +34,7 @@ use Friendica\Factory\ConfigFactory;
use Friendica\Model\Config\Config; use Friendica\Model\Config\Config;
use Friendica\Model\Storage; use Friendica\Model\Storage;
use Friendica\Core\Session; use Friendica\Core\Session;
use Friendica\Model\Storage\StorageException;
use Friendica\Test\DatabaseTest; use Friendica\Test\DatabaseTest;
use Friendica\Test\Util\Database\StaticDatabase; use Friendica\Test\Util\Database\StaticDatabase;
use Friendica\Test\Util\VFSTrait; use Friendica\Test\Util\VFSTrait;
@ -56,7 +57,7 @@ class StorageManagerTest extends DatabaseTest
use VFSTrait; use VFSTrait;
public function setUp() protected function setUp()
{ {
parent::setUp(); parent::setUp();
@ -319,12 +320,12 @@ class StorageManagerTest extends DatabaseTest
/** /**
* Test moving data to a WRONG storage * Test moving data to a WRONG storage
*
* @expectedException \Friendica\Model\Storage\StorageException
* @expectedExceptionMessage Can't move to storage backend 'SystemResource'
*/ */
public function testMoveStorageWrong() public function testMoveStorageWrong()
{ {
$this->expectExceptionMessage("Can't move to storage backend 'SystemResource'");
$this->expectException(StorageException::class);
$storageManager = new StorageManager($this->dba, $this->config, $this->logger, $this->l10n); $storageManager = new StorageManager($this->dba, $this->config, $this->logger, $this->l10n);
$storage = $storageManager->getByName(Storage\SystemResource::getName()); $storage = $storageManager->getByName(Storage\SystemResource::getName());
$storageManager->move($storage); $storageManager->move($storage);

View file

@ -45,28 +45,28 @@ class SystemTest extends TestCase
self::assertRegExp("/^" . $prefix . "[a-z0-9]{" . $length . "}?$/", $guid); self::assertRegExp("/^" . $prefix . "[a-z0-9]{" . $length . "}?$/", $guid);
} }
function testGuidWithoutParameter() public function testGuidWithoutParameter()
{ {
$this->useBaseUrl(); $this->useBaseUrl();
$guid = System::createGUID(); $guid = System::createGUID();
self::assertGuid($guid, 16); self::assertGuid($guid, 16);
} }
function testGuidWithSize32() public function testGuidWithSize32()
{ {
$this->useBaseUrl(); $this->useBaseUrl();
$guid = System::createGUID(32); $guid = System::createGUID(32);
self::assertGuid($guid, 32); self::assertGuid($guid, 32);
} }
function testGuidWithSize64() public function testGuidWithSize64()
{ {
$this->useBaseUrl(); $this->useBaseUrl();
$guid = System::createGUID(64); $guid = System::createGUID(64);
self::assertGuid($guid, 64); self::assertGuid($guid, 64);
} }
function testGuidWithPrefix() public function testGuidWithPrefix()
{ {
$guid = System::createGUID(23, 'test'); $guid = System::createGUID(23, 'test');
self::assertGuid($guid, 23, 'test'); self::assertGuid($guid, 23, 'test');

View file

@ -10,7 +10,7 @@ use Friendica\Test\Util\Database\StaticDatabase;
class DBATest extends DatabaseTest class DBATest extends DatabaseTest
{ {
public function setUp() protected function setUp()
{ {
parent::setUp(); parent::setUp();

View file

@ -75,7 +75,7 @@ class DBStructureTest extends DatabaseTest
* @small * @small
*/ */
public function testChangePrimaryKey() { public function testChangePrimaryKey() {
$this->markTestSkipped('rename primary key with autoincrement and foreign key support necessary first'); static::markTestSkipped('rename primary key with autoincrement and foreign key support necessary first');
$oldID = 'client_id'; $oldID = 'client_id';
$newID = 'pw'; $newID = 'pw';

View file

@ -24,7 +24,7 @@ class ProcessTest extends DatabaseTest
$this->setUpVfsDir(); $this->setUpVfsDir();
$this->logger = new NullLogger(); $logger = new NullLogger();
$profiler = \Mockery::mock(Profiler::class); $profiler = \Mockery::mock(Profiler::class);
$profiler->shouldReceive('saveTimestamp')->withAnyArgs()->andReturn(true); $profiler->shouldReceive('saveTimestamp')->withAnyArgs()->andReturn(true);
@ -34,7 +34,7 @@ class ProcessTest extends DatabaseTest
$loader = new ConfigFileLoader($this->root->url()); $loader = new ConfigFileLoader($this->root->url());
$configCache = $configFactory->createCache($loader); $configCache = $configFactory->createCache($loader);
$this->dba = new StaticDatabase($configCache, $profiler, $this->logger); $this->dba = new StaticDatabase($configCache, $profiler, $logger);
} }
public function testInsertDelete() public function testInsertDelete()

View file

@ -25,12 +25,12 @@ use Friendica\Core\Config\IConfig;
use Friendica\Core\L10n; use Friendica\Core\L10n;
use Friendica\Model\Storage\Filesystem; use Friendica\Model\Storage\Filesystem;
use Friendica\Model\Storage\IStorage; use Friendica\Model\Storage\IStorage;
use Friendica\Model\Storage\StorageException;
use Friendica\Test\Util\VFSTrait; use Friendica\Test\Util\VFSTrait;
use Friendica\Util\Profiler; use Friendica\Util\Profiler;
use Mockery\MockInterface; use Mockery\MockInterface;
use org\bovigo\vfs\vfsStream; use org\bovigo\vfs\vfsStream;
use Psr\Log\NullLogger; use Psr\Log\NullLogger;
use function GuzzleHttp\Psr7\uri_for;
class FilesystemStorageTest extends StorageTest class FilesystemStorageTest extends StorageTest
{ {
@ -77,12 +77,11 @@ class FilesystemStorageTest extends StorageTest
/** /**
* Test the exception in case of missing directorsy permissions * Test the exception in case of missing directorsy permissions
*
* @expectedException \Friendica\Model\Storage\StorageException
* @expectedExceptionMessageRegExp /Filesystem storage failed to create \".*\". Check you write permissions./
*/ */
public function testMissingDirPermissions() public function testMissingDirPermissions()
{ {
$this->expectException(StorageException::class);
$this->expectExceptionMessageRegExp("/Filesystem storage failed to create \".*\". Check you write permissions./");
$this->root->getChild('storage')->chmod(000); $this->root->getChild('storage')->chmod(000);
$instance = $this->getInstance(); $instance = $this->getInstance();
@ -92,12 +91,13 @@ class FilesystemStorageTest extends StorageTest
/** /**
* Test the exception in case of missing file permissions * Test the exception in case of missing file permissions
* *
* @expectedException \Friendica\Model\Storage\StorageException
* @expectedExceptionMessageRegExp /Filesystem storage failed to save data to \".*\". Check your write permissions/
*/ */
public function testMissingFilePermissions() public function testMissingFilePermissions()
{ {
$this->markTestIncomplete("Cannot catch file_put_content() error due vfsStream failure"); static::markTestIncomplete("Cannot catch file_put_content() error due vfsStream failure");
$this->expectException(StorageException::class);
$this->expectExceptionMessageRegExp("/Filesystem storage failed to save data to \".*\". Check your write permissions/");
vfsStream::create(['storage' => ['f0' => ['c0' => ['k0i0' => '']]]], $this->root); vfsStream::create(['storage' => ['f0' => ['c0' => ['k0i0' => '']]]], $this->root);

View file

@ -48,6 +48,8 @@ class CookieTest extends MockedTest
protected function tearDown() protected function tearDown()
{ {
StaticCookie::clearStatic(); StaticCookie::clearStatic();
parent::tearDown();
} }
/** /**

View file

@ -2,6 +2,8 @@
namespace Friendica\Test\src\Module\Api\Twitter; namespace Friendica\Test\src\Module\Api\Twitter;
use Friendica\Module\Api\Twitter\ContactEndpoint;
/** /**
* Class ContactEndpointMock * Class ContactEndpointMock
* *
@ -13,7 +15,7 @@ namespace Friendica\Test\src\Module\Api\Twitter;
* *
* @package Friendica\Test\Mock\Module\Api\Twitter * @package Friendica\Test\Mock\Module\Api\Twitter
*/ */
class ContactEndpointMock extends \Friendica\Module\Api\Twitter\ContactEndpoint class ContactEndpointMock extends ContactEndpoint
{ {
public static function __callStatic($name, $arguments) public static function __callStatic($name, $arguments)
{ {

View file

@ -4,6 +4,7 @@ namespace Friendica\Test\src\Module\Api\Twitter;
use Friendica\Model\Contact; use Friendica\Model\Contact;
use Friendica\Module\Api\Twitter\ContactEndpoint; use Friendica\Module\Api\Twitter\ContactEndpoint;
use Friendica\Network\HTTPException\InternalServerErrorException;
use Friendica\Network\HTTPException\NotFoundException; use Friendica\Network\HTTPException\NotFoundException;
use Friendica\Object\Api\Twitter\User; use Friendica\Object\Api\Twitter\User;
use Friendica\Test\FixtureTest; use Friendica\Test\FixtureTest;
@ -172,7 +173,7 @@ class ContactEndpointTest extends FixtureTest
* @depends testIds * @depends testIds
* *
* @throws NotFoundException * @throws NotFoundException
* @throws \Friendica\Network\HTTPException\InternalServerErrorException * @throws InternalServerErrorException
* @throws \ImagickException * @throws \ImagickException
*/ */
public function testList() public function testList()

View file

@ -21,7 +21,6 @@
namespace Friendica\Test\src\Util; namespace Friendica\Test\src\Util;
use Error;
use Friendica\Model\Group; use Friendica\Model\Group;
use Friendica\Util\ACLFormatter; use Friendica\Util\ACLFormatter;
use PHPUnit\Framework\TestCase; use PHPUnit\Framework\TestCase;

View file

@ -64,11 +64,12 @@ class BasePathTest extends MockedTest
/** /**
* Test the basepath determination with a complete wrong path * Test the basepath determination with a complete wrong path
* @expectedException \Exception
* @expectedExceptionMessageRegExp /(.*) is not a valid basepath/
*/ */
public function testFailedBasePath() public function testFailedBasePath()
{ {
$this->expectException(\Exception::class);
$this->expectExceptionMessageRegExp("/(.*) is not a valid basepath/");
$basepath = new BasePath('/now23452sgfgas', []); $basepath = new BasePath('/now23452sgfgas', []);
$basepath->getPath(); $basepath->getPath();
} }

View file

@ -534,9 +534,9 @@ class BaseURLTest extends MockedTest
self::assertFalse($baseUrl->save('test', 10, 'nope')); self::assertFalse($baseUrl->save('test', 10, 'nope'));
// nothing should have changed because we never successfully saved anything // nothing should have changed because we never successfully saved anything
self::assertEquals($baseUrl->getHostname(), 'friendica.local'); self::assertEquals('friendica.local', $baseUrl->getHostname());
self::assertEquals($baseUrl->getUrlPath(), 'new/test'); self::assertEquals('new/test', $baseUrl->getUrlPath());
self::assertEquals($baseUrl->getSSLPolicy(), BaseURL::DEFAULT_SSL_SCHEME); self::assertEquals(BaseURL::DEFAULT_SSL_SCHEME, $baseUrl->getSSLPolicy());
self::assertEquals($baseUrl->get(), 'http://friendica.local/new/test'); self::assertEquals('http://friendica.local/new/test', $baseUrl->get());
} }
} }

View file

@ -55,11 +55,12 @@ class ConfigFileLoaderTest extends MockedTest
/** /**
* Test the loadConfigFiles() method with a wrong local.config.php * Test the loadConfigFiles() method with a wrong local.config.php
* @expectedException \Exception *
* @expectedExceptionMessageRegExp /Error loading config file \w+/
*/ */
public function testLoadConfigWrong() public function testLoadConfigWrong()
{ {
$this->expectExceptionMessageRegExp("/Error loading config file \w+/");
$this->expectException(\Exception::class);
$this->delConfigFile('local.config.php'); $this->delConfigFile('local.config.php');
vfsStream::newFile('local.config.php') vfsStream::newFile('local.config.php')

View file

@ -19,6 +19,8 @@
* *
* This is in the same namespace as Crypto for mocking 'rand' and 'random_init' * This is in the same namespace as Crypto for mocking 'rand' and 'random_init'
*/ */
/// @todo Use right namespace - needs alternative way of mocking random_int()
namespace Friendica\Util; namespace Friendica\Util;
use phpseclib\Crypt\RSA; use phpseclib\Crypt\RSA;
@ -120,7 +122,6 @@ function random_int($min, $max)
{ {
global $phpMock; global $phpMock;
if (isset($phpMock['random_int'])) { if (isset($phpMock['random_int'])) {
$result = call_user_func_array($phpMock['random_int'], func_get_args()); return call_user_func_array($phpMock['random_int'], func_get_args());
return $result;
} }
} }

View file

@ -35,9 +35,6 @@ class EMailerTest extends MockedTest
/** @var BaseURL|MockInterface */ /** @var BaseURL|MockInterface */
private $baseUrl; private $baseUrl;
/** @var string */
private $defaultHeaders;
protected function setUp() protected function setUp()
{ {
parent::setUp(); parent::setUp();
@ -54,8 +51,6 @@ class EMailerTest extends MockedTest
$this->baseUrl = \Mockery::mock(BaseURL::class); $this->baseUrl = \Mockery::mock(BaseURL::class);
$this->baseUrl->shouldReceive('getHostname')->andReturn('friendica.local'); $this->baseUrl->shouldReceive('getHostname')->andReturn('friendica.local');
$this->baseUrl->shouldReceive('get')->andReturn('http://friendica.local'); $this->baseUrl->shouldReceive('get')->andReturn('http://friendica.local');
$this->defaultHeaders = [];
} }
protected function tearDown() protected function tearDown()

View file

@ -24,6 +24,7 @@ namespace Friendica\Test\src\Util\Emailer;
use Friendica\App\BaseURL; use Friendica\App\BaseURL;
use Friendica\Core\Config\IConfig; use Friendica\Core\Config\IConfig;
use Friendica\Core\L10n; use Friendica\Core\L10n;
use Friendica\Network\HTTPException\InternalServerErrorException;
use Friendica\Object\EMail\IEmail; use Friendica\Object\EMail\IEmail;
use Friendica\Test\MockedTest; use Friendica\Test\MockedTest;
use Friendica\Test\Util\SampleMailBuilder; use Friendica\Test\Util\SampleMailBuilder;
@ -50,7 +51,7 @@ class MailBuilderTest extends MockedTest
/** @var string */ /** @var string */
private $defaultHeaders; private $defaultHeaders;
public function setUp() protected function setUp()
{ {
parent::setUp(); parent::setUp();
@ -95,7 +96,7 @@ class MailBuilderTest extends MockedTest
*/ */
public function testBuilderWithNonRawEmail() public function testBuilderWithNonRawEmail()
{ {
$this->markTestIncomplete('Cannot easily mock Renderer and BBCode, so skipping tests wit them'); static::markTestIncomplete('Cannot easily mock Renderer and BBCode, so skipping tests wit them');
} }
/** /**
@ -128,11 +129,12 @@ class MailBuilderTest extends MockedTest
/** /**
* Test if the builder throws an exception in case no recipient * Test if the builder throws an exception in case no recipient
* *
* @expectedException \Friendica\Network\HTTPException\InternalServerErrorException
* @expectedExceptionMessage Recipient address is missing.
*/ */
public function testBuilderWithEmptyMail() public function testBuilderWithEmptyMail()
{ {
$this->expectException(InternalServerErrorException::class);
$this->expectExceptionMessage("Recipient address is missing.");
$builder = new SampleMailBuilder($this->l10n, $this->baseUrl, $this->config, new NullLogger()); $builder = new SampleMailBuilder($this->l10n, $this->baseUrl, $this->config, new NullLogger());
$builder->build(true); $builder->build(true);
@ -140,12 +142,12 @@ class MailBuilderTest extends MockedTest
/** /**
* Test if the builder throws an exception in case no sender * Test if the builder throws an exception in case no sender
*
* @expectedException \Friendica\Network\HTTPException\InternalServerErrorException
* @expectedExceptionMessage Sender address or name is missing.
*/ */
public function testBuilderWithEmptySender() public function testBuilderWithEmptySender()
{ {
$this->expectException(InternalServerErrorException::class);
$this->expectExceptionMessage("Sender address or name is missing.");
$builder = new SampleMailBuilder($this->l10n, $this->baseUrl, $this->config, new NullLogger()); $builder = new SampleMailBuilder($this->l10n, $this->baseUrl, $this->config, new NullLogger());
$builder $builder

View file

@ -41,10 +41,7 @@ class SystemMailBuilderTest extends MockedTest
/** @var BaseURL */ /** @var BaseURL */
private $baseUrl; private $baseUrl;
/** @var string[] */ protected function setUp()
private $defaultHeaders;
public function setUp()
{ {
parent::setUp(); parent::setUp();
@ -59,8 +56,6 @@ class SystemMailBuilderTest extends MockedTest
$this->baseUrl = \Mockery::mock(BaseURL::class); $this->baseUrl = \Mockery::mock(BaseURL::class);
$this->baseUrl->shouldReceive('getHostname')->andReturn('friendica.local'); $this->baseUrl->shouldReceive('getHostname')->andReturn('friendica.local');
$this->baseUrl->shouldReceive('get')->andReturn('http://friendica.local'); $this->baseUrl->shouldReceive('get')->andReturn('http://friendica.local');
$this->defaultHeaders = [];
} }
/** /**

View file

@ -32,11 +32,6 @@ class StreamLoggerTest extends AbstractLoggerTest
{ {
use VFSTrait; use VFSTrait;
/**
* @var StreamLogger
*/
private $logger;
/** /**
* @var vfsStreamFile * @var vfsStreamFile
*/ */
@ -53,7 +48,7 @@ class StreamLoggerTest extends AbstractLoggerTest
$this->setUpVfsDir(); $this->setUpVfsDir();
$this->fileSystem = new Filesystem(); $this->fileSystem = new FileSystem();
} }
/** /**
@ -64,9 +59,9 @@ class StreamLoggerTest extends AbstractLoggerTest
$this->logfile = vfsStream::newFile('friendica.log') $this->logfile = vfsStream::newFile('friendica.log')
->at($this->root); ->at($this->root);
$this->logger = new StreamLogger('test', $this->logfile->url(), $this->introspection, $this->fileSystem, $level); $logger = new StreamLogger('test', $this->logfile->url(), $this->introspection, $this->fileSystem, $level);
return $this->logger; return $logger;
} }
/** /**
@ -116,11 +111,12 @@ class StreamLoggerTest extends AbstractLoggerTest
/** /**
* Test when a file isn't set * Test when a file isn't set
* @expectedException \LogicException
* @expectedExceptionMessage Missing stream URL.
*/ */
public function testNoUrl() public function testNoUrl()
{ {
$this->expectException(\LogicException::class);
$this->expectExceptionMessage("Missing stream URL.");
$logger = new StreamLogger('test', '', $this->introspection, $this->fileSystem); $logger = new StreamLogger('test', '', $this->introspection, $this->fileSystem);
$logger->emergency('not working'); $logger->emergency('not working');
@ -128,11 +124,12 @@ class StreamLoggerTest extends AbstractLoggerTest
/** /**
* Test when a file cannot be opened * Test when a file cannot be opened
* @expectedException \UnexpectedValueException
* @expectedExceptionMessageRegExp /The stream or file .* could not be opened: .* /
*/ */
public function testWrongUrl() public function testWrongUrl()
{ {
$this->expectException(\UnexpectedValueException::class);
$this->expectExceptionMessageRegExp("/The stream or file .* could not be opened: .* /");
$logfile = vfsStream::newFile('friendica.log') $logfile = vfsStream::newFile('friendica.log')
->at($this->root)->chmod(0); ->at($this->root)->chmod(0);
@ -143,12 +140,13 @@ class StreamLoggerTest extends AbstractLoggerTest
/** /**
* Test when the directory cannot get created * Test when the directory cannot get created
* @expectedException \UnexpectedValueException
* @expectedExceptionMessageRegExp /Directory .* cannot get created: .* /
*/ */
public function testWrongDir() public function testWrongDir()
{ {
$this->markTestIncomplete('We need a platform independent way to set directory to readonly'); $this->expectException(\UnexpectedValueException::class);
$this->expectExceptionMessageRegExp("/Directory .* cannot get created: .* /");
static::markTestIncomplete('We need a platform independent way to set directory to readonly');
$logger = new StreamLogger('test', '/$%/wrong/directory/file.txt', $this->introspection, $this->fileSystem); $logger = new StreamLogger('test', '/$%/wrong/directory/file.txt', $this->introspection, $this->fileSystem);
@ -157,21 +155,23 @@ class StreamLoggerTest extends AbstractLoggerTest
/** /**
* Test when the minimum level is not valid * Test when the minimum level is not valid
* @expectedException \InvalidArgumentException
* @expectedExceptionMessageRegExp /The level ".*" is not valid./
*/ */
public function testWrongMinimumLevel() public function testWrongMinimumLevel()
{ {
$this->expectException(\InvalidArgumentException::class);
$this->expectExceptionMessageRegExp("/The level \".*\" is not valid./");
$logger = new StreamLogger('test', 'file.text', $this->introspection, $this->fileSystem, 'NOPE'); $logger = new StreamLogger('test', 'file.text', $this->introspection, $this->fileSystem, 'NOPE');
} }
/** /**
* Test when the minimum level is not valid * Test when the minimum level is not valid
* @expectedException \InvalidArgumentException
* @expectedExceptionMessageRegExp /The level ".*" is not valid./
*/ */
public function testWrongLogLevel() public function testWrongLogLevel()
{ {
$this->expectException(\InvalidArgumentException::class);
$this->expectExceptionMessageRegExp("/The level \".*\" is not valid./");
$logfile = vfsStream::newFile('friendica.log') $logfile = vfsStream::newFile('friendica.log')
->at($this->root); ->at($this->root);
@ -182,11 +182,12 @@ class StreamLoggerTest extends AbstractLoggerTest
/** /**
* Test when the file is null * Test when the file is null
* @expectedException \InvalidArgumentException
* @expectedExceptionMessage A stream must either be a resource or a string.
*/ */
public function testWrongFile() public function testWrongFile()
{ {
$this->expectException(\InvalidArgumentException::class);
$this->expectExceptionMessage("A stream must either be a resource or a string.");
$logger = new StreamLogger('test', null, $this->introspection, $this->fileSystem); $logger = new StreamLogger('test', null, $this->introspection, $this->fileSystem);
} }
@ -195,7 +196,7 @@ class StreamLoggerTest extends AbstractLoggerTest
*/ */
public function testRealPath() public function testRealPath()
{ {
$this->markTestSkipped('vfsStream isn\'t compatible with chdir, so not testable.'); static::markTestSkipped('vfsStream isn\'t compatible with chdir, so not testable.');
$logfile = vfsStream::newFile('friendica.log') $logfile = vfsStream::newFile('friendica.log')
->at($this->root); ->at($this->root);

View file

@ -59,21 +59,23 @@ class SyslogLoggerTest extends AbstractLoggerTest
/** /**
* Test when the minimum level is not valid * Test when the minimum level is not valid
* @expectedException \InvalidArgumentException
* @expectedExceptionMessageRegExp /The level ".*" is not valid./
*/ */
public function testWrongMinimumLevel() public function testWrongMinimumLevel()
{ {
$this->expectException(\InvalidArgumentException::class);
$this->expectExceptionMessageRegExp("/The level \".*\" is not valid./");
$logger = new SyslogLoggerWrapper('test', $this->introspection, 'NOPE'); $logger = new SyslogLoggerWrapper('test', $this->introspection, 'NOPE');
} }
/** /**
* Test when the minimum level is not valid * Test when the minimum level is not valid
* @expectedException \InvalidArgumentException
* @expectedExceptionMessageRegExp /The level ".*" is not valid./
*/ */
public function testWrongLogLevel() public function testWrongLogLevel()
{ {
$this->expectException(\InvalidArgumentException::class);
$this->expectExceptionMessageRegExp("/The level \".*\" is not valid./");
$logger = new SyslogLoggerWrapper('test', $this->introspection); $logger = new SyslogLoggerWrapper('test', $this->introspection);
$logger->log('NOPE', 'a test'); $logger->log('NOPE', 'a test');
@ -81,11 +83,12 @@ class SyslogLoggerTest extends AbstractLoggerTest
/** /**
* Test when the logfacility is wrong (string) * Test when the logfacility is wrong (string)
* @expectedException \UnexpectedValueException
* @expectedExceptionMessageRegExp /Can\'t open syslog for ident ".*" and facility ".*": .* /
*/ */
public function testServerException() public function testServerException()
{ {
$this->expectException(\UnexpectedValueException::class);
$this->expectExceptionMessageRegExp("/Can\'t open syslog for ident \".*\" and facility \".*\": .* /");
$logger = new SyslogLoggerWrapper('test', $this->introspection, LogLevel::DEBUG, null, 'a string'); $logger = new SyslogLoggerWrapper('test', $this->introspection, LogLevel::DEBUG, null, 'a string');
$logger->emergency('not working'); $logger->emergency('not working');
} }

View file

@ -51,6 +51,7 @@ class SyslogLoggerWrapper extends SyslogLogger
/** /**
* {@inheritdoc} * {@inheritdoc}
* @noinspection PhpMissingParentCallCommonInspection
*/ */
protected function syslogWrapper($level, $entry) protected function syslogWrapper($level, $entry)
{ {

View file

@ -34,10 +34,12 @@ class WorkerLoggerTest extends MockedTest
/** /**
* Test the a id with length zero * Test the a id with length zero
* @expectedException \Error *
*/ */
public function testGetWorkerIdZero() public function testGetWorkerIdZero()
{ {
$this->expectException(\Error::class);
$logger = \Mockery::mock(LoggerInterface::class); $logger = \Mockery::mock(LoggerInterface::class);
new WorkerLogger($logger, 'test', 0); new WorkerLogger($logger, 'test', 0);
} }

View file

@ -53,6 +53,8 @@ class ProfilerTest extends MockedTest
->andReturn(true) ->andReturn(true)
->twice(); ->twice();
$profiler = new Profiler($configCache); $profiler = new Profiler($configCache);
self::assertInstanceOf(Profiler::class, $profiler);
} }
/** /**
@ -141,7 +143,7 @@ class ProfilerTest extends MockedTest
* Test the Profiler reset * Test the Profiler reset
* @dataProvider dataPerformance * @dataProvider dataPerformance
*/ */
public function testReset($timestamp, $name, array $functions) public function testReset($timestamp, $name)
{ {
$configCache = \Mockery::mock(Cache::class); $configCache = \Mockery::mock(Cache::class);
$configCache->shouldReceive('get') $configCache->shouldReceive('get')

View file

@ -126,11 +126,11 @@ class StringsTest extends TestCase
* Tests if the string is a valid hexadecimal value * Tests if the string is a valid hexadecimal value
* *
* @param string $input * @param string $input
* @param bool $valid * @param bool $valid
* *
* @dataProvider dataIsHex * @dataProvider dataIsHex
*/ */
public function testIsHex($input, $valid) public function testIsHex(string $input, bool $valid)
{ {
self::assertEquals($valid, Strings::isHex($input)); self::assertEquals($valid, Strings::isHex($input));
} }

View file

@ -29,36 +29,36 @@ use PHPUnit\Framework\TestCase;
*/ */
class XmlTest extends TestCase class XmlTest extends TestCase
{ {
/** /**
* escape and unescape * escape and unescape
*/ */
public function testEscapeUnescape() public function testEscapeUnescape()
{ {
$text="<tag>I want to break\n this!11!<?hard?></tag>"; $text = "<tag>I want to break\n this!11!<?hard?></tag>";
$xml=XML::escape($text); $xml = XML::escape($text);
$retext=XML::unescape($text); $retext = XML::unescape($text);
self::assertEquals($text, $retext); self::assertEquals($text, $retext);
} }
/** /**
* escape and put in a document * escape and put in a document
*/ */
public function testEscapeDocument() public function testEscapeDocument()
{ {
$tag="<tag>I want to break</tag>"; $tag = "<tag>I want to break</tag>";
$xml=XML::escape($tag); $xml = XML::escape($tag);
$text='<text>'.$xml.'</text>'; $text = '<text>' . $xml . '</text>';
$xml_parser=xml_parser_create(); $xml_parser = xml_parser_create();
//should be possible to parse it //should be possible to parse it
$values=array(); $values = [];
$index=array(); $index = [];
self::assertEquals(1, xml_parse_into_struct($xml_parser, $text, $values, $index)); self::assertEquals(1, xml_parse_into_struct($xml_parser, $text, $values, $index));
self::assertEquals( self::assertEquals(
array('TEXT'=>array(0)), ['TEXT' => [0]],
$index $index
); );
self::assertEquals( self::assertEquals(
array(array('tag'=>'TEXT', 'type'=>'complete', 'level'=>1, 'value'=>$tag)), [['tag' => 'TEXT', 'type' => 'complete', 'level' => 1, 'value' => $tag]],
$values $values
); );
xml_parser_free($xml_parser); xml_parser_free($xml_parser);