- š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
I'm shifting away from Symfony Validators to a (hopefully) simpler approach in š Allow validators passed to file_validate to use callable syntax Closed: outdated
- Status changed to Needs review
almost 2 years ago 12:19am 17 April 2023 - last update
almost 2 years ago 29,190 pass, 3 fail - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
Re-roll to see what's breaking.
The last submitted patch, 22: 3221793-22.patch, failed testing. View results ā
- last update
almost 2 years ago 29,203 pass - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
Fix test fails
- š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
I wonder if we should go further up the stack and replace
'#upload_validators'
in the Form API with an array of\Symfony\Component\Validator\Constraint
instances? This probably means replacing how form validation works to be more inline with Symfony Validator component, and there seems to be some pushback on using it at all š Discuss whether to decouple from Symfony Validator Active - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
Also not sure how the form API and existing validators tie into the whole Typed Data API and plugin validators like
\Drupal\file\Plugin\Validation\Constraint\FileValidationConstraintValidator
. - š¬š§United Kingdom joachim
-
+++ b/core/modules/file/file.module @@ -99,25 +104,49 @@ function file_field_widget_info_alter(array &$info) { + * The validation constraints.
Keyed by what? And in what order?
-
+++ b/core/modules/file/file.module @@ -99,25 +104,49 @@ function file_field_widget_info_alter(array &$info) { +function _file_convert_validators_to_constraints(FileInterface $file, array $validators): array {
Could this go on a service somewhere instead of being a function? We can mark it as @internal.
-
+++ b/core/modules/file/file.module @@ -99,25 +104,49 @@ function file_field_widget_info_alter(array &$info) { + // We can't convert the validator, so lets just call it.
Typo: should be "let's".
-
+++ b/core/modules/file/src/Plugin/Field/FieldType/FileItem.php @@ -341,6 +343,30 @@ public function getUploadValidators() { + public function getUploadConstraints(): array {
I think we need some docs on this class to explain why we have a mishmash of procedural validators and Symfony constraints.
I assume it's because of BC? But shouldn't there also be an issue to deprecate the functional validators?
-
- š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
- š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
Chatted with @larowlan about this at DrupalSouth and decided the best approach is utilise constraint validation plugins.
We can create plugins with the same IDs as the function names for BC, and deprecate the functions.
- š¦šŗAustralia larowlan š¦šŗš.au GMT+10
Capturing some conversation from DrupalSouth
\Drupal\Core\TypedData\TypedDataManager::getValidator
has some prior art to create a validator\Drupal\Core\TypedData\TypedData::validate
has how to validate once you have the validator - Status changed to Needs work
over 1 year ago 6:49pm 19 May 2023 - šŗšøUnited States smustgrave
Can the issue summary also be updated to include agreed upon solution please
Thanks!
- š¦šŗAustralia larowlan š¦šŗš.au GMT+10
To reflect current discussion
- Status changed to Needs review
over 1 year ago 7:46am 22 May 2023 - last update
over 1 year ago 29,389 pass - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
- last update
over 1 year ago 29,389 pass, 2 fail - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
Added an additional validation for FileExtension to test passing in arguments. We will need to use the existing '$value' option as we don't currently an associative array of options, just the function arguments.
I also updated the issue summary with the current approach and remaining tasks.
The last submitted patch, 34: 3221793-34.patch, failed testing. View results ā
49:49 49:33 Running- last update
over 1 year ago Unable to generate test groups - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
Still a work in progress. Did more work building out constraints and added logic for deprecating existing hook functions.
Ran into
file_validate_image_resolution()
which I think doesn't belong as a validator. I created š Deprecate file_validate_image_resolution() and replace with a service Postponed which I think is a blocker for this issue. - last update
over 1 year ago Unable to generate test groups - Status changed to Needs work
over 1 year ago 3:09pm 31 May 2023 - Status changed to Needs review
over 1 year ago 1:43am 1 June 2023 44:43 41:20 Running- š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
Re: #37 I dug a bit deeper and trying to remove
file_validate_image_resolution()
from the validators is going to be complex. I have added a\Drupal\file\Plugin\Validation\Constraint\FileImageDimensionsConstraint
. Happy to hear opinions on how we can do this better.Remaining tasks:
- Deprecate the legacy functions
- Replace usages in core
The last submitted patch, 39: 3221793-39.patch, failed testing. View results ā
- last update
over 1 year ago 29,409 pass - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
Fixes test fails and adds a test for
FileNameLengthConstraintValidator
. - last update
over 1 year ago 29,411 pass - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
Adds a test event subscriber.
- last update
over 1 year ago 28,415 pass, 199 fail - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
Deprecates
file_validate()
and replaces usages.Remaining tasks:
- Deprecate the legacy file validate hook functions
- Deprecate
file_validate()
The last submitted patch, 43: 3221793-43.patch, failed testing. View results ā
- last update
over 1 year ago 28,651 pass, 129 fail - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
Replaced more usages of
file_validate()
andfile_validate_*
functions. The last submitted patch, 45: 3221793-45.patch, failed testing. View results ā
- last update
over 1 year ago 29,298 pass, 23 fail - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
Fixing test fails.
The last submitted patch, 47: 3221793-47.patch, failed testing. View results ā
- last update
over 1 year ago 29,379 pass, 2 fail - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
JSON API has an undeclared dependency on file module so a lot of these fails are because we have a new file service that will error out when the container is built, whereas before we were just calling the
file_validate()
function and not checking if it was available.Added
'file'
as a module dependency to a load of the JSON-API tests.The patch grows bigger, and the night grows darker...
The last submitted patch, 49: 3221793-49.patch, failed testing. View results ā
- last update
over 1 year ago 29,078 pass, 135 fail - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
Fixes tests.
Remaining tasks:
- Ensure we have the same test coverage for new ConstaintValidators as we did for legacy
file_validate_*
functions
- Ensure we have the same test coverage for new ConstaintValidators as we did for legacy
The last submitted patch, 51: 3221793-51.patch, failed testing. View results ā
45:44 44:34 Running- š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
Trying a different approach to fix test issue by checking
$file instanceof ConstraintViolationListInterface
instead of$file instanceof EntityConstraintViolationListInterface
. - last update
over 1 year ago 29,423 pass, 1 fail - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
- Renamed
FileSizeMax
toFileSizeLimit
. - Copied over existing f
ile_validate_*
tests to ensure we don't lose any test coverage.
No more remaining tasks! Just reviews needed.
- Renamed
The last submitted patch, 54: 3221793-54.patch, failed testing. View results ā
- last update
over 1 year ago 29,430 pass - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
Don't use markup in test assertions.
Updated the CR to provide much more details and mapping old to new form API changes.
- Status changed to RTBC
over 1 year ago 10:38pm 5 June 2023 - šŗšøUnited States smustgrave
Searched for file_validate_size() and all instances appear to be addressed.
Fyi expectDeprecation is deprecated itself but seems š Several expect*() methods have been deprecated in PHPUnit 9.6 Active there is still a plan being made.
- Status changed to Needs work
over 1 year ago 7:58am 6 June 2023 - š¦šŗAustralia larowlan š¦šŗš.au GMT+10
This is looking amazing. I've done half the review and will finish it off tomorrow, here's observations so far
-
+++ b/core/modules/ckeditor5/src/Controller/CKEditor5ImageController.php @@ -238,20 +258,7 @@ protected function validate(FileInterface $file, array $validators) { - $errors = file_validate($file, $validators); - if (!empty($errors)) { - $translator = new DrupalTranslator(); - foreach ($errors as $error) { - $violation = new ConstraintViolation($translator->trans($error), - (string) $error, - [], - EntityAdapter::createFromEntity($file), - '', - NULL - ); - $violations->add($violation); - } - } + $violations->addAll($this->fileValidator->validate($file, $validators));
š„
-
+++ b/core/modules/ckeditor5/src/Controller/CKEditor5ImageController.php @@ -261,15 +268,14 @@ protected function validate(FileInterface $file, array $validators) { - protected function prepareFilename($filename, array &$validators) { - $extensions = $validators['file_validate_extensions'][0] ?? ''; - $event = new FileUploadSanitizeNameEvent($filename, $extensions); + protected function prepareFilename($filename, string $allowed_extensions) { + $event = new FileUploadSanitizeNameEvent($filename, $allowed_extensions);
Technically this is a BC break but we don't provide API for controllers and it looks like nothing is extending it in contrib https://git.drupalcode.org/search?group_id=2&scope=blobs&search=%22exten... so I think we're fine as long as this is mentioned in the CR
-
+++ b/core/modules/file/file.field.inc @@ -152,16 +152,16 @@ function template_preprocess_file_upload_help(&$variables) { - if (isset($upload_validators['file_validate_size'])) { - $descriptions[] = t('@size limit.', ['@size' => format_size($upload_validators['file_validate_size'][0])]); + if (isset($upload_validators['FileSizeLimit'])) { + $descriptions[] = t('@size limit.', ['@size' => format_size($upload_validators['FileSizeLimit']['fileLimit'])]); } - if (isset($upload_validators['file_validate_extensions'])) { - $descriptions[] = t('Allowed types: @extensions.', ['@extensions' => $upload_validators['file_validate_extensions'][0]]); + if (isset($upload_validators['FileExtension'])) { + $descriptions[] = t('Allowed types: @extensions.', ['@extensions' => $upload_validators['FileExtension']['extensions']]); } - if (isset($upload_validators['file_validate_image_resolution'])) { - $max = $upload_validators['file_validate_image_resolution'][0]; - $min = $upload_validators['file_validate_image_resolution'][1]; + if (isset($upload_validators['FileImageDimensions'])) { + $max = $upload_validators['FileImageDimensions']['maxDimensions']; + $min = $upload_validators['FileImageDimensions']['minDimensions'];
We will need to handle both formats here, as there will be existing render arrays with the theme hook in contrib/custom code with this in the old format.
We should trigger a deprecation error if they are
-
+++ b/core/modules/file/src/Element/ManagedFile.php @@ -360,8 +360,8 @@ public static function processManagedFile(&$element, FormStateInterface $form_st - if (isset($element['#upload_validators']['file_validate_extensions'][0])) { - $extension_list = implode(',', array_filter(explode(' ', $element['#upload_validators']['file_validate_extensions'][0]))); + if (isset($element['#upload_validators']['FileExtension']['extensions'])) { + $extension_list = implode(',', array_filter(explode(' ', $element['#upload_validators']['FileExtension']['extensions']))); $element['upload']['#attached']['drupalSettings']['file']['elements']['#' . $id] = $extension_list;
We will need to handle both formats here, as there will be existing forms in contrib/custom code with this in the old format.
We should trigger a deprecation error if they are
-
+++ b/core/modules/file/src/Plugin/Validation/Constraint/BaseFileConstraintValidator.php @@ -0,0 +1,35 @@ + if (!$value instanceof FileInterface) { + throw new UnexpectedTypeException($value, FileInterface::class); + }
nice
-
+++ b/core/modules/file/src/Plugin/Validation/Constraint/FileExtensionConstraint.php @@ -0,0 +1,41 @@ + public function getDefaultOption(): ?string {
we should be safe to narrow this to
:string
-
+++ b/core/modules/file/src/Plugin/Validation/Constraint/FileExtensionSecureConstraintValidator.php @@ -0,0 +1,51 @@ + if (!$allowInsecureUploads && preg_match(FileSystemInterface::INSECURE_EXTENSION_REGEX, $file->getFilename())) {
š§ think there's an extra space here
-
+++ b/core/modules/file/src/Plugin/Validation/Constraint/FileImageDimensionsConstraint.php @@ -0,0 +1,55 @@ + * File extension secure constraint.
copy/paste?
-
+++ b/core/modules/file/src/Plugin/Validation/Constraint/FileImageDimensionsConstraintValidator.php @@ -0,0 +1,123 @@ + if ($image->isValid()) {
I think if we flip this and return early it would simplify the code, e.g.
if (!$image->isValid()) { return; }
-
+++ b/core/modules/file/src/Plugin/Validation/Constraint/FileImageDimensionsConstraintValidator.php @@ -0,0 +1,123 @@ + if ($image->scale($width, $height)) {
we can probably flip this too, and add the violation and return early, avoiding the else and another layer of nesting
-
+++ b/core/modules/file/src/Plugin/Validation/Constraint/FileImageDimensionsConstraintValidator.php @@ -0,0 +1,123 @@ + if (!empty($width) && !empty($height)) { ... + elseif (empty($width)) { ... + elseif (empty($height)) {
we can return from each of these and avoid elseif
-
+++ b/core/modules/file/src/Plugin/Validation/Constraint/FileImageDimensionsConstraintValidator.php @@ -0,0 +1,123 @@ + $this->context->addViolation($constraint->messageResizedImageTooSmall,
we can return here and avoid an else too
-
+++ b/core/modules/file/src/Plugin/Validation/Constraint/FileIsImageConstraintValidator.php @@ -0,0 +1,51 @@ + * Validator for the FileExtensionSecureConstraint.
copy/paste
-
+++ b/core/modules/file/src/Plugin/Validation/Constraint/FileNameLengthConstraint.php @@ -0,0 +1,39 @@ + public string $messageTooLong = "The file's name exceeds the 240 characters limit. Please rename the file and try again.";
Should the 240 in this string be placeholdered? I think the maxLength would be configurable via the constraint constructor right?
-
+++ b/core/modules/file/src/Plugin/Validation/Constraint/FileNameLengthConstraintValidator.php @@ -0,0 +1,30 @@ + if (strlen($file->getFilename()) > $constraint->maxLength) {
should this be using mb_strlen to allow for utf-8 characters?
-
+++ b/core/modules/file/src/Plugin/Validation/Constraint/FileSizeLimitConstraintValidator.php @@ -0,0 +1,74 @@ + * Validates the file name size constraint.
copy paste?
-
+++ b/core/modules/file/src/Plugin/rest/resource/FileUploadResource.php @@ -451,38 +470,6 @@ protected function validateAndLoadFieldDefinition($entity_type_id, $bundle, $fie - protected function validate(FileInterface $file, array $validators) { - $this->resourceValidate($file); -
Note to other reviewers, this just uses the parent now
however, we can probably drop the use of the trait now
-
+++ b/core/modules/file/src/Validation/FileValidationEvent.php @@ -0,0 +1,27 @@ +class FileValidationEvent extends Event {
Part way through review, up to here
-
- Status changed to Needs review
over 1 year ago 10:25pm 6 June 2023 - last update
over 1 year ago 29,432 pass - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
- šļø
- Updated CR
- Fixed
- Fixed
- šļø
- Fixed
- Fixed
- Fixed
- Fixed
- We can't return early as we might add another
minDimensions
violation further down. - Fixed
- Fixed
- Fixed
- Fixed
- Fixed. Although this is existing functionality.
- Fixed
- šļø
- šļø
- Status changed to Needs work
over 1 year ago 1:57am 7 June 2023 - š¦šŗAustralia larowlan š¦šŗš.au GMT+10
Got to the end, couple of questions about tests
-
+++ b/core/modules/file/file.field.inc @@ -153,20 +153,39 @@ function template_preprocess_file_upload_help(&$variables) { + @trigger_error('\'file_validate_size\' is deprecated in drupal:10.2.0 and is removed from drupal:11.0.0. Use the \'FileSizeLimit\' constraint instead. See https://www.drupal.org/node/3363700', E_USER_DEPRECATED);
do we need a legacy test for this and the equivalent BC layer in the managed file element ?
-
+++ b/core/modules/file/src/Validation/FileValidationEvent.php @@ -0,0 +1,27 @@ + public readonly ConstraintViolationListInterface $violations,
was going to ask 'should there be a getter for this' then realised its public, š
-
+++ b/core/modules/file/src/Validation/FileValidator.php @@ -0,0 +1,95 @@ + * Implements the file validator.
minor: can we improve this? 'Provides a class for file validation' perhaps?
-
+++ b/core/modules/file/src/Validation/FileValidator.php @@ -0,0 +1,95 @@ + $entityAdapter = EntityAdapter::createFromEntity($file);
I _think_ you can just call $file->getTypedData()
-
+++ b/core/modules/file/tests/src/Functional/SaveUploadFormTest.php @@ -95,7 +95,7 @@ protected function setUp(): void { - $this->assertFileHooksCalled(['validate', 'insert']); + $this->assertFileHooksCalled(['insert']);
Should we add a test event listener using the new event that writes the 'validate' entry and keep these as they were? Would reduce the size of the patch and retain the existing coverage.
-
+++ b/core/modules/file/tests/src/Kernel/Plugin/Validation/Constraint/FileExtensionConstraintValidatorTest.php @@ -0,0 +1,133 @@ + $violations = $this->validator->validate($file, $validators); + $this->assertCount(1, $violations, 'Invalid extension blocked.');
should we assert the message is as expected?
-
+++ b/core/modules/file/tests/src/Kernel/Plugin/Validation/Constraint/FileImageDimensionsConstraintValidatorTest.php @@ -0,0 +1,144 @@ + $violations = $this->validator->validate($this->image, $validators); + $this->assertCount(1, $violations, 'Got an error for an image that was not wide enough.'); ... + $violations = $this->validator->validate($this->image, $validators); + $this->assertCount(1, $violations, 'Got an error for an image that was not tall enough.'); ... + $violations = $this->validator->validate($this->image, $validators); + $this->assertCount(1, $violations, 'Small images report an error.'); ... + $violations = $this->validator->validate($this->image, $validators); + $this->assertCount(1, $violations, 'An error reported for an oversized image that can not be scaled down.'); ... + $violations = $this->validator->validate($this->image, $validators); + $this->assertCount(1, $violations, 'Oversize images that cannot be scaled get an error.');
here too, I think we should be asserting the expected message to ensure the violation is what we expect rather than just the count
-
+++ b/core/modules/file/tests/src/Kernel/Plugin/Validation/Constraint/FileIsImageConstraintValidatorTest.php @@ -0,0 +1,67 @@ + $this->assertCount(1, $violations, 'An error reported for our non-image file.'); +++ b/core/modules/file/tests/src/Kernel/Plugin/Validation/Constraint/FileNameLengthConstraintValidatorTest.php @@ -0,0 +1,44 @@ + $this->assertCount(1, $violations, 'An error reported for 241 length filename.'); ... + $this->assertCount(1, $violations, 'An error reported for 0 length filename.'); +++ b/core/modules/file/tests/src/Kernel/Plugin/Validation/Constraint/FileSizeLimitConstraintValidatorTest.php @@ -0,0 +1,33 @@ + $this->assertCount(1, $violations, 'Error for the file being over the limit.'); ... + $this->assertCount(1, $violations, 'Error for the user being over their limit.'); ... + $this->assertCount(2, $violations, 'Errors for both the file and their limit.');
here too
-
+++ b/core/modules/file/tests/src/Kernel/Validation/FileValidatorTest.php @@ -0,0 +1,91 @@ + protected function setUp(): void { + parent::setUp(); + $this->installConfig(['system']); + $this->installEntitySchema('file'); + $this->installEntitySchema('user'); + $this->installSchema('file', ['file_usage']); + + $uri = 'public://druplicon.txt'; + $this->file = File::create([ + 'uid' => 1,
if we extend the abstract base class from above I think we can remove all this setup
Removing the needs architectural review tag as I think this looks good.
The cleanup in the API resources makes it clear this is the right model, we were mixing constraints and errors in a weird mis-mash. Now its a single approach (or it will be once we can remove the BC layer).
-
- Status changed to Needs review
over 1 year ago 4:23am 7 June 2023 - last update
over 1 year ago 29,432 pass - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
- Added a legacy test
\Drupal\Tests\file\Kernel\LegacyFileThemeTest::testTemplatePreprocessFileUploadHelp()
- šļø
- Fixed
- I think it just calls
::createFromEntity()
underneath, but lets find out. - I modified the
file_validator_test
module's event listener to set the test state that the FileUploadTest was previously checking, and re-added the check for 'validation' hook being fired (event though it's an event now). I had to rework the FileValidatorTest as we are no longer adding a violation in the event listener. - Removed this test as it's more fully covered by the tests below that use the dataProvider.
- Fixed
- Fixed
- Fixed. Moved it from
Drupal\Tests\file\Kernel\Plugin\Validation\Constraint\FileConstraintValidatorTestBase
to\Drupal\Tests\file\Kernel\Validation\FileValidatorTestBase
- Added a legacy test
- Status changed to RTBC
over 1 year ago 9:55pm 7 June 2023 - šŗšøUnited States smustgrave
From what I can tell all of @larowlan's points have been addressed.
- š§šŖBelgium wim leers Ghent š§šŖšŖšŗ
š¤©
+++ b/core/modules/file/src/Plugin/Validation/Constraint/FileExtensionConstraint.php @@ -0,0 +1,41 @@ +class FileExtensionConstraint extends Constraint { +++ b/core/modules/file/src/Plugin/Validation/Constraint/FileIsImageConstraint.php @@ -0,0 +1,27 @@ +class FileIsImageConstraint extends Constraint { +++ b/core/modules/file/src/Plugin/Validation/Constraint/FileSizeLimitConstraint.php @@ -0,0 +1,53 @@ +class FileSizeLimitConstraint extends Constraint {
I think that many of these could use
\Symfony\Component\Validator\Constraints\FileValidator
instead? š That would mean less code to maintain on the Drupal side!Related: š Add Missing Symfony Validators to Drupal Constraint Validator Needs work .
- Status changed to Needs review
over 1 year ago 3:59pm 8 June 2023 - Status changed to Needs work
over 1 year ago 10:19pm 8 June 2023 - šŗšøUnited States smustgrave
@Wim Leers showed me this and explained a lot about how the Constraints can be leveraged. Think if we can leverage them we should!
- š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
I think that many of these could use \Symfony\Component\Validator\Constraints\FileValidator instead? š That would mean less code to maintain on the Drupal side!
Had a look through the Symfony constraints. As mentioned in Slack, we have a
\Drupal\file\FileInterface
and\Drupal\Core\Image\ImageInterface
we are validating, so the Symfony validators won't work. - Status changed to Needs review
over 1 year ago 11:50pm 8 June 2023 - Status changed to RTBC
over 1 year ago 10:09pm 9 June 2023 - šŗšøUnited States smustgrave
Thanks for checking that. Will remark then.
- last update
over 1 year ago 29,452 pass - last update
over 1 year ago 29,452 pass - last update
over 1 year ago 29,460 pass - last update
over 1 year ago Patch Failed to Apply - last update
over 1 year ago 29,488 pass - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
Re-roll of #62
- last update
over 1 year ago 29,514 pass - last update
over 1 year ago 29,514 pass - last update
over 1 year ago 29,523 pass - Status changed to Needs work
over 1 year ago 1:22am 23 June 2023 - š¦šŗAustralia larowlan š¦šŗš.au GMT+10
Just one comment and one follow up request, feel free to self RTBC or push back if not appropriate.
-
+++ b/core/modules/file/tests/file_test/src/Form/FileTestForm.php @@ -94,18 +94,18 @@ public function submitForm(array &$form, FormStateInterface $form_state) { - $validators['file_validate_is_image'] = []; +++ b/core/modules/file/tests/file_test/src/Form/FileTestSaveUploadFromForm.php @@ -141,18 +141,18 @@ public function validateForm(array &$form, FormStateInterface $form_state) { - $validators['file_validate_is_image'] = [];
there's a lot of duplicate code between these two, can we get a followup to move to a base-class or trait?
-
+++ b/core/modules/file/tests/src/Kernel/LegacyValidatorTest.php @@ -8,8 +8,9 @@ +class LegacyValidatorTest extends FileManagedUnitTestBase { +++ b/core/modules/file/tests/src/Kernel/Plugin/Validation/Constraint/FileIsImageConstraintValidatorTest.php @@ -0,0 +1,68 @@ + protected function setUp(): void { + parent::setUp(); + + $this->image = File::create(); + $this->image->setFileUri('core/misc/druplicon.png'); + /** @var \Drupal\Core\File\FileSystemInterface $file_system */ + $file_system = \Drupal::service('file_system'); + $this->image->setFilename($file_system->basename($this->image->getFileUri())); + + $this->nonImage = File::create(); + $this->nonImage->setFileUri('core/assets/vendor/jquery/jquery.min.js'); + $this->nonImage->setFilename($file_system->basename($this->nonImage->getFileUri())); + }
these two classes have identical setup methods - could/should we use a base class? We have one already in this patch, could some of this duplication go there?
-
- Status changed to RTBC
over 1 year ago 1:34am 23 June 2023 - š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
- Added follow-up issue š Remove duplication from FileTestForm and FileTestSaveUploadFromForm Active
- LegacyValidatorTest will be removed in the next major release, so we'd end up with only one use of the trait or base class.
-
larowlan ā
committed 79c7666a on 11.x
Issue #3221793 by kim.pepper, larowlan, smustgrave, Wim Leers, joachim,...
-
larowlan ā
committed 79c7666a on 11.x
- Status changed to Fixed
over 1 year ago 2:29am 23 June 2023 Automatically closed - issue fixed for 2 weeks with no activity.
- Status changed to Fixed
about 1 year ago 10:40pm 20 December 2023 - šŗšøUnited States DamienMcKenna NH, USA
FYI this introduced a subtle bug whereby if a validator passed through #upload_validators did not exist as a function it was assumed to be a constraint plugin, whereas lots of contrib modules used it as a namespaced variable that would ultimately be passed through to hook_file_validate(). This has caused problems with several contrib modules, including Webform ( š Drupal\Component\Plugin\Exception\PluginNotFoundException: The "webform_file_validate_extensions" plugin does not exist Active ).
- š¦šŗAustralia kim.pepper šāāļøš¦šŗSydney, Australia
A new bug reported for the BC layer: š file_save_upload broken by 10.2.x Needs work