Add validation constraints to comment.type.*

Created on 17 June 2024, 10 months ago

Comment type entity is not yet fully validatable:

./vendor/bin/drush config:inspect --filter-keys=comment.type.comment --detail --list-constraints --fields=key,validatability,constraints

>  πŸ€– Analyzing…

 ------------------------------------------------- ------------- ---------------------------------------------------------------------- 
  Key                                               Validatable   Validation constraints                                                
 ------------------------------------------------- ------------- ---------------------------------------------------------------------- 
  comment.type.comment                              91%           ValidKeys: '<infer>'                                                  
   comment.type.comment:                            Validatable   ValidKeys: '<infer>'                                                  
   comment.type.comment:_core                       Validatable   ValidKeys:                                                            
                                                                    - default_config_hash                                               
   comment.type.comment:_core.default_config_hash   Validatable   NotNull: {  }                                                         
                                                                  Regex: '/^[a-zA-Z0-9\-_]+$/'                                          
                                                                  Length: 43                                                            
                                                                  ↣ PrimitiveType: {  }                                                 
   comment.type.comment:dependencies                Validatable   ValidKeys: '<infer>'                                                  
   comment.type.comment:description                 Validatable   Regex:                                                                
                                                                    pattern: '/([^\PC\x09\x0a\x0d])/u'                                  
                                                                    match: false                                                        
                                                                    message: 'Text is not allowed to contain control characters, only   
                                                                  visible characters.'                                                  
                                                                  ↣ PrimitiveType: {  }                                                 
   comment.type.comment:id                          Validatable   Regex:                                                                
                                                                    pattern: '/^[a-z0-9_]+$/'                                           
                                                                    message: 'The %value machine name is not valid.'                    
                                                                  Length:                                                               
                                                                    max: 166                                                            
                                                                  ↣ PrimitiveType: {  }                                                 
   comment.type.comment:label                       Validatable   Regex:                                                                
                                                                    pattern: '/([^\PC])/u'                                              
                                                                    match: false                                                        
                                                                    message: 'Labels are not allowed to span multiple lines or contain  
                                                                  control characters.'                                                  
                                                                  NotBlank: {  }                                                        
                                                                  ↣ PrimitiveType: {  }                                                 
   comment.type.comment:langcode                    Validatable   NotNull: {  }                                                         
                                                                  Choice:                                                               
                                                                    callback:                                                           
                                                                  'Drupal\Core\TypedData\Plugin\DataType\LanguageReference::getAllVali  
                                                                  dLangcodes'                                                           
                                                                  ↣ PrimitiveType: {  }                                                 
   comment.type.comment:status                      Validatable   ↣ PrimitiveType: {  }                                                 
   comment.type.comment:target_entity_type_id       NOT           ⚠️  @todo Add validation constraints to config entity type:           
                                                                  comment.type.*                                                        
   comment.type.comment:uuid                        Validatable   Uuid: {  }                                                            
                                                                  ↣ PrimitiveType: {  }                                                 
 ------------------------------------------------- ------------- ---------------------------------------------------------------------- 

Steps to reproduce

  1. Get a local git clone of Drupal core 11.x.
  2. composer require drupal/config_inspector β€” or manually install https://www.drupal.org/project/config_inspector/releases/2.1.5 β†’ or newer (which supports Drupal 11!)
  3. composer require drush/drush
  4. vendor/bin/drush config:inspect --filter-keys=user.role.anonymous --detail --list-constraints

Proposed resolution

Add validation constraints to missing properties.

Remaining tasks

User interface changes

None.

API changes

None.

Data model changes

More validation πŸš€

Release notes snippet

None.

πŸ“Œ Task
Status

Active

Version

11.0 πŸ”₯

Component
BaseΒ  β†’

Last updated 35 minutes ago

Created by

πŸ‡ΊπŸ‡ΈUnited States mtift Minnesota, USA

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Merge Requests

Comments & Activities

  • Issue created by @mtift
  • πŸ‡ΊπŸ‡ΈUnited States mtift Minnesota, USA
  • First commit to issue fork.
  • Issue was unassigned.
  • πŸ‡ΊπŸ‡ΈUnited States mtift Minnesota, USA
  • πŸ‡§πŸ‡ͺBelgium borisson_ Mechelen, πŸ‡§πŸ‡ͺ

    This requires us to add something like EntityTypeExistsValidator, currently working on that.

  • Pipeline finished with Failed
    9 months ago
    Total: 190s
    #210425
  • Pipeline finished with Failed
    9 months ago
    Total: 606s
    #210440
  • Pipeline finished with Failed
    9 months ago
    Total: 167s
    #210752
  • πŸ‡§πŸ‡ͺBelgium borisson_ Mechelen, πŸ‡§πŸ‡ͺ

    Spellcheck fails, but not sure how to better name this.

  • Status changed to Needs review 9 months ago
  • πŸ‡§πŸ‡ͺBelgium borisson_ Mechelen, πŸ‡§πŸ‡ͺ
  • Status changed to Needs work 9 months ago
  • πŸ‡ΊπŸ‡ΈUnited States smustgrave

    MR appears to have phpcs errors.

  • I have observed the test failures, may be we can use:

    "commentAccepted/commentEligible/commentAllowed" in place of "Commentable"

    As "commentAccepted/commentEligible/commentAllowed" word would be more closer/relative to the "Commentable" word to fix cspell test failures.

    Left suggestion not updating MR, as most of the work done already.

  • First commit to issue fork.
  • Pipeline finished with Failed
    about 1 month ago
    Total: 198s
    #431897
  • Pipeline finished with Failed
    about 1 month ago
    Total: 115s
    #431901
  • Pipeline finished with Failed
    about 1 month ago
    Total: 194s
    #431904
  • πŸ‡³πŸ‡±Netherlands bbrala Netherlands

    Commentable makes so much sense i dont want to change it, just added to the drupal words. THink this can go back to NR

  • Pipeline finished with Failed
    about 1 month ago
    Total: 955s
    #431905
  • πŸ‡³πŸ‡±Netherlands bbrala Netherlands

    Seems a test is still fialing since it expects a string, not null.

  • πŸ‡³πŸ‡±Netherlands bbrala Netherlands

    I don't get why the id cannot be string and this test fails. Trying to figure why that would not be allowed. The schema does tell us string is fine, is that wrong then?

    Drupal\Tests\comment\Kernel\CommentStringIdEntitiesTest::testCommentFieldNonStringId
    Failed asserting that exception of type "Drupal\Core\Config\Schema\SchemaIncompleteException" matches expected exception "UnexpectedValueException". Message was: "Schema errors for comment.type.foo with the following errors: 0 [target_entity_type_id] The &#039;entity_test_string_id&#039; entity is not commentable" at
    core/lib/Drupal/Core/Config/Development/ConfigSchemaChecker.php:98
    vendor/symfony/event-dispatcher/EventDispatcher.php:206
    vendor/symfony/event-dispatcher/EventDispatcher.php:56
    core/lib/Drupal/Core/Config/Config.php:230
    core/lib/Drupal/Core/Config/Entity/ConfigEntityStorage.php:260
    core/lib/Drupal/Core/Entity/EntityStorageBase.php:487
    core/lib/Drupal/Core/Config/Entity/ConfigEntityStorage.php:239
    core/lib/Drupal/Core/Entity/EntityBase.php:370
    core/lib/Drupal/Core/Config/Entity/ConfigEntityBase.php:618
    core/modules/comment/tests/src/Kernel/CommentStringIdEntitiesTest.php:53
    
  • Pipeline finished with Failed
    about 1 month ago
    Total: 593s
    #431999
  • πŸ‡³πŸ‡±Netherlands bbrala Netherlands

    Ok, so the issue remaining is the fact that in ConfigEntityValidationTestBase::testRequiredPropertyValuesMissing it tries to test what happens when a property is set to null. When EntityTypeExistsConstraintValidator is validated it also executes the code:

        if (!is_string($value)) {
          throw new UnexpectedTypeException($value, 'string');
        }
    

    Which is then thrown. When looking at other implementations where this eror is thrown i see ContentLanguageSettings with EntityBundleExists. This sems to be an immutable property.

    I'm now guessing there is 2 possible solutions:

    1. The target_entity_type_id property of the comment type should be immutable.
    2. It is not immutable, but instead of throwing an UnexpectedTypeException is might just need to add a validation error that the property shhould be string.

    What the right solution is, i dont know. Hopefully someone does :x

  • Pipeline finished with Failed
    about 1 month ago
    Total: 154s
    #433686
  • πŸ‡³πŸ‡±Netherlands bbrala Netherlands

    Did some digging. Ended up removing the exception and checking for null and '' in IsCommentable and EntityTypeExists. Seems to make more sense. Also adjusted the test so it expects extra validation errors when looking for null.

  • Pipeline finished with Failed
    about 1 month ago
    Total: 157s
    #433693
  • Pipeline finished with Success
    about 1 month ago
    Total: 3583s
    #433695
  • πŸ‡³πŸ‡±Netherlands bbrala Netherlands

    All green.

  • πŸ‡§πŸ‡ͺBelgium borisson_ Mechelen, πŸ‡§πŸ‡ͺ

    I think this looks good, there's no way I can rtbc this issue, because I wrote part of it.

  • πŸ‡ΊπŸ‡ΈUnited States smustgrave

    Before

    After

    "EntityTypeExists" We actually used a similar constraint in book contrib so glad to see this is going to be part of core.

    Did a review of the code changes and nothing stands out and comments appear to be functioning just fine (11.x standard profile install locally).

    LGTM

  • The Needs Review Queue Bot β†’ tested this issue. It no longer applies to Drupal core. Therefore, this issue status is now "Needs work".

    This does not mean that the patch necessarily needs to be re-rolled or the MR rebased. Read the Issue Summary, the issue tags and the latest discussion here to determine what needs to be done.

    Consult the Drupal Contributor Guide β†’ to find step-by-step guides for working with issues.

  • πŸ‡³πŸ‡±Netherlands bbrala Netherlands

    Conflict was on cspell word list. Rebased, keeping rtbc

  • Pipeline finished with Success
    27 days ago
    Total: 480s
    #442512
  • The Needs Review Queue Bot β†’ tested this issue. It no longer applies to Drupal core. Therefore, this issue status is now "Needs work".

    This does not mean that the patch necessarily needs to be re-rolled or the MR rebased. Read the Issue Summary, the issue tags and the latest discussion here to determine what needs to be done.

    Consult the Drupal Contributor Guide β†’ to find step-by-step guides for working with issues.

  • πŸ‡³πŸ‡±Netherlands bbrala Netherlands

    This was a clean rebase. Not sure why its confused.

  • Pipeline finished with Failed
    13 days ago
    Total: 550s
    #454193
  • πŸ‡³πŸ‡±Netherlands bbrala Netherlands

    Added CR

  • Pipeline finished with Success
    5 days ago
    Total: 1158s
    #460223
Production build 0.71.5 2024