mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
Merge branch '4.0' into 4
This commit is contained in:
commit
6d5cbe0a0e
@ -12,6 +12,7 @@ Our web-based [PHP installer](installation/) can check if you meet the requireme
|
|||||||
* Once PHP versions become [unsupported by the PHP Project](http://php.net/supported-versions.php),
|
* Once PHP versions become [unsupported by the PHP Project](http://php.net/supported-versions.php),
|
||||||
we drop support for those versions in the [next minor release](/contributing/release-process). This means that PHP 5.6 support may be dropped in a 4.x minor release after December 2018.
|
we drop support for those versions in the [next minor release](/contributing/release-process). This means that PHP 5.6 support may be dropped in a 4.x minor release after December 2018.
|
||||||
* We recommend using a PHP accelerator or opcode cache, such as [xcache](http://xcache.lighttpd.net/) or [WinCache](http://www.iis.net/download/wincacheforphp).
|
* We recommend using a PHP accelerator or opcode cache, such as [xcache](http://xcache.lighttpd.net/) or [WinCache](http://www.iis.net/download/wincacheforphp).
|
||||||
|
* Note: Some PHP 5.5+ packages already have [Zend OpCache](http://php.net/manual/en/book.opcache.php) installed by default. If this is the case on your system, do not try and run additional opcaches alongside Zend OpCache without first disabling it, as it will likely have unexpected consequences.
|
||||||
* Allocate at least 48MB of memory to each PHP process. (SilverStripe can be resource hungry for some intensive operations.)
|
* Allocate at least 48MB of memory to each PHP process. (SilverStripe can be resource hungry for some intensive operations.)
|
||||||
* PHP requires a suitable CSPRNG (random number generator) source for generating random tokens, password salts etc. This can be any of the following, and most operating systems will have at least one source available:
|
* PHP requires a suitable CSPRNG (random number generator) source for generating random tokens, password salts etc. This can be any of the following, and most operating systems will have at least one source available:
|
||||||
* PHP 7 `random_bytes()`:
|
* PHP 7 `random_bytes()`:
|
||||||
|
@ -1813,6 +1813,8 @@ If left unset, this will raise an error.
|
|||||||
to see if there is a url to redirect back to.
|
to see if there is a url to redirect back to.
|
||||||
* Renamed `LeftAndMain_TreeNode` to `CMSMain_TreeNode`
|
* Renamed `LeftAndMain_TreeNode` to `CMSMain_TreeNode`
|
||||||
* Removed `LeftAndMain::SiteTreeAsUL()` (override left in `CMSMain`)
|
* Removed `LeftAndMain::SiteTreeAsUL()` (override left in `CMSMain`)
|
||||||
|
* Removed `LeftAndMain::setApplicationLink()` (Deprecated from 3.x)
|
||||||
|
* Removed `LeftAndMain::setApplicationName()` (Deprecated from 3.x)
|
||||||
* Moved `LeftAndMain::getSiteTreeFor()` to `CMSMain`
|
* Moved `LeftAndMain::getSiteTreeFor()` to `CMSMain`
|
||||||
* Moved `LeftAndMain::getsubtree()` to `CMSMain`
|
* Moved `LeftAndMain::getsubtree()` to `CMSMain`
|
||||||
* Moved `LeftAndMain::updatetreenodes()` to `CMSMain`
|
* Moved `LeftAndMain::updatetreenodes()` to `CMSMain`
|
||||||
|
@ -308,7 +308,7 @@ class HTTP
|
|||||||
|
|
||||||
// Fallback to use the list from the HTTP.yml configuration and rely on the file extension
|
// Fallback to use the list from the HTTP.yml configuration and rely on the file extension
|
||||||
// to get the file mime-type
|
// to get the file mime-type
|
||||||
$ext = File::get_file_extension($filename);
|
$ext = strtolower(File::get_file_extension($filename));
|
||||||
// Get the mime-types
|
// Get the mime-types
|
||||||
$mimeTypes = HTTP::config()->uninherited('MimeTypes');
|
$mimeTypes = HTTP::config()->uninherited('MimeTypes');
|
||||||
|
|
||||||
|
@ -5,6 +5,7 @@ namespace SilverStripe\Core\Cache;
|
|||||||
use Psr\Log\LoggerAwareInterface;
|
use Psr\Log\LoggerAwareInterface;
|
||||||
use Psr\Log\LoggerInterface;
|
use Psr\Log\LoggerInterface;
|
||||||
use Psr\SimpleCache\CacheInterface;
|
use Psr\SimpleCache\CacheInterface;
|
||||||
|
use SilverStripe\Control\Director;
|
||||||
use SilverStripe\Core\Injector\Injector;
|
use SilverStripe\Core\Injector\Injector;
|
||||||
use Symfony\Component\Cache\Simple\FilesystemCache;
|
use Symfony\Component\Cache\Simple\FilesystemCache;
|
||||||
use Symfony\Component\Cache\Simple\ApcuCache;
|
use Symfony\Component\Cache\Simple\ApcuCache;
|
||||||
@ -85,7 +86,8 @@ class DefaultCacheFactory implements CacheFactory
|
|||||||
{
|
{
|
||||||
static $apcuSupported = null;
|
static $apcuSupported = null;
|
||||||
if (null === $apcuSupported) {
|
if (null === $apcuSupported) {
|
||||||
$apcuSupported = ApcuAdapter::isSupported();
|
// Need to check for CLI because Symfony won't: https://github.com/symfony/symfony/pull/25080
|
||||||
|
$apcuSupported = Director::is_cli() ? ini_get('apc.enable_cli') && ApcuAdapter::isSupported() : ApcuAdapter::isSupported();
|
||||||
}
|
}
|
||||||
return $apcuSupported;
|
return $apcuSupported;
|
||||||
}
|
}
|
||||||
|
@ -218,6 +218,13 @@ class SapphireTest extends PHPUnit_Framework_TestCase implements TestOnly
|
|||||||
*/
|
*/
|
||||||
protected function setUp()
|
protected function setUp()
|
||||||
{
|
{
|
||||||
|
if (!defined('FRAMEWORK_PATH')) {
|
||||||
|
trigger_error(
|
||||||
|
'Missing constants, did you remember to include the test bootstrap in your phpunit.xml file?',
|
||||||
|
E_USER_WARNING
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
// Call state helpers
|
// Call state helpers
|
||||||
static::$state->setUp($this);
|
static::$state->setUp($this);
|
||||||
|
|
||||||
|
@ -2862,7 +2862,7 @@ class DataObject extends ViewableData implements DataObjectInterface, i18nEntity
|
|||||||
$SNG = singleton($callerClass);
|
$SNG = singleton($callerClass);
|
||||||
|
|
||||||
$cacheComponents = array($filter, $orderby, $SNG->extend('cacheKeyComponent'));
|
$cacheComponents = array($filter, $orderby, $SNG->extend('cacheKeyComponent'));
|
||||||
$cacheKey = md5(var_export($cacheComponents, true));
|
$cacheKey = md5(serialize($cacheComponents));
|
||||||
|
|
||||||
$item = null;
|
$item = null;
|
||||||
if (!$cache || !isset(self::$_cache_get_one[$callerClass][$cacheKey])) {
|
if (!$cache || !isset(self::$_cache_get_one[$callerClass][$cacheKey])) {
|
||||||
|
@ -205,6 +205,7 @@ class HTTPTest extends FunctionalTest
|
|||||||
$this->assertEquals('image/gif', HTTP::get_mime_type('file.gif'));
|
$this->assertEquals('image/gif', HTTP::get_mime_type('file.gif'));
|
||||||
$this->assertEquals('text/html', HTTP::get_mime_type('file.html'));
|
$this->assertEquals('text/html', HTTP::get_mime_type('file.html'));
|
||||||
$this->assertEquals('image/jpeg', HTTP::get_mime_type('file.jpg'));
|
$this->assertEquals('image/jpeg', HTTP::get_mime_type('file.jpg'));
|
||||||
|
$this->assertEquals('image/jpeg', HTTP::get_mime_type('upperfile.JPG'));
|
||||||
$this->assertEquals('image/png', HTTP::get_mime_type('file.png'));
|
$this->assertEquals('image/png', HTTP::get_mime_type('file.png'));
|
||||||
$this->assertEquals(
|
$this->assertEquals(
|
||||||
'image/vnd.adobe.photoshop',
|
'image/vnd.adobe.photoshop',
|
||||||
|
BIN
tests/php/Control/HTTPTest/upperfile.JPG
Normal file
BIN
tests/php/Control/HTTPTest/upperfile.JPG
Normal file
Binary file not shown.
After Width: | Height: | Size: 331 B |
@ -137,7 +137,7 @@ class HTMLEditorFieldTest extends FunctionalTest
|
|||||||
$this->assertEquals(20, (int)$xml[0]['height'], 'Height tag of resized image is set.');
|
$this->assertEquals(20, (int)$xml[0]['height'], 'Height tag of resized image is set.');
|
||||||
|
|
||||||
$neededFilename
|
$neededFilename
|
||||||
= '/assets/HTMLEditorFieldTest/f5c7c2f814/example__ResizedImageWyIxMCIsIjIwIl0.jpg';
|
= '/assets/HTMLEditorFieldTest/f5c7c2f814/example__ResizedImageWzEwLDIwXQ.jpg';
|
||||||
|
|
||||||
$this->assertEquals($neededFilename, (string)$xml[0]['src'], 'Correct URL of resized image is set.');
|
$this->assertEquals($neededFilename, (string)$xml[0]['src'], 'Correct URL of resized image is set.');
|
||||||
$this->assertTrue(file_exists(BASE_PATH.DIRECTORY_SEPARATOR.$neededFilename), 'File for resized image exists');
|
$this->assertTrue(file_exists(BASE_PATH.DIRECTORY_SEPARATOR.$neededFilename), 'File for resized image exists');
|
||||||
@ -186,7 +186,7 @@ class HTMLEditorFieldTest extends FunctionalTest
|
|||||||
$this->assertEquals(
|
$this->assertEquals(
|
||||||
<<<EOS
|
<<<EOS
|
||||||
<span class="readonly typography" id="Content">
|
<span class="readonly typography" id="Content">
|
||||||
<img src="/assets/HTMLEditorFieldTest/f5c7c2f814/example__ResizedImageWyIxMCIsIjIwIl0.jpg" alt="example" width="10" height="20">
|
<img src="/assets/HTMLEditorFieldTest/f5c7c2f814/example__ResizedImageWzEwLDIwXQ.jpg" alt="example" width="10" height="20">
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
|
||||||
@ -203,7 +203,7 @@ EOS
|
|||||||
$this->assertEquals(
|
$this->assertEquals(
|
||||||
<<<EOS
|
<<<EOS
|
||||||
<span class="readonly typography" id="Content">
|
<span class="readonly typography" id="Content">
|
||||||
<img src="/assets/HTMLEditorFieldTest/f5c7c2f814/example__ResizedImageWyIxMCIsIjIwIl0.jpg" alt="example" width="10" height="20">
|
<img src="/assets/HTMLEditorFieldTest/f5c7c2f814/example__ResizedImageWzEwLDIwXQ.jpg" alt="example" width="10" height="20">
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
<input type="hidden" name="Content" value="[image src="/assets/HTMLEditorFieldTest/f5c7c2f814/example.jpg" width="10" height="20" id="{$fileID}"]" />
|
<input type="hidden" name="Content" value="[image src="/assets/HTMLEditorFieldTest/f5c7c2f814/example.jpg" width="10" height="20" id="{$fileID}"]" />
|
||||||
|
@ -930,6 +930,16 @@ class DataListTest extends SapphireTest
|
|||||||
$this->assertEquals(1, $list->count());
|
$this->assertEquals(1, $list->count());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testFilterAnyWithRelation()
|
||||||
|
{
|
||||||
|
$list = Player::get();
|
||||||
|
$list = $list->filterAny(array(
|
||||||
|
'Teams.Title:StartsWith' => 'Team',
|
||||||
|
'ID:GreaterThan' => 0,
|
||||||
|
));
|
||||||
|
$this->assertCount(4, $list);
|
||||||
|
}
|
||||||
|
|
||||||
public function testFilterAnyMultipleArray()
|
public function testFilterAnyMultipleArray()
|
||||||
{
|
{
|
||||||
$list = TeamComment::get();
|
$list = TeamComment::get();
|
||||||
|
@ -84,7 +84,7 @@ class DataQueryTest extends SapphireTest
|
|||||||
$this->assertContains('"testctwo_DataQueryTest_C"."ID" = "DataQueryTest_B"."TestCTwoID"', $dq->sql());
|
$this->assertContains('"testctwo_DataQueryTest_C"."ID" = "DataQueryTest_B"."TestCTwoID"', $dq->sql());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testApplyReplationDeepInheretence()
|
public function testApplyRelationDeepInheritance()
|
||||||
{
|
{
|
||||||
//test has_one relation
|
//test has_one relation
|
||||||
$newDQ = new DataQuery(DataQueryTest\ObjectE::class);
|
$newDQ = new DataQuery(DataQueryTest\ObjectE::class);
|
||||||
|
Loading…
Reference in New Issue
Block a user