Merge pull request #24940 from owncloud/fix-normalizedcachekey-keepunicode
Add keepUnicode value in the cache key of normalizedPathCache
This commit is contained in:
commit
1ab7ee5e23
|
@ -781,7 +781,7 @@ class Filesystem {
|
|||
*/
|
||||
$path = (string)$path;
|
||||
|
||||
$cacheKey = json_encode([$path, $stripTrailingSlash, $isAbsolutePath]);
|
||||
$cacheKey = json_encode([$path, $stripTrailingSlash, $isAbsolutePath, $keepUnicode]);
|
||||
|
||||
if (isset(self::$normalizedPathCache[$cacheKey])) {
|
||||
return self::$normalizedPathCache[$cacheKey];
|
||||
|
|
|
@ -92,6 +92,7 @@ class FilesystemTest extends \Test\TestCase {
|
|||
}
|
||||
|
||||
$this->logout();
|
||||
$this->invokePrivate('\OC\Files\Filesystem', 'normalizedPathCache', [null]);
|
||||
parent::tearDown();
|
||||
}
|
||||
|
||||
|
@ -190,6 +191,32 @@ class FilesystemTest extends \Test\TestCase {
|
|||
$this->assertEquals($expected, \OC\Files\Filesystem::normalizePath($path, $stripTrailingSlash));
|
||||
}
|
||||
|
||||
public function normalizePathKeepUnicodeData() {
|
||||
$nfdName = 'ümlaut';
|
||||
$nfcName = 'ümlaut';
|
||||
return [
|
||||
['/' . $nfcName, $nfcName, true],
|
||||
['/' . $nfcName, $nfcName, false],
|
||||
['/' . $nfdName, $nfdName, true],
|
||||
['/' . $nfcName, $nfdName, false],
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider normalizePathKeepUnicodeData
|
||||
*/
|
||||
public function testNormalizePathKeepUnicode($expected, $path, $keepUnicode = false) {
|
||||
$this->assertEquals($expected, \OC\Files\Filesystem::normalizePath($path, true, false, $keepUnicode));
|
||||
}
|
||||
|
||||
public function testNormalizePathKeepUnicodeCache() {
|
||||
$nfdName = 'ümlaut';
|
||||
$nfcName = 'ümlaut';
|
||||
// call in succession due to cache
|
||||
$this->assertEquals('/' . $nfcName, \OC\Files\Filesystem::normalizePath($nfdName, true, false, false));
|
||||
$this->assertEquals('/' . $nfdName, \OC\Files\Filesystem::normalizePath($nfdName, true, false, true));
|
||||
}
|
||||
|
||||
public function isValidPathData() {
|
||||
return array(
|
||||
array('/', true),
|
||||
|
|
|
@ -166,7 +166,12 @@ abstract class TestCase extends \PHPUnit_Framework_TestCase {
|
|||
* @return mixed
|
||||
*/
|
||||
protected static function invokePrivate($object, $methodName, array $parameters = array()) {
|
||||
$reflection = new \ReflectionClass(get_class($object));
|
||||
if (is_string($object)) {
|
||||
$className = $object;
|
||||
} else {
|
||||
$className = get_class($object);
|
||||
}
|
||||
$reflection = new \ReflectionClass($className);
|
||||
|
||||
if ($reflection->hasMethod($methodName)) {
|
||||
$method = $reflection->getMethod($methodName);
|
||||
|
|
Loading…
Reference in New Issue