- Issue created by @phenaproxima
- Merge request !4535Issue #3379091: Make NodeType config entities fully validatable → (Closed) created by phenaproxima
- last update
over 1 year ago 29,947 pass - Assigned to wim leers
- Status changed to Needs review
over 1 year ago 4:07pm 3 August 2023 - 🇺🇸United States phenaproxima Massachusetts
Well, that was easy. Assigning to Wim for review.
- Assigned to phenaproxima
- Status changed to Needs work
over 1 year ago 4:27pm 3 August 2023 - 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
help
anddescription
need validation constraints too. It's not that because they're optional that we accept any value for them.I'd like to see explicit test coverage for trying to set
preview_mode
tonull
, because I'm not sure if that would be cast to0
during validation at some point? 🤔They're
type: text
… do we want invisible control characters (think \x08 for backspace: https://www.asciitable.com/) to be accepted?Opened 📌 Add validation constraint to `type: label` + `type: text`: disallow control characters Fixed for this.
- last update
over 1 year ago 27,971 pass, 1,250 fail - 🇺🇸United States phenaproxima Massachusetts
help and description need validation constraints too. It's not that because they're optional that we accept any value for them.
I mean...I agree, but what constraints would you have me add here? Both are optional text fields. They are already using the
text
data type. I agree that we want to disallow control characters, but I also agree that's not in scope here, and should be done in a separate issue.I guess we could at least add
NotNull
.I'd like to see explicit test coverage for trying to set preview_mode to null
Great catch! This revealed the need for a
NotNull
constraint onpreview_mode
. - 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
Making
help
anddescription
not nullable implies making them required? 😅 - 🇺🇸United States phenaproxima Massachusetts
Wouldn't they be empty strings? That's distinct from NULL.
- 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
Yes, but IIRC
\Drupal\Core\Validation\Plugin\Validation\Constraint\NotNullConstraintValidator::validate()
automatically maps''
toNULL
🤓 - last update
over 1 year ago 29,961 pass, 4 fail - last update
over 1 year ago 29,960 pass, 6 fail - Assigned to wim leers
- Status changed to Needs review
over 1 year ago 5:48pm 3 August 2023 - 🇺🇸United States phenaproxima Massachusetts
Re #8: that's not accurate.
\Drupal\Core\Validation\Plugin\Validation\Constraint\NotNullConstraintValidator::validate()
maps empty values to NULL...forListInterface
andComplexDataInterface
. Plain strings don't implement those interfaces (although string field items do). Meanwhile, the parent class of that validator strictly checks for NULL.So,
NotNull
is a reasonable choice forhelp
anddescription
. - Assigned to phenaproxima
- Status changed to Needs work
over 1 year ago 6:56am 4 August 2023 - 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
#9: Oops, you're right! I was confusing it with
StringItem
which does implementComplexDataInterface
. Since this is (typed) config, this isStringData
instead. My bad!But … I don't think defaulting
help
anddescription
to the empty string makes sense? That means we'd end up withnode.type.*.yml
files containing:name: Article type: article help: '' description: '' …
Wouldn't it then be clearer to have this instead?
name: Article type: article help: null description: null …
IOW: I think
NotBlank
would be conceptually more clear thanNotNull
. Requiring a value (i.e. not NULL) but then accepting the empty string feels rather odd to me? 🥸 - 🇺🇸United States phenaproxima Massachusetts
NotBlank is a no-go: that means description and help will become required, rather than optional. Changing the defaults to empty strings is correct — there is default config in core with empty strings for those keys.
- 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
I'm questioning whether that default config makes sense.
- last update
over 1 year ago 29,988 pass - Status changed to Postponed
over 1 year ago 1:44pm 8 August 2023 - 🇺🇸United States phenaproxima Massachusetts
Okay, Wim, I think you've convinced me (on Slack, that is). Let's postpone this issue on 📌 Configuration schema & required values: add test coverage for `nullable: true` validation support Fixed and make those fields nullable.
The solution you proposed (which I think is good) is:
ADD NotBlank → empty string is not allowed, because that’s nonsensical
REMOVE NotNull
Modify the logic of \Drupal\node\Entity\NodeType::getDescription() (the Entity API-level representation) to return the empty string if the config-level representation contains null, to avoid a BC break. - 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
To allow other Drupal contributors to actually grok #13:
@phenaproxima wrote in Slack, in response to #12:
OK, I don’t see how it doesn’t make sense. These are just optional strings.
null
would be legit, as would''
in my opinionSo I don’t really care how we approach them, but I cannot for the life of me see what other constraints would be useful.
to which I responded this:
The point is that
description: ''
(the empty string) makes it seem like there’s an actual description present, but there isn’t. All we’ve done is satisfy the requirement that it’s a string.So on the one hand it’s a “required” value (because we’re not allowing
null
, which is why you changed it to''
in your latest commit).This conveys “every Node Type MUST have a description”. Okay! 👍
But on the other hand we allow a value that is completely pointless, because the empty string is NOT a reasonable description! 👎
That’s why I’m saying 📌 [PP-1] Make NodeType config entities fully validatable Needs review it would be clearer to have
description: null
, because that at least makes it clear that it is indeed optional.Any time something is optional, it should allow
null
. That’s literally why\Drupal\Core\TypedData\TypedDataManager::getDefaultConstraints()
has:// Add the NotNull constraint for required data. if ($definition->isRequired()) { $constraints['NotNull'] = []; }
IMHO the correct solution is:
- ADD
NotBlank
→ empty string is not allowed, because that’s nonsensical - REMOVE
NotNull
- Modify the logic of
\Drupal\node\Entity\NodeType::getDescription()
(the Entity API-level representation) to return the empty string if the config-level representation containsnull
, to avoid a BC break.
- ADD
- 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
FYI this is itself also a blocker, for 📌 [PP-1] Make NodeType config entities fully validatable Needs review .
- Status changed to Active
over 1 year ago 9:30am 30 August 2023 - 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
Let’s continue this issue, because there’s nothing stopping us from rebasing that MR on top of a squashed commit of its blocker’s ( 📌 Configuration schema & required values: add test coverage for `nullable: true` validation support Fixed ) MR! 🤓
If we can get this to green or even RTBC, then it becomes more likely that the blocker (which has been RTBC for exactly 3 weeks now) gets committed! 🤞
(Also: it's clear that 📌 [PP-1] Convert field_storage_config and field_config's form validation logic to validation constraints Postponed is full of dragons 🐲 that jump out of every crevice 🐉 — so getting this one config entity type to fully validatable is much more realistic and would still be a huge leap forward!)
- last update
over 1 year ago 30,175 pass, 1 fail - last update
over 1 year ago Build Successful - Assigned to wim leers
- Status changed to Needs review
over 1 year ago 4:15pm 18 September 2023 - last update
over 1 year ago Build Successful - last update
over 1 year ago Build Successful - last update
over 1 year ago Build Successful - last update
over 1 year ago Build Successful - 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
This is impossible to review right now, because I can't create a diff relative to 📌 [PP-1] Make NodeType config entities fully validatable Needs review . To allow for such diffs, this must always:
- be rebased on top of the latest
origin/11.x
- with its oldest commit being the commit that brings in #3379091
So, did that: started from latest 11.x, cherry-picked #3379091, then cherry-picked all of the individual commits by @phenaproxima one-by-one.
- be rebased on top of the latest
- Assigned to phenaproxima
- Status changed to Needs work
over 1 year ago 10:24am 19 September 2023 - 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
+++ b/core/modules/node/config/schema/node.schema.yml @@ -26,15 +26,29 @@ node.type.*: + nullable: true + constraints: + NotBlank: + allowNull: true help: type: text label: 'Explanation or submission guidelines' + nullable: true + constraints: + NotBlank: + allowNull: true new_revision: type: boolean label: 'Whether a new revision should be created by default' preview_mode: type: integer label: 'Preview before submitting' + constraints: + NotNull: [] + # These are the values of the DRUPAL_DISABLED, DRUPAL_OPTIONAL, and + # DRUPAL_REQUIRED constants. + # @see \Drupal\node\NodeTypeForm::form() + Choice: [0, 1, 2]
Looks great! 🤩
232 tests fail. Looks like many of them are due to a missing update path. For example when running
CKEditor5UpdateCodeBlockConfigurationTest
, the failure is:There should be no errors in configuration 'node.type.article'. Errors: Schema key 0 failed with: [help] This value should not be blank. Failed asserting that Array &0 ( 0 => '[help] This value should not be blank.' ) is true.
That update logic should match the one at 📌 Views should require a label, rather than falling back to an unhelpful ID RTBC .
- last update
over 1 year ago Build Successful - 🇺🇸United States phenaproxima Massachusetts
Here's a review-only version of the patch which doesn't include the stuff in 📌 Configuration schema & required values: add test coverage for `nullable: true` validation support Fixed .
- last update
over 1 year ago 30,087 pass, 163 fail - last update
over 1 year ago 30,183 pass, 4 fail - last update
over 1 year ago 30,195 pass, 1 fail - last update
over 1 year ago 30,203 pass - Assigned to wim leers
- Status changed to Needs review
over 1 year ago 4:53pm 20 September 2023 - 🇺🇸United States phenaproxima Massachusetts
Finally! Here's a review-only patch.
- Issue was unassigned.
- Status changed to RTBC
over 1 year ago 5:46pm 20 September 2023 - 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
That was fast! 😄 Way faster than I thought possible!
I have zero remarks whatsoever 😦😅🥳
I have only one bit of magnificent output to share:
$ vendor/bin/drush config:inspect --filter-keys=node.type.article --detail --strict-validation Legend for Data: ✅❓ → Correct primitive type, detailed validation impossible. ✅✅ → Correct primitive type, passed all validation constraints. ---------------------------------------------- --------- ------------- --------------------------------- Key Status Validatable Data ---------------------------------------------- --------- ------------- --------------------------------- node.type.article Correct 100% 1 errors node.type.article: Correct Validatable ✅✅ node.type.article:_core Correct Validatable ✅✅ node.type.article:_core.default_config_hash Correct Validatable ✅✅ node.type.article:dependencies Correct Validatable ✅✅ node.type.article:description Correct Validatable ✅✅ node.type.article:display_submitted Correct Validatable ✅✅ node.type.article:help Correct Validatable This value should not be blank. node.type.article:langcode Correct Validatable ✅✅ node.type.article:name Correct Validatable ✅✅ node.type.article:new_revision Correct Validatable ✅✅ node.type.article:preview_mode Correct Validatable ✅✅ node.type.article:status Correct Validatable ✅✅ node.type.article:type Correct Validatable ✅✅ node.type.article:uuid Correct Validatable ✅✅ ---------------------------------------------- --------- ------------- ---------------------------------
(Fresh install of
11.x
branch, https://www.drupal.org/project/config_inspector → installed, then switching to this MR, will give you that output.)Look at that!!! The first 100% validatable config entity type! 🤩🚀
Marking as a postponed RTBC until the blocker lands. Awesome work, @phenaproxima! 🙏
- last update
over 1 year ago 30,203 pass - Status changed to Postponed
over 1 year ago 8:08pm 22 September 2023 - 🇺🇸United States effulgentsia
Setting status to postponed since it's blocked on 📌 Configuration schema & required values: add test coverage for `nullable: true` validation support Fixed which needs a rebase.
- 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
Re-reviewing this now that [#3364109 is getting closer …
+++ b/core/modules/node/config/schema/node.schema.yml @@ -26,15 +26,29 @@ node.type.*: + nullable: true + constraints: + NotBlank: + allowNull: true
The first line here will be necessary after 📌 Configuration schema & required values: add test coverage for `nullable: true` validation support Fixed lands.
The last 3 lines: 1) IMHO this should be added to
type: text
(see 📌 Add validation constraint to `type: label` + `type: text`: disallow control characters Fixed for earlier issue), 2) confirming that this constraint makes sense — ran into that (NotBlank: {allowNull: true}
) with another issue: 🐛 When setting `NotNull` constraint on type: required_label, two validation errors appear Needs review . - 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
+++ b/core/modules/node/config/schema/node.schema.yml @@ -26,15 +26,29 @@ node.type.*: + NotBlank: + allowNull: true ... + NotBlank: + allowNull: true
Thanks to 🐛 When setting `NotNull` constraint on type: required_label, two validation errors appear Needs review having landed, this can now be changed to merely
NotBlank: {}
👍
- Assigned to wim leers
- Status changed to Needs work
about 1 year ago 1:42am 15 December 2023 - 🇺🇸United States phenaproxima Massachusetts
📌 Configuration schema & required values: add test coverage for `nullable: true` validation support Fixed landed, so per #23 this is no longer postponed. Assigning to Wim for rebase and whatever updates are needed.
- Status changed to Needs review
about 1 year ago 8:08am 15 December 2023 - 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
Whew, this ain't no simple rebase or merge! 😳
Catching this up on months of history and getting rid of the in-flux blocker that was merged in here but has now been merged upstream (see #26) is no easy task.
I came up with this:
$ git log --oneline -n 25 --first-parent f0984b5f0c1 Fix jsonapi NodeTypeTest ab22479ac7e Fix base class for REST resource test d46b907e178 Make the NodeType migration destination set help and description to NULL if empty 9e29c8b053c Make NodeTypeForm explicitly set NULL for empty description and help 4d4123fcb74 Add explicit update path test coverage 732ef4b451f Fix typo 3425dc4dba7 Merge remote-tracking branch 'origin/11.x' into 3379091-make-nodetype-config a041e788f3e Merge branch '3379091-make-nodetype-config' of git.drupal.org:issue/drupal-3379091 into 3379091-make-nodetype-config c77d2f18b9e Add update path to Node, hopefully fixing all tests ccae4f1431b Merge remote-tracking branch 'origin/11.x' into 3379091-make-nodetype-config cc0c5fb04dc Same for description 6fcb09a569c Make empty help null in all node types shipped with core b5c7ce6ebb8 Make help and description nullable, but not blank 11da9ff35c8 Merge remote-tracking branch 'origin/11.x' into 3379091-make-nodetype-config 1f4d04a920c Merge in #3379091 5ac40b2cdf9 Merge remote-tracking branch 'origin/11.x' into 3379091-make-nodetype-config d0d54c1cb97 Fix a couple of broken tests a4a87d179c1 Merge branch '11.x' into 3379091-make-nodetype-config 266caf476d5 Fix node.type.options_insatll_test e5cc02f6ee4 Default NodeType::$help and ::$description to empty strings d4583730a3c Make help and description non-nullable 09073c0e92a Add NotNull check c32fa582a0f Make preview_mode validatable and add explicit test coverage 5052fcddde7 Issue #3377131 by longwave, smustgrave: File mode check in commit-code-check.sh is too strict d8ec17df74c Issue #3219667 by quietone, ravi.shankar, longwave, smustgrave: Fix spelling for words used once, beginning with 't' -> 'z', inclusive
gives me the commit hashes of all commits from this MR that I care about (I could also copy/paste them from https://git.drupalcode.org/project/drupal/-/merge_requests/4535/commits, but that is a LOT of clicking and back-and-forth).
Next, create a new branch from upstream
11.x
:git checkout -b 3379091-nodetype-post-required-values
and then do an interactive rebase in which I paste the relevant commits that I want to port into the new branch (which is all of them except the ones that mention "merge"):
pick f0984b5f0c1 Fix jsonapi NodeTypeTest pick ab22479ac7e Fix base class for REST resource test pick d46b907e178 Make the NodeType migration destination set help and description to NULL if empty pick 9e29c8b053c Make NodeTypeForm explicitly set NULL for empty description and help pick 4d4123fcb74 Add explicit update path test coverage pick 732ef4b451f Fix typo pick c77d2f18b9e Add update path to Node, hopefully fixing all tests pick cc0c5fb04dc Same for description pick 6fcb09a569c Make empty help null in all node types shipped with core pick b5c7ce6ebb8 Make help and description nullable, but not blank pick d0d54c1cb97 Fix a couple of broken tests pick 266caf476d5 Fix node.type.options_insatll_test pick e5cc02f6ee4 Default NodeType::$help and ::$description to empty strings pick d4583730a3c Make help and description non-nullable pick 09073c0e92a Add NotNull check pick c32fa582a0f Make preview_mode validatable and add explicit test coverage
and then invert their order (CTRL+T on macOS), to paste them into the interactive rebase.
So then the interactive rebase looks like this:
$ git rebase -i HEAD^^ pick 502c857b92a Issue #3408698 by lauriii, alexpott: Provide alter for the field typ e UI definitions¬ pick 5aa9704ce3a Issue #3364109 by Wim Leers, effulgentsia, lauriii, phenaproxima, bo risson_, bircher, alexpott: Configuration schema & required values: add test coverage for `nullable: true` validation support¬ pick c32fa582a0f Make preview_mode validatable and add explicit test coverage¬ pick 09073c0e92a Add NotNull check¬ pick d4583730a3c Make help and description non-nullable¬ pick e5cc02f6ee4 Default NodeType::$help and ::$description to empty strings¬ pick 266caf476d5 Fix node.type.options_insatll_test¬ pick d0d54c1cb97 Fix a couple of broken tests¬ pick b5c7ce6ebb8 Make help and description nullable, but not blank¬ pick 6fcb09a569c Make empty help null in all node types shipped with core¬ pick cc0c5fb04dc Same for description¬ pick c77d2f18b9e Add update path to Node, hopefully fixing all tests¬ pick 732ef4b451f Fix typo¬ pick 4d4123fcb74 Add explicit update path test coverage¬ pick 9e29c8b053c Make NodeTypeForm explicitly set NULL for empty description and help ¬ pick d46b907e178 Make the NodeType migration destination set help and description to NULL if empty¬ pick ab22479ac7e Fix base class for REST resource test¬ pick f0984b5f0c1 Fix jsonapi NodeTypeTest¬
- 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
Wim Leers → changed the visibility of the branch 3379091-make-nodetype-config to hidden.
- Assigned to phenaproxima
- Status changed to Needs work
about 1 year ago 8:45am 15 December 2023 - 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
The new MR is green!
What does it contain?
- All commits @phenaproxima did when he worked on this originally between August 3 and September 20, just with the merge commits omitted (see #27)
- A commit to remove the
::testNonNullableFields()
test coverage @phenaproxima added, because that landed as part of 📌 Configuration schema & required values: add test coverage for `nullable: true` validation support Fixed , where it was named::testRequiredPropertyValuesMissing()
(which tests it in more detail and in a more robust way) - A commit to actually use the infra that #3364109 added: i) use the
FullyValidatable
constraint onNodeType
, ii) explicitly declaredescription
andhelp
as having optional values, to allow::testRequiredPropertyValuesMissing()
to pass - A commit to simplify the config schema changes: no more need to specify
NotNull
thanks to specifyingFullyValidatable
at the root!
I will RTBC this … once there is a change record. 😄
- 🇧🇪Belgium borisson_ Mechelen, 🇧🇪
I agree with @Wim Leers, the open MR is looking great and the testcoverage that is added is great as well. The last nitpick should be simple to remove as well.
Do we need the change record for the added strictness to the schema (and will we need one for each entity type we make more strict as we go?), or what is it for?
- First commit to issue fork.
- 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
@sourabhjain That's the second issue in a span of 10 minutes 📌 Add validation constraints to block_content.type.* Needs work where you applied my suggestion manually locally and pushed it. Why are you doing that? 🤔
- 🇮🇳India sourabhjain
I apologize for any inconvenience, @wim-leers. I misunderstood the suggestion, thinking it was a provided task that anyone could work on. I will be more careful in the future and ensure that such misunderstandings don't happen again. Rest assured, everyone at Valuebound will be mindful of this.
- Assigned to wim leers
- Status changed to Needs review
about 1 year ago 2:24pm 18 December 2023 - 🇺🇸United States phenaproxima Massachusetts
Change record written: https://www.drupal.org/node/3409486 →
- Issue was unassigned.
- Status changed to RTBC
about 1 year ago 2:30pm 18 December 2023 - 🇦🇺Australia larowlan 🇦🇺🏝.au GMT+10
Left a question on the MR, not changing the status
- 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
Addressed — keeping at RTBC because it was a trivial change.
-
larowlan →
committed 52adbcfa on 11.x
Issue #3379091 by phenaproxima, Wim Leers: Make NodeType config entities...
-
larowlan →
committed 52adbcfa on 11.x
- Status changed to Fixed
about 1 year ago 11:18pm 21 December 2023 - 🇦🇺Australia larowlan 🇦🇺🏝.au GMT+10
Committed to 11.x
Didn't backport to 10.2.x because this has an update path which is not allowed in patch updates.
Published change record.
Automatically closed - issue fixed for 2 weeks with no activity.