Merge branch '4.1'
* 4.1: [Console] simplified code removed useless phpdoc improve docblocks around group sequences [Cache] prevent getting older entries when the version key is evicted [WebProfilerBundle] added a note in the README [Yaml] Skip parser test with root user [Filesystem] Skip tests on readable file when run with root user [FWBundle] Fix an error in WebTestCase::createClient's PHPDoc [HttpFoundation][Security] forward locale and format to subrequests [Console] Send the right exit code to console.terminate listeners [HttpFoundation] fix hidding warnings from session handlers Caching missed templates on cache warmup
This commit is contained in:
commit
deaf53c231
@ -23,7 +23,7 @@ abstract class WebTestCase extends KernelTestCase
|
|||||||
/**
|
/**
|
||||||
* Creates a Client.
|
* Creates a Client.
|
||||||
*
|
*
|
||||||
* @param array $options An array of options to pass to the createKernel class
|
* @param array $options An array of options to pass to the createKernel method
|
||||||
* @param array $server An array of server parameters
|
* @param array $server An array of server parameters
|
||||||
*
|
*
|
||||||
* @return Client A Client instance
|
* @return Client A Client instance
|
||||||
|
@ -63,7 +63,7 @@ class TemplateIterator implements \IteratorAggregate
|
|||||||
$this->templates = array_merge(
|
$this->templates = array_merge(
|
||||||
$this->templates,
|
$this->templates,
|
||||||
$this->findTemplatesInDirectory($bundle->getPath().'/Resources/views', $name),
|
$this->findTemplatesInDirectory($bundle->getPath().'/Resources/views', $name),
|
||||||
$this->findTemplatesInDirectory($this->rootDir.'/'.$bundle->getName().'/views', $name),
|
$this->findTemplatesInDirectory($this->rootDir.'/Resources/'.$bundle->getName().'/views', $name),
|
||||||
$this->findTemplatesInDirectory($this->defaultPath.'/bundles/'.$bundle->getName(), $name)
|
$this->findTemplatesInDirectory($this->defaultPath.'/bundles/'.$bundle->getName(), $name)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -31,6 +31,7 @@ class TemplateIteratorTest extends TestCase
|
|||||||
sort($sorted);
|
sort($sorted);
|
||||||
$this->assertEquals(
|
$this->assertEquals(
|
||||||
array(
|
array(
|
||||||
|
'@Bar/base.html.twig',
|
||||||
'@Bar/index.html.twig',
|
'@Bar/index.html.twig',
|
||||||
'@Bar/layout.html.twig',
|
'@Bar/layout.html.twig',
|
||||||
'@Foo/index.html.twig',
|
'@Foo/index.html.twig',
|
||||||
|
@ -107,14 +107,7 @@ trait AbstractTrait
|
|||||||
{
|
{
|
||||||
$this->deferred = array();
|
$this->deferred = array();
|
||||||
if ($cleared = $this->versioningIsEnabled) {
|
if ($cleared = $this->versioningIsEnabled) {
|
||||||
$namespaceVersion = 2;
|
$namespaceVersion = substr_replace(base64_encode(pack('V', mt_rand())), ':', 5);
|
||||||
try {
|
|
||||||
foreach ($this->doFetch(array('/'.$this->namespace)) as $v) {
|
|
||||||
$namespaceVersion = 1 + (int) $v;
|
|
||||||
}
|
|
||||||
} catch (\Exception $e) {
|
|
||||||
}
|
|
||||||
$namespaceVersion .= '/';
|
|
||||||
try {
|
try {
|
||||||
$cleared = $this->doSave(array('/'.$this->namespace => $namespaceVersion), 0);
|
$cleared = $this->doSave(array('/'.$this->namespace => $namespaceVersion), 0);
|
||||||
} catch (\Exception $e) {
|
} catch (\Exception $e) {
|
||||||
@ -254,6 +247,10 @@ trait AbstractTrait
|
|||||||
foreach ($this->doFetch(array('/'.$this->namespace)) as $v) {
|
foreach ($this->doFetch(array('/'.$this->namespace)) as $v) {
|
||||||
$this->namespaceVersion = $v;
|
$this->namespaceVersion = $v;
|
||||||
}
|
}
|
||||||
|
if ('1:' === $this->namespaceVersion) {
|
||||||
|
$this->namespaceVersion = substr_replace(base64_encode(pack('V', time())), ':', 5);
|
||||||
|
$this->doSave(array('@'.$this->namespace => $this->namespaceVersion), 0);
|
||||||
|
}
|
||||||
} catch (\Exception $e) {
|
} catch (\Exception $e) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -159,6 +159,8 @@ class Application
|
|||||||
} else {
|
} else {
|
||||||
$exitCode = 1;
|
$exitCode = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return $exitCode;
|
||||||
} finally {
|
} finally {
|
||||||
// if the exception handler changed, keep it
|
// if the exception handler changed, keep it
|
||||||
// otherwise, unregister $renderException
|
// otherwise, unregister $renderException
|
||||||
|
@ -985,6 +985,31 @@ class ApplicationTest extends TestCase
|
|||||||
$this->assertSame(4, $exitCode, '->run() returns integer exit code extracted from raised exception');
|
$this->assertSame(4, $exitCode, '->run() returns integer exit code extracted from raised exception');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testRunDispatchesIntegerExitCode()
|
||||||
|
{
|
||||||
|
$passedRightValue = false;
|
||||||
|
|
||||||
|
// We can assume here that some other test asserts that the event is dispatched at all
|
||||||
|
$dispatcher = new EventDispatcher();
|
||||||
|
$self = $this;
|
||||||
|
$dispatcher->addListener('console.terminate', function (ConsoleTerminateEvent $event) use ($self, &$passedRightValue) {
|
||||||
|
$passedRightValue = (4 === $event->getExitCode());
|
||||||
|
});
|
||||||
|
|
||||||
|
$application = new Application();
|
||||||
|
$application->setDispatcher($dispatcher);
|
||||||
|
$application->setAutoExit(false);
|
||||||
|
|
||||||
|
$application->register('test')->setCode(function (InputInterface $input, OutputInterface $output) {
|
||||||
|
throw new \Exception('', 4);
|
||||||
|
});
|
||||||
|
|
||||||
|
$tester = new ApplicationTester($application);
|
||||||
|
$tester->run(array('command' => 'test'));
|
||||||
|
|
||||||
|
$this->assertTrue($passedRightValue, '-> exit code 4 was passed in the console.terminate event');
|
||||||
|
}
|
||||||
|
|
||||||
public function testRunReturnsExitCodeOneForExceptionCodeZero()
|
public function testRunReturnsExitCodeOneForExceptionCodeZero()
|
||||||
{
|
{
|
||||||
$exception = new \Exception('', 0);
|
$exception = new \Exception('', 0);
|
||||||
@ -1000,6 +1025,31 @@ class ApplicationTest extends TestCase
|
|||||||
$this->assertSame(1, $exitCode, '->run() returns exit code 1 when exception code is 0');
|
$this->assertSame(1, $exitCode, '->run() returns exit code 1 when exception code is 0');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testRunDispatchesExitCodeOneForExceptionCodeZero()
|
||||||
|
{
|
||||||
|
$passedRightValue = false;
|
||||||
|
|
||||||
|
// We can assume here that some other test asserts that the event is dispatched at all
|
||||||
|
$dispatcher = new EventDispatcher();
|
||||||
|
$self = $this;
|
||||||
|
$dispatcher->addListener('console.terminate', function (ConsoleTerminateEvent $event) use ($self, &$passedRightValue) {
|
||||||
|
$passedRightValue = (1 === $event->getExitCode());
|
||||||
|
});
|
||||||
|
|
||||||
|
$application = new Application();
|
||||||
|
$application->setDispatcher($dispatcher);
|
||||||
|
$application->setAutoExit(false);
|
||||||
|
|
||||||
|
$application->register('test')->setCode(function (InputInterface $input, OutputInterface $output) {
|
||||||
|
throw new \Exception();
|
||||||
|
});
|
||||||
|
|
||||||
|
$tester = new ApplicationTester($application);
|
||||||
|
$tester->run(array('command' => 'test'));
|
||||||
|
|
||||||
|
$this->assertTrue($passedRightValue, '-> exit code 1 was passed in the console.terminate event');
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @expectedException \LogicException
|
* @expectedException \LogicException
|
||||||
* @expectedExceptionMessage An option with shortcut "e" already exists.
|
* @expectedExceptionMessage An option with shortcut "e" already exists.
|
||||||
|
@ -50,6 +50,10 @@ class FilesystemTest extends FilesystemTestCase
|
|||||||
$this->markTestSkipped('This test cannot run on Windows.');
|
$this->markTestSkipped('This test cannot run on Windows.');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!getenv('USER') || 'root' === getenv('USER')) {
|
||||||
|
$this->markTestSkipped('This test will fail if run under superuser');
|
||||||
|
}
|
||||||
|
|
||||||
$sourceFilePath = $this->workspace.\DIRECTORY_SEPARATOR.'copy_source_file';
|
$sourceFilePath = $this->workspace.\DIRECTORY_SEPARATOR.'copy_source_file';
|
||||||
$targetFilePath = $this->workspace.\DIRECTORY_SEPARATOR.'copy_target_file';
|
$targetFilePath = $this->workspace.\DIRECTORY_SEPARATOR.'copy_target_file';
|
||||||
|
|
||||||
@ -124,6 +128,10 @@ class FilesystemTest extends FilesystemTestCase
|
|||||||
$this->markTestSkipped('This test cannot run on Windows.');
|
$this->markTestSkipped('This test cannot run on Windows.');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!getenv('USER') || 'root' === getenv('USER')) {
|
||||||
|
$this->markTestSkipped('This test will fail if run under superuser');
|
||||||
|
}
|
||||||
|
|
||||||
$sourceFilePath = $this->workspace.\DIRECTORY_SEPARATOR.'copy_source_file';
|
$sourceFilePath = $this->workspace.\DIRECTORY_SEPARATOR.'copy_source_file';
|
||||||
$targetFilePath = $this->workspace.\DIRECTORY_SEPARATOR.'copy_target_file';
|
$targetFilePath = $this->workspace.\DIRECTORY_SEPARATOR.'copy_target_file';
|
||||||
|
|
||||||
|
@ -137,7 +137,7 @@ class FormValidator extends ConstraintValidator
|
|||||||
/**
|
/**
|
||||||
* Returns the validation groups of the given form.
|
* Returns the validation groups of the given form.
|
||||||
*
|
*
|
||||||
* @return array The validation groups
|
* @return string|GroupSequence|(string|GroupSequence)[] The validation groups
|
||||||
*/
|
*/
|
||||||
private static function getValidationGroups(FormInterface $form)
|
private static function getValidationGroups(FormInterface $form)
|
||||||
{
|
{
|
||||||
@ -172,10 +172,10 @@ class FormValidator extends ConstraintValidator
|
|||||||
/**
|
/**
|
||||||
* Post-processes the validation groups option for a given form.
|
* Post-processes the validation groups option for a given form.
|
||||||
*
|
*
|
||||||
* @param array|callable $groups The validation groups
|
* @param string|GroupSequence|(string|GroupSequence)[]|callable $groups The validation groups
|
||||||
* @param FormInterface $form The validated form
|
* @param FormInterface $form The validated form
|
||||||
*
|
*
|
||||||
* @return array The validation groups
|
* @return (string|GroupSequence)[] The validation groups
|
||||||
*/
|
*/
|
||||||
private static function resolveValidationGroups($groups, FormInterface $form)
|
private static function resolveValidationGroups($groups, FormInterface $form)
|
||||||
{
|
{
|
||||||
|
@ -1332,7 +1332,7 @@ class Request
|
|||||||
* * _format request attribute
|
* * _format request attribute
|
||||||
* * $default
|
* * $default
|
||||||
*
|
*
|
||||||
* @param string $default The default format
|
* @param string|null $default The default format
|
||||||
*
|
*
|
||||||
* @return string The request format
|
* @return string The request format
|
||||||
*/
|
*/
|
||||||
|
@ -241,29 +241,22 @@ class NativeSessionStorage implements SessionStorageInterface
|
|||||||
unset($_SESSION[$key]);
|
unset($_SESSION[$key]);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Register custom error handler to catch a possible failure warning during session write
|
// Register error handler to add information about the current save handler
|
||||||
set_error_handler(function ($errno, $errstr, $errfile, $errline) {
|
$previousHandler = set_error_handler(function ($type, $msg, $file, $line) use (&$previousHandler) {
|
||||||
throw new \ErrorException($errstr, $errno, E_WARNING, $errfile, $errline);
|
if (E_WARNING === $type && 0 === strpos($msg, 'session_write_close():')) {
|
||||||
}, E_WARNING);
|
$handler = $this->saveHandler instanceof SessionHandlerProxy ? $this->saveHandler->getHandler() : $this->saveHandler;
|
||||||
|
$msg = sprintf('session_write_close(): Failed to write session data with "%s" handler', \get_class($handler));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $previousHandler ? $previousHandler($type, $msg, $file, $line) : false;
|
||||||
|
});
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$e = null;
|
|
||||||
session_write_close();
|
session_write_close();
|
||||||
} catch (\ErrorException $e) {
|
|
||||||
} finally {
|
} finally {
|
||||||
restore_error_handler();
|
restore_error_handler();
|
||||||
$_SESSION = $session;
|
$_SESSION = $session;
|
||||||
}
|
}
|
||||||
if (null !== $e) {
|
|
||||||
// The default PHP error message is not very helpful, as it does not give any information on the current save handler.
|
|
||||||
// Therefore, we catch this error and trigger a warning with a better error message
|
|
||||||
$handler = $this->getSaveHandler();
|
|
||||||
if ($handler instanceof SessionHandlerProxy) {
|
|
||||||
$handler = $handler->getHandler();
|
|
||||||
}
|
|
||||||
|
|
||||||
trigger_error(sprintf('session_write_close(): Failed to write session data with %s handler', \get_class($handler)), E_USER_WARNING);
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->closed = true;
|
$this->closed = true;
|
||||||
$this->started = false;
|
$this->started = false;
|
||||||
|
@ -125,6 +125,13 @@ class InlineFragmentRenderer extends RoutableFragmentRenderer
|
|||||||
}
|
}
|
||||||
$setSession($subRequest, $request);
|
$setSession($subRequest, $request);
|
||||||
|
|
||||||
|
if ($request->get('_format')) {
|
||||||
|
$subRequest->attributes->set('_format', $request->get('_format'));
|
||||||
|
}
|
||||||
|
if ($request->getDefaultLocale() !== $request->getLocale()) {
|
||||||
|
$subRequest->setLocale($request->getLocale());
|
||||||
|
}
|
||||||
|
|
||||||
return $subRequest;
|
return $subRequest;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -145,6 +145,26 @@ class InlineFragmentRendererTest extends TestCase
|
|||||||
$this->assertEquals('Foo', ob_get_clean());
|
$this->assertEquals('Foo', ob_get_clean());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testLocaleAndFormatAreIsKeptInSubrequest()
|
||||||
|
{
|
||||||
|
$expectedSubRequest = Request::create('/');
|
||||||
|
$expectedSubRequest->attributes->set('_format', 'foo');
|
||||||
|
$expectedSubRequest->setLocale('fr');
|
||||||
|
if (Request::getTrustedHeaderName(Request::HEADER_CLIENT_IP)) {
|
||||||
|
$expectedSubRequest->headers->set('x-forwarded-for', array('127.0.0.1'));
|
||||||
|
$expectedSubRequest->server->set('HTTP_X_FORWARDED_FOR', '127.0.0.1');
|
||||||
|
}
|
||||||
|
$expectedSubRequest->headers->set('forwarded', array('for="127.0.0.1";host="localhost";proto=http'));
|
||||||
|
$expectedSubRequest->server->set('HTTP_FORWARDED', 'for="127.0.0.1";host="localhost";proto=http');
|
||||||
|
|
||||||
|
$strategy = new InlineFragmentRenderer($this->getKernelExpectingRequest($expectedSubRequest));
|
||||||
|
|
||||||
|
$request = Request::create('/');
|
||||||
|
$request->attributes->set('_format', 'foo');
|
||||||
|
$request->setLocale('fr');
|
||||||
|
$strategy->render('/', $request);
|
||||||
|
}
|
||||||
|
|
||||||
public function testESIHeaderIsKeptInSubrequest()
|
public function testESIHeaderIsKeptInSubrequest()
|
||||||
{
|
{
|
||||||
$expectedSubRequest = Request::create('/');
|
$expectedSubRequest = Request::create('/');
|
||||||
|
@ -101,6 +101,13 @@ class HttpUtils
|
|||||||
$newRequest->attributes->set(Security::LAST_USERNAME, $request->attributes->get(Security::LAST_USERNAME));
|
$newRequest->attributes->set(Security::LAST_USERNAME, $request->attributes->get(Security::LAST_USERNAME));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($request->get('_format')) {
|
||||||
|
$newRequest->attributes->set('_format', $request->get('_format'));
|
||||||
|
}
|
||||||
|
if ($request->getDefaultLocale() !== $request->getLocale()) {
|
||||||
|
$newRequest->setLocale($request->getLocale());
|
||||||
|
}
|
||||||
|
|
||||||
return $newRequest;
|
return $newRequest;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11,6 +11,8 @@
|
|||||||
|
|
||||||
namespace Symfony\Component\Validator;
|
namespace Symfony\Component\Validator;
|
||||||
|
|
||||||
|
use Symfony\Component\Validator\Constraints\GroupSequence;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Defines the interface for a group sequence provider.
|
* Defines the interface for a group sequence provider.
|
||||||
*/
|
*/
|
||||||
@ -20,7 +22,7 @@ interface GroupSequenceProviderInterface
|
|||||||
* Returns which validation groups should be used for a certain state
|
* Returns which validation groups should be used for a certain state
|
||||||
* of the object.
|
* of the object.
|
||||||
*
|
*
|
||||||
* @return array An array of validation groups
|
* @return string[]|GroupSequence An array of validation groups
|
||||||
*/
|
*/
|
||||||
public function getGroupSequence();
|
public function getGroupSequence();
|
||||||
}
|
}
|
||||||
|
@ -392,7 +392,7 @@ class ClassMetadata extends GenericMetadata implements ClassMetadataInterface
|
|||||||
/**
|
/**
|
||||||
* Sets the default group sequence for this class.
|
* Sets the default group sequence for this class.
|
||||||
*
|
*
|
||||||
* @param array $groupSequence An array of group names
|
* @param string[]|GroupSequence $groupSequence An array of group names
|
||||||
*
|
*
|
||||||
* @return $this
|
* @return $this
|
||||||
*
|
*
|
||||||
|
@ -12,6 +12,7 @@
|
|||||||
namespace Symfony\Component\Validator\Validator;
|
namespace Symfony\Component\Validator\Validator;
|
||||||
|
|
||||||
use Symfony\Component\Validator\Constraint;
|
use Symfony\Component\Validator\Constraint;
|
||||||
|
use Symfony\Component\Validator\Constraints\GroupSequence;
|
||||||
use Symfony\Component\Validator\ConstraintViolationListInterface;
|
use Symfony\Component\Validator\ConstraintViolationListInterface;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -40,11 +41,8 @@ interface ContextualValidatorInterface
|
|||||||
* {@link \Symfony\Component\Validator\Constraints\Valid} is assumed.
|
* {@link \Symfony\Component\Validator\Constraints\Valid} is assumed.
|
||||||
*
|
*
|
||||||
* @param mixed $value The value to validate
|
* @param mixed $value The value to validate
|
||||||
* @param Constraint|Constraint[] $constraints The constraint(s) to validate
|
* @param Constraint|Constraint[] $constraints The constraint(s) to validate against
|
||||||
* against
|
* @param string|GroupSequence|(string|GroupSequence)[]|null $groups The validation groups to validate. If none is given, "Default" is assumed
|
||||||
* @param array|null $groups The validation groups to
|
|
||||||
* validate. If none is given,
|
|
||||||
* "Default" is assumed
|
|
||||||
*
|
*
|
||||||
* @return $this
|
* @return $this
|
||||||
*/
|
*/
|
||||||
@ -56,8 +54,7 @@ interface ContextualValidatorInterface
|
|||||||
*
|
*
|
||||||
* @param object $object The object
|
* @param object $object The object
|
||||||
* @param string $propertyName The name of the validated property
|
* @param string $propertyName The name of the validated property
|
||||||
* @param array|null $groups The validation groups to validate. If
|
* @param string|GroupSequence|(string|GroupSequence)[]|null $groups The validation groups to validate. If none is given, "Default" is assumed
|
||||||
* none is given, "Default" is assumed
|
|
||||||
*
|
*
|
||||||
* @return $this
|
* @return $this
|
||||||
*/
|
*/
|
||||||
@ -69,10 +66,8 @@ interface ContextualValidatorInterface
|
|||||||
*
|
*
|
||||||
* @param object|string $objectOrClass The object or its class name
|
* @param object|string $objectOrClass The object or its class name
|
||||||
* @param string $propertyName The name of the property
|
* @param string $propertyName The name of the property
|
||||||
* @param mixed $value The value to validate against the
|
* @param mixed $value The value to validate against the property's constraints
|
||||||
* property's constraints
|
* @param string|GroupSequence|(string|GroupSequence)[]|null $groups The validation groups to validate. If none is given, "Default" is assumed
|
||||||
* @param array|null $groups The validation groups to validate. If
|
|
||||||
* none is given, "Default" is assumed
|
|
||||||
*
|
*
|
||||||
* @return $this
|
* @return $this
|
||||||
*/
|
*/
|
||||||
|
@ -272,9 +272,9 @@ class RecursiveContextualValidator implements ContextualValidatorInterface
|
|||||||
/**
|
/**
|
||||||
* Normalizes the given group or list of groups to an array.
|
* Normalizes the given group or list of groups to an array.
|
||||||
*
|
*
|
||||||
* @param mixed $groups The groups to normalize
|
* @param string|GroupSequence|(string|GroupSequence)[] $groups The groups to normalize
|
||||||
*
|
*
|
||||||
* @return array A group array
|
* @return (string|GroupSequence)[] A group array
|
||||||
*/
|
*/
|
||||||
protected function normalizeGroups($groups)
|
protected function normalizeGroups($groups)
|
||||||
{
|
{
|
||||||
@ -295,7 +295,7 @@ class RecursiveContextualValidator implements ContextualValidatorInterface
|
|||||||
*
|
*
|
||||||
* @param object $object The object to cascade
|
* @param object $object The object to cascade
|
||||||
* @param string $propertyPath The current property path
|
* @param string $propertyPath The current property path
|
||||||
* @param string[] $groups The validated groups
|
* @param (string|GroupSequence)[] $groups The validated groups
|
||||||
* @param int $traversalStrategy The strategy for traversing the
|
* @param int $traversalStrategy The strategy for traversing the
|
||||||
* cascaded object
|
* cascaded object
|
||||||
* @param ExecutionContextInterface $context The current execution context
|
* @param ExecutionContextInterface $context The current execution context
|
||||||
@ -357,7 +357,7 @@ class RecursiveContextualValidator implements ContextualValidatorInterface
|
|||||||
*
|
*
|
||||||
* @param iterable $collection The collection
|
* @param iterable $collection The collection
|
||||||
* @param string $propertyPath The current property path
|
* @param string $propertyPath The current property path
|
||||||
* @param string[] $groups The validated groups
|
* @param (string|GroupSequence)[] $groups The validated groups
|
||||||
* @param ExecutionContextInterface $context The current execution context
|
* @param ExecutionContextInterface $context The current execution context
|
||||||
*
|
*
|
||||||
* @see ClassNode
|
* @see ClassNode
|
||||||
@ -424,7 +424,7 @@ class RecursiveContextualValidator implements ContextualValidatorInterface
|
|||||||
* the object
|
* the object
|
||||||
* @param string $propertyPath The property path leading
|
* @param string $propertyPath The property path leading
|
||||||
* to the object
|
* to the object
|
||||||
* @param string[] $groups The groups in which the
|
* @param (string|GroupSequence)[] $groups The groups in which the
|
||||||
* object should be validated
|
* object should be validated
|
||||||
* @param string[]|null $cascadedGroups The groups in which
|
* @param string[]|null $cascadedGroups The groups in which
|
||||||
* cascaded objects should
|
* cascaded objects should
|
||||||
@ -608,7 +608,7 @@ class RecursiveContextualValidator implements ContextualValidatorInterface
|
|||||||
* value
|
* value
|
||||||
* @param string $propertyPath The property path leading
|
* @param string $propertyPath The property path leading
|
||||||
* to the value
|
* to the value
|
||||||
* @param string[] $groups The groups in which the
|
* @param (string|GroupSequence)[] $groups The groups in which the
|
||||||
* value should be validated
|
* value should be validated
|
||||||
* @param string[]|null $cascadedGroups The groups in which
|
* @param string[]|null $cascadedGroups The groups in which
|
||||||
* cascaded objects should
|
* cascaded objects should
|
||||||
|
@ -12,6 +12,7 @@
|
|||||||
namespace Symfony\Component\Validator\Validator;
|
namespace Symfony\Component\Validator\Validator;
|
||||||
|
|
||||||
use Symfony\Component\Validator\Constraint;
|
use Symfony\Component\Validator\Constraint;
|
||||||
|
use Symfony\Component\Validator\Constraints\GroupSequence;
|
||||||
use Symfony\Component\Validator\ConstraintViolationListInterface;
|
use Symfony\Component\Validator\ConstraintViolationListInterface;
|
||||||
use Symfony\Component\Validator\Context\ExecutionContextInterface;
|
use Symfony\Component\Validator\Context\ExecutionContextInterface;
|
||||||
use Symfony\Component\Validator\Mapping\Factory\MetadataFactoryInterface;
|
use Symfony\Component\Validator\Mapping\Factory\MetadataFactoryInterface;
|
||||||
@ -30,11 +31,8 @@ interface ValidatorInterface extends MetadataFactoryInterface
|
|||||||
* {@link \Symfony\Component\Validator\Constraints\Valid} is assumed.
|
* {@link \Symfony\Component\Validator\Constraints\Valid} is assumed.
|
||||||
*
|
*
|
||||||
* @param mixed $value The value to validate
|
* @param mixed $value The value to validate
|
||||||
* @param Constraint|Constraint[] $constraints The constraint(s) to validate
|
* @param Constraint|Constraint[] $constraints The constraint(s) to validate against
|
||||||
* against
|
* @param string|GroupSequence|(string|GroupSequence)[]|null $groups The validation groups to validate. If none is given, "Default" is assumed
|
||||||
* @param array|null $groups The validation groups to
|
|
||||||
* validate. If none is given,
|
|
||||||
* "Default" is assumed
|
|
||||||
*
|
*
|
||||||
* @return ConstraintViolationListInterface A list of constraint violations
|
* @return ConstraintViolationListInterface A list of constraint violations
|
||||||
* If the list is empty, validation
|
* If the list is empty, validation
|
||||||
@ -48,8 +46,7 @@ interface ValidatorInterface extends MetadataFactoryInterface
|
|||||||
*
|
*
|
||||||
* @param object $object The object
|
* @param object $object The object
|
||||||
* @param string $propertyName The name of the validated property
|
* @param string $propertyName The name of the validated property
|
||||||
* @param array|null $groups The validation groups to validate. If
|
* @param string|GroupSequence|(string|GroupSequence)[]|null $groups The validation groups to validate. If none is given, "Default" is assumed
|
||||||
* none is given, "Default" is assumed
|
|
||||||
*
|
*
|
||||||
* @return ConstraintViolationListInterface A list of constraint violations
|
* @return ConstraintViolationListInterface A list of constraint violations
|
||||||
* If the list is empty, validation
|
* If the list is empty, validation
|
||||||
@ -63,10 +60,8 @@ interface ValidatorInterface extends MetadataFactoryInterface
|
|||||||
*
|
*
|
||||||
* @param object|string $objectOrClass The object or its class name
|
* @param object|string $objectOrClass The object or its class name
|
||||||
* @param string $propertyName The name of the property
|
* @param string $propertyName The name of the property
|
||||||
* @param mixed $value The value to validate against the
|
* @param mixed $value The value to validate against the property's constraints
|
||||||
* property's constraints
|
* @param string|GroupSequence|(string|GroupSequence)[]|null $groups The validation groups to validate. If none is given, "Default" is assumed
|
||||||
* @param array|null $groups The validation groups to validate. If
|
|
||||||
* none is given, "Default" is assumed
|
|
||||||
*
|
*
|
||||||
* @return ConstraintViolationListInterface A list of constraint violations
|
* @return ConstraintViolationListInterface A list of constraint violations
|
||||||
* If the list is empty, validation
|
* If the list is empty, validation
|
||||||
|
@ -1945,6 +1945,10 @@ YAML;
|
|||||||
$this->markTestSkipped('chmod is not supported on Windows');
|
$this->markTestSkipped('chmod is not supported on Windows');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!getenv('USER') || 'root' === getenv('USER')) {
|
||||||
|
$this->markTestSkipped('This test will fail if run under superuser');
|
||||||
|
}
|
||||||
|
|
||||||
$file = __DIR__.'/Fixtures/not_readable.yml';
|
$file = __DIR__.'/Fixtures/not_readable.yml';
|
||||||
chmod($file, 0200);
|
chmod($file, 0200);
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user