Move the PostgreSQL override of the entityQuery to the pgsql module

Created on 20 November 2024, 4 months ago

Problem/Motivation

The database driver have been moved to their own modules and all database specific stuff should be in those modules. The PostgreSQL override of the entityQuery is now located in the namespace Drupal\Core\Entity\Query\Sql\pgsql and not in the pgsql module.

Proposed resolution

Move the PostgreSQL override of the entityQuery to the pgsql module

Remaining tasks

TBD

User interface changes

None

Introduced terminology

None

API changes

None

Data model changes

None

Release notes snippet

TBD

πŸ“Œ Task
Status

Active

Version

11.0 πŸ”₯

Component

postgresql db driver

Created by

πŸ‡³πŸ‡±Netherlands daffie

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

Merge Requests

Comments & Activities

  • Issue created by @daffie
  • Pipeline finished with Failed
    4 months ago
    Total: 143s
    #344510
  • Pipeline finished with Failed
    4 months ago
    Total: 1369s
    #344640
  • Pipeline finished with Failed
    4 months ago
    Total: 610s
    #344658
  • Pipeline finished with Success
    4 months ago
    Total: 1687s
    #344724
  • Pipeline finished with Failed
    4 months ago
    Total: 143s
    #344773
  • Pipeline finished with Success
    4 months ago
    Total: 2008s
    #344775
  • πŸ‡³πŸ‡±Netherlands daffie

    Ready for a review.

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

    Only comment is if we can add a simple deprecation test for the class

  • Pipeline finished with Failed
    4 months ago
    Total: 196s
    #368435
  • πŸ‡³πŸ‡±Netherlands daffie

    The requested deprecation test has been added.
    Back to NR.

    @smustgrave: Thank you for the review.

  • Pipeline finished with Success
    4 months ago
    Total: 8342s
    #368438
  • πŸ‡ΊπŸ‡ΈUnited States smustgrave

    Thanks! rest of the changes LGTM.

  • πŸ‡¬πŸ‡§United Kingdom alexpott πŸ‡ͺπŸ‡ΊπŸŒ

    This patch does not implement the deprecation for 11.x correctly... before:

    > \Drupal::service('pgsql.entity.query.sql')
    = Drupal\Core\Entity\Query\Sql\pgsql\QueryFactory {#7704}
    

    after

    > \Drupal::service('pgsql.entity.query.sql')
    
       Error  Class "Drupal\pgsql\EntityQuery\QueryFactory" not found.
    

    The core classes cannot extend the pgsql classes. We should just deprecate the code and not extend from the new code.

  • Pipeline finished with Success
    3 months ago
    Total: 618s
    #392093
  • πŸ‡³πŸ‡±Netherlands daffie

    As requested by @alexpott, the extending of the deprecated classes to the new ones in the pgsql module have been removed and the original code has been restored..

  • Status changed to Needs work about 2 months ago
  • πŸ‡ΊπŸ‡ΈUnited States smustgrave

    Appears to be 1 open thread on MR.

  • Pipeline finished with Success
    about 1 month ago
    Total: 927s
    #436672
  • Pipeline finished with Failed
    about 1 month ago
    Total: 691s
    #436707
  • Pipeline finished with Failed
    about 1 month ago
    Total: 424s
    #436820
  • Pipeline finished with Failed
    about 1 month ago
    Total: 493s
    #436844
  • Pipeline finished with Failed
    about 1 month ago
    Total: 111s
    #436897
  • Pipeline finished with Failed
    about 1 month ago
    Total: 556s
    #436913
  • Pipeline finished with Success
    about 1 month ago
    Total: 435s
    #438571
  • Pipeline finished with Success
    about 1 month ago
    Total: 2758s
    #438908
  • πŸ‡³πŸ‡±Netherlands daffie

    I have added the by @alexpott requested deprecation to the service in core.services.yml.

  • Pipeline finished with Failed
    29 days ago
    Total: 500s
    #441165
  • Pipeline finished with Canceled
    29 days ago
    Total: 235s
    #441179
  • πŸ‡¬πŸ‡§United Kingdom alexpott πŸ‡ͺπŸ‡ΊπŸŒ

    Moving the deprecation to the constructor (like we do for plugins) resolves the issues caused by compiler passes reflecting on the class. This is very similar to what we do for plugins. They can't have deprecations in the main body of a class for a similar reason.

  • Pipeline finished with Success
    29 days ago
    Total: 1125s
    #441182
  • πŸ‡³πŸ‡±Netherlands daffie

    @alexpott: Moving the deprecation to the constructor was the solution. Thank you for your help. It is clear to me why you are a core framework manager and I am not. ;-)

    All code changes look good to me.
    All deprecations have testing.
    We have a change record.
    For me it is RTBC.

  • πŸ‡ΊπŸ‡ΈUnited States mradcliffe USA

    Seems good to me. Do we need to trigger a "PHP 8.3 PostgreSQL 16" test run?

  • πŸ‡³πŸ‡±Netherlands daffie

    Do we need to trigger a "PHP 8.3 PostgreSQL 16" test run?

    I have tried, but I am not allowed to do that.

Production build 0.71.5 2024