Skip to content
Snippets Groups Projects
Commit b12dd10f authored by catch's avatar catch
Browse files

Issue #3449851 by Liam Morland, alexpott, smustgrave, solideogloria, catch,...

Issue #3449851 by Liam Morland, alexpott, smustgrave, solideogloria, catch, kopeboy: Replace LogicException with trigger_error in LangcodeRequiredIfTranslatableValues constraint
parent cc9baee9
No related branches found
No related tags found
26 merge requests!12227Issue #3181946 by jonmcl, mglaman,!11131[10.4.x-only-DO-NOT-MERGE]: Issue ##2842525 Ajax attached to Views exposed filter form does not trigger callbacks,!9470[10.3.x-only-DO-NOT-MERGE]: #3331771 Fix file_get_contents(): Passing null to parameter,!8736Update the Documention As per the Function uses.,!8528Issue #3456871 by Tim Bozeman: Support NULL services,!8513Issue #3453786: DefaultSelection should document why values for target_bundles NULL and [] behave as they do,!5423Draft: Resolve #3329907 "Test2",!3878Removed unused condition head title for views,!3818Issue #2140179: $entity->original gets stale between updates,!3742Issue #3328429: Create item list field formatter for displaying ordered and unordered lists,!3731Claro: role=button on status report items,!3651Issue #3347736: Create new SDC component for Olivero (header-search),!3478Issue #3337882: Deleted menus are not removed from content type config,!3355Issue #3209129: Scrolling problems when adding a block via layout builder,!3154Fixes #2987987 - CSRF token validation broken on routes with optional parameters.,!3133core/modules/system/css/components/hidden.module.css,!2964Issue #2865710 : Dependencies from only one instance of a widget are used in display modes,!2812Issue #3312049: [Followup] Fix Drupal.Commenting.FunctionComment.MissingReturnType returns for NULL,!2378Issue #2875033: Optimize joins and table selection in SQL entity query implementation,!2062Issue #3246454: Add weekly granularity to views date sort,!10223132456: Fix issue where views instances are emptied before an ajax request is complete,!877Issue #2708101: Default value for link text is not saved,!617Issue #3043725: Provide a Entity Handler for user cancelation,!579Issue #2230909: Simple decimals fail to pass validation,!560Move callback classRemove outside of the loop,!555Issue #3202493
Pipeline #219629 canceled
Pipeline: drupal

#219631

    ......@@ -22,8 +22,12 @@ public function validate(mixed $value, Constraint $constraint): void {
    $mapping = $this->context->getObject();
    assert($mapping instanceof Mapping);
    if ($mapping !== $this->context->getRoot()) {
    throw new LogicException('The LangcodeRequiredIfTranslatableValues constraint can only operate on the root object being validated.');
    $root = $this->context->getRoot();
    if ($mapping !== $root) {
    throw new LogicException(sprintf(
    'The LangcodeRequiredIfTranslatableValues constraint is applied to \'%s\'. This constraint can only operate on the root object being validated.',
    $root->getName() . '::' . $mapping->getName()
    ));
    }
    assert(in_array('langcode', $mapping->getValidKeys(), TRUE));
    ......
    ......@@ -241,6 +241,13 @@ config_test.foo:
    label:
    type: label
    label: 'Label'
    # Note that config_object should never be used on a non-root key.
    broken_langcode_required:
    type: config_object
    required: false
    mapping:
    foo:
    type: string
    config_test.bar:
    type: config_test.foo
    ......
    ......@@ -859,4 +859,15 @@ public function testConfigSaveWithWrappingSchemaDoubleBrackets(): void {
    ], $definition['mapping']['breed']);
    }
    public function testLangcodeRequiredIfTranslatableValuesConstraintError(): void {
    $config = \Drupal::configFactory()->getEditable('config_test.foo');
    $this->expectException(\LogicException::class);
    $this->expectExceptionMessage('The LangcodeRequiredIfTranslatableValues constraint is applied to \'config_test.foo::broken_langcode_required\'. This constraint can only operate on the root object being validated.');
    $config
    ->set('broken_langcode_required.foo', 'bar')
    ->save();
    }
    }
    0% Loading or .
    You are about to add 0 people to the discussion. Proceed with caution.
    Please register or to comment