mirror of
https://github.com/EGroupware/egroupware.git
synced 2024-11-24 08:53:37 +01:00
Some more test work
- Refactoring to reduce duplication - Add tests for filesystem StreamWrapper - Clear infolog's access cache
This commit is contained in:
parent
9c4942957f
commit
7d941c8bfe
@ -12,6 +12,7 @@
|
|||||||
|
|
||||||
namespace EGroupware\Api\Vfs;
|
namespace EGroupware\Api\Vfs;
|
||||||
|
|
||||||
|
use EGroupware\Api\Config;
|
||||||
use EGroupware\Api\Vfs;
|
use EGroupware\Api\Vfs;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -133,7 +134,7 @@ class Base
|
|||||||
|
|
||||||
if ($persitent_mount)
|
if ($persitent_mount)
|
||||||
{
|
{
|
||||||
Api\Config::save_value('vfs_fstab',self::$fstab,'phpgwapi');
|
Config::save_value('vfs_fstab',self::$fstab,'phpgwapi');
|
||||||
$GLOBALS['egw_info']['server']['vfs_fstab'] = self::$fstab;
|
$GLOBALS['egw_info']['server']['vfs_fstab'] = self::$fstab;
|
||||||
// invalidate session cache
|
// invalidate session cache
|
||||||
if (method_exists($GLOBALS['egw'],'invalidate_session_cache')) // egw object in setup is limited
|
if (method_exists($GLOBALS['egw'],'invalidate_session_cache')) // egw object in setup is limited
|
||||||
@ -164,7 +165,7 @@ class Base
|
|||||||
}
|
}
|
||||||
unset(self::$fstab[$path]);
|
unset(self::$fstab[$path]);
|
||||||
|
|
||||||
\EGroupware\Api\Config::save_value('vfs_fstab',self::$fstab,'phpgwapi');
|
Config::save_value('vfs_fstab',self::$fstab,'phpgwapi');
|
||||||
$GLOBALS['egw_info']['server']['vfs_fstab'] = self::$fstab;
|
$GLOBALS['egw_info']['server']['vfs_fstab'] = self::$fstab;
|
||||||
// invalidate session cache
|
// invalidate session cache
|
||||||
if (method_exists($GLOBALS['egw'],'invalidate_session_cache')) // egw object in setup is limited
|
if (method_exists($GLOBALS['egw'],'invalidate_session_cache')) // egw object in setup is limited
|
||||||
|
@ -79,6 +79,9 @@ abstract class LoggedInTest extends TestCase
|
|||||||
// Reset stream context, or current user will always be there
|
// Reset stream context, or current user will always be there
|
||||||
stream_context_set_option(stream_context_get_default(),['vfs'=>['user' => null]]);
|
stream_context_set_option(stream_context_get_default(),['vfs'=>['user' => null]]);
|
||||||
|
|
||||||
|
// Clear some link caching
|
||||||
|
Link::init_static(true);
|
||||||
|
|
||||||
if($GLOBALS['egw'])
|
if($GLOBALS['egw'])
|
||||||
{
|
{
|
||||||
if($GLOBALS['egw']->session)
|
if($GLOBALS['egw']->session)
|
||||||
|
58
api/tests/Vfs/Filesystem/StreamWrapperTest.php
Normal file
58
api/tests/Vfs/Filesystem/StreamWrapperTest.php
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test the basic Vfs::StreamWrapper
|
||||||
|
*
|
||||||
|
* @link http://www.egroupware.org
|
||||||
|
* @author Nathan Gray
|
||||||
|
* @copyright (c) 2020 Nathan Gray
|
||||||
|
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace EGroupware\Api\Vfs\Filesystem;
|
||||||
|
|
||||||
|
require_once __DIR__ . '/../StreamWrapperBase.php';
|
||||||
|
|
||||||
|
use EGroupware\Api;
|
||||||
|
use EGroupware\Api\Vfs;
|
||||||
|
|
||||||
|
|
||||||
|
class StreamWrapperTest extends Vfs\StreamWrapperBase
|
||||||
|
{
|
||||||
|
public static $mountpoint = '/test/filesystem';
|
||||||
|
|
||||||
|
protected function setUp() : void
|
||||||
|
{
|
||||||
|
parent::setUp();
|
||||||
|
|
||||||
|
$this->files[] = $this->test_file = $this->getFilename();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function tearDown() : void
|
||||||
|
{
|
||||||
|
parent::tearDown();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function mount(): void
|
||||||
|
{
|
||||||
|
$this->mountFilesystem(static::$mountpoint);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function allowAccess(string $test_name, string $test_file, int $test_user, string $needed) : void
|
||||||
|
{
|
||||||
|
// We'll allow access by putting test user in Default group
|
||||||
|
$command = new \admin_cmd_edit_user($test_user, ['account_groups' => array_merge($this->account['account_groups'],['Default'])]);
|
||||||
|
$command->run();
|
||||||
|
|
||||||
|
// Add explicit permission on group
|
||||||
|
Vfs::chmod($test_file, Vfs::mode2int('g+'.$needed));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Make a filename that reflects the current test
|
||||||
|
*/
|
||||||
|
protected function getFilename($path = null)
|
||||||
|
{
|
||||||
|
return parent::getFilename(static::$mountpoint);
|
||||||
|
}
|
||||||
|
}
|
@ -25,7 +25,6 @@ class StreamWrapperTest extends Vfs\StreamWrapperBase
|
|||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
$this->mountLinks('/apps');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function tearDown() : void
|
protected function tearDown() : void
|
||||||
@ -65,13 +64,18 @@ class StreamWrapperTest extends Vfs\StreamWrapperBase
|
|||||||
parent::testWithAccess();
|
parent::testWithAccess();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function allowAccess(string $test_name, string $test_file, int $test_user, string $needed)
|
protected function allowAccess(string $test_name, string $test_file, int $test_user, string $needed) : void
|
||||||
{
|
{
|
||||||
// We'll allow access by putting test user in responsible
|
// We'll allow access by putting test user in responsible
|
||||||
$so = new \infolog_so();
|
$so = new \infolog_so();
|
||||||
$element = $so->read($this->entries[0]);
|
$element = $so->read(Array('info_id' => $this->entries[0]));
|
||||||
$element['info_responsible'] = [$test_user];
|
$element['info_responsible'] = [$test_user];
|
||||||
$so->write($so);
|
$so->write($element);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function mount() : void
|
||||||
|
{
|
||||||
|
$this->mountLinks('/apps');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -21,7 +21,7 @@ use EGroupware\Api\Vfs;
|
|||||||
use EGroupware\Stylite\Vfs\Versioning;
|
use EGroupware\Stylite\Vfs\Versioning;
|
||||||
|
|
||||||
|
|
||||||
class StreamWrapperBase extends LoggedInTest
|
abstract class StreamWrapperBase extends LoggedInTest
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* How much should be logged to the console (stdout)
|
* How much should be logged to the console (stdout)
|
||||||
@ -84,6 +84,7 @@ class StreamWrapperBase extends LoggedInTest
|
|||||||
{
|
{
|
||||||
$this->markTestSkipped('No write access to files dir "' .$GLOBALS['egw_info']['server']['files_dir'].'"' );
|
$this->markTestSkipped('No write access to files dir "' .$GLOBALS['egw_info']['server']['files_dir'].'"' );
|
||||||
}
|
}
|
||||||
|
$this->mount();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function tearDown() : void
|
protected function tearDown() : void
|
||||||
@ -249,9 +250,11 @@ class StreamWrapperBase extends LoggedInTest
|
|||||||
// Log in as them
|
// Log in as them
|
||||||
$this->switchUser($this->account['account_lid'], $this->account['account_passwd']);
|
$this->switchUser($this->account['account_lid'], $this->account['account_passwd']);
|
||||||
|
|
||||||
|
$this->mount();
|
||||||
|
|
||||||
// Check the file
|
// Check the file
|
||||||
$post = Vfs::stat($file);
|
$this->assertFalse(
|
||||||
$this->assertEquals(null,$post,
|
Vfs::is_readable($file),
|
||||||
"File '$file' was accessible by another user who had no permission"
|
"File '$file' was accessible by another user who had no permission"
|
||||||
);
|
);
|
||||||
$this->assertFalse(
|
$this->assertFalse(
|
||||||
@ -305,6 +308,8 @@ class StreamWrapperBase extends LoggedInTest
|
|||||||
// Log in as them
|
// Log in as them
|
||||||
$this->switchUser($this->account['account_lid'], $this->account['account_passwd']);
|
$this->switchUser($this->account['account_lid'], $this->account['account_passwd']);
|
||||||
|
|
||||||
|
$this->mount();
|
||||||
|
|
||||||
// Check the file
|
// Check the file
|
||||||
$post = Vfs::stat($file);
|
$post = Vfs::stat($file);
|
||||||
$this->assertNotNull($post,
|
$this->assertNotNull($post,
|
||||||
@ -386,6 +391,26 @@ class StreamWrapperBase extends LoggedInTest
|
|||||||
return $path . $reflect->getShortName() . '_' . $this->getName() . '.txt';
|
return $path . $reflect->getShortName() . '_' . $this->getName() . '.txt';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Mount the needed filesystem
|
||||||
|
*
|
||||||
|
* This may be called multiple times for each test as we change users, logout, etc.
|
||||||
|
*/
|
||||||
|
abstract protected function mount() : void;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Allow access to the given file for the given user ID
|
||||||
|
*
|
||||||
|
* Using whatever way works best for the mount/streamwrapper being tested, allow the user access
|
||||||
|
*
|
||||||
|
* @param string $test_name
|
||||||
|
* @param string $test_file
|
||||||
|
* @param int $test_user
|
||||||
|
* @param string $needed r, w, rw
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
abstract protected function allowAccess(string $test_name, string $test_file, int $test_user, string $needed) : void;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Mount the app entries into the filesystem
|
* Mount the app entries into the filesystem
|
||||||
*
|
*
|
||||||
|
@ -24,6 +24,7 @@ class StreamWrapperTest extends StreamWrapperBase
|
|||||||
protected function setUp() : void
|
protected function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
$this->files[] = $this->test_file = $this->getFilename();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function tearDown() : void
|
protected function tearDown() : void
|
||||||
@ -33,21 +34,6 @@ class StreamWrapperTest extends StreamWrapperBase
|
|||||||
parent::tearDown();
|
parent::tearDown();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testSimpleReadWrite(): string
|
|
||||||
{
|
|
||||||
$this->files[] = $this->test_file = $this->getFilename();
|
|
||||||
|
|
||||||
return parent::testSimpleReadWrite();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public function testNoReadAccess(): void
|
|
||||||
{
|
|
||||||
$this->files[] = $this->test_file = $this->getFilename();
|
|
||||||
|
|
||||||
parent::testNoReadAccess();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testWithAccess() : void
|
public function testWithAccess() : void
|
||||||
{
|
{
|
||||||
// Put it in the group directory this time so we can give access
|
// Put it in the group directory this time so we can give access
|
||||||
@ -56,7 +42,12 @@ class StreamWrapperTest extends StreamWrapperBase
|
|||||||
parent::testWithAccess();
|
parent::testWithAccess();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function allowAccess(string $test_name, string $test_file, int $test_user, string $needed)
|
protected function mount(): void
|
||||||
|
{
|
||||||
|
// Nothing here
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function allowAccess(string $test_name, string $test_file, int $test_user, string $needed) : void
|
||||||
{
|
{
|
||||||
// We'll allow access by putting test user in Default group
|
// We'll allow access by putting test user in Default group
|
||||||
$command = new \admin_cmd_edit_user($test_user, ['account_groups' => array_merge($this->account['account_groups'],['Default'])]);
|
$command = new \admin_cmd_edit_user($test_user, ['account_groups' => array_merge($this->account['account_groups'],['Default'])]);
|
||||||
|
@ -46,6 +46,12 @@ class infolog_bo
|
|||||||
* @var boolean
|
* @var boolean
|
||||||
*/
|
*/
|
||||||
var $log = false;
|
var $log = false;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Access permission cache for current user
|
||||||
|
*/
|
||||||
|
protected static $access_cache = array();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Cached timezone data
|
* Cached timezone data
|
||||||
*
|
*
|
||||||
@ -330,15 +336,13 @@ class infolog_bo
|
|||||||
*/
|
*/
|
||||||
function check_access($info,$required_rights,$other=0,$user=null)
|
function check_access($info,$required_rights,$other=0,$user=null)
|
||||||
{
|
{
|
||||||
static $cache = array();
|
|
||||||
|
|
||||||
$info_id = is_array($info) ? $info['info_id'] : $info;
|
$info_id = is_array($info) ? $info['info_id'] : $info;
|
||||||
|
|
||||||
if (!$user) $user = $this->user;
|
if (!$user) $user = $this->user;
|
||||||
if ($user == $this->user)
|
if ($user == $this->user)
|
||||||
{
|
{
|
||||||
$grants = $this->grants;
|
$grants = $this->grants;
|
||||||
if ($info_id) $access =& $cache[$info_id][$required_rights]; // we only cache the current user!
|
if ($info_id) $access =& static::$access_cache[$info_id][$required_rights]; // we only cache the current user!
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -410,6 +414,7 @@ class infolog_bo
|
|||||||
*/
|
*/
|
||||||
function init()
|
function init()
|
||||||
{
|
{
|
||||||
|
static::$access_cache = array();
|
||||||
$this->so->init();
|
$this->so->init();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user