Normalize the way core does

Created on 29 August 2021, over 3 years ago
Updated 17 March 2025, 18 days ago

Problem/Motivation

Implement the normalization the same way Config Split does #3229250: Add service to sort a config array the same way core does. β†’ .
But also adopt the core patch to actually do the normalization πŸ“Œ Config export key order is not predictable, use config schema to order keys for maps Fixed

Proposed resolution

Change ConfigItemNormalizer to do normalization instead of getting the plugins.
There may be more, but we can discover that when we have tests.

Remaining tasks

do it
write lots of tests for it. In particular: normalize config from umami, shuffle it and normalize it again and assert that they are the same.

User interface changes

none

API changes

plugins not involved, normalization happens always the same way.

Data model changes

none

πŸ“Œ Task
Status

Downport

Version

2.0

Component

Code

Created by

πŸ‡¨πŸ‡­Switzerland bircher πŸ‡¨πŸ‡Ώ

Live updates comments and jobs are added and updated live.
  • Needs tests

    The change is currently missing an automated test that fails when run with the original code, and succeeds when the bug has been fixed.

Sign in to follow issues

Merge Requests

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • First commit to issue fork.
  • Pipeline finished with Canceled
    17 days ago
    Total: 122s
    #451830
  • Pipeline finished with Canceled
    17 days ago
    Total: 86s
    #451833
  • Pipeline finished with Failed
    17 days ago
    Total: 140s
    #451834
  • Pipeline finished with Failed
    17 days ago
    Total: 137s
    #451836
  • Pipeline finished with Failed
    17 days ago
    Total: 166s
    #451838
  • Pipeline finished with Failed
    17 days ago
    #451865
  • Pipeline finished with Canceled
    17 days ago
    Total: 132s
    #451874
  • Pipeline finished with Failed
    17 days ago
    Total: 252s
    #451876
  • Pipeline finished with Canceled
    17 days ago
    Total: 131s
    #451891
  • Pipeline finished with Failed
    17 days ago
    Total: 140s
    #451892
  • Pipeline finished with Success
    17 days ago
    Total: 143s
    #451900
  • Pipeline finished with Failed
    17 days ago
    Total: 142s
    #451903
  • πŸ‡ΊπŸ‡ΈUnited States trackleft2 Tucson, AZ πŸ‡ΊπŸ‡Έ

    After investigating the failing PHPUnit tests, it appears the issue is caused by unpredictable sequence order when configuration is saved without an orderby: key setting in the configuration's schema. As noted in the configuration schema documentation β†’ , sequence data is preserved in the order it exists unless explicitly sorted.

    My test uses PHP’s shuffle function to alter the sequence order artificially. Without an orderby: key setting in the schema for view displays, the order remains unpredictable, which is causing the PHPUnit tests to fail.

    To test this, I added orderby: key or orderby: value to a local codebase in the following locations:

    Additionally, please note that there is an open dependency array order issue: #3186905: Normalize config import β†’ .

    The Test will always fail unless we change the fixtures to remove sequences that aren't sorted, skip shuffling unsorted sequences, or some other way.

  • πŸ‡ΊπŸ‡ΈUnited States trackleft2 Tucson, AZ πŸ‡ΊπŸ‡Έ

    Setting as needs review to discuss what to do about this new PHPUnit test.

    I'd also like some feedback on the overall approach.

  • Pipeline finished with Failed
    8 days ago
    Total: 163s
    #459200
Production build 0.71.5 2024