Make WordPress Core


Ignore:
Timestamp:
09/05/2018 11:01:36 AM (6 years ago)
Author:
flixos90
Message:

Upgrade/Install: Introduce populate_site_meta().

Fixes #44896. See #41333.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/tests/phpunit/tests/admin/includesSchema.php

    r43628 r43629  
    88
    99    private static $options;
     10    private static $blogmeta;
    1011    private static $sitemeta;
    1112
     
    1718
    1819        self::$options  = 'testprefix_options';
     20        self::$blogmeta = 'testprefix_blogmeta';
    1921        self::$sitemeta = 'testprefix_sitemeta';
    2022
    2123        $options  = self::$options;
     24        $blogmeta = self::$blogmeta;
    2225        $sitemeta = self::$sitemeta;
    2326
     
    3639                PRIMARY KEY  (option_id),
    3740                UNIQUE KEY option_name (option_name)
     41            ) {$charset_collate}
     42            "
     43        );
     44        $wpdb->query(
     45            "
     46            CREATE TABLE {$blogmeta} (
     47                meta_id bigint(20) unsigned NOT NULL auto_increment,
     48                blog_id bigint(20) unsigned NOT NULL default '0',
     49                meta_key varchar(255) default NULL,
     50                meta_value longtext,
     51                PRIMARY KEY  (meta_id),
     52                KEY meta_key (meta_key({$max_index_length})),
     53                KEY blog_id (blog_id)
    3854            ) {$charset_collate}
    3955            "
     
    6177
    6278        $options  = self::$options;
     79        $blogmeta = self::$blogmeta;
    6380        $sitemeta = self::$sitemeta;
    6481
    6582        $wpdb->query( "DROP TABLE IF EXISTS {$options}" );
     83        $wpdb->query( "DROP TABLE IF EXISTS {$blogmeta}" );
    6684        $wpdb->query( "DROP TABLE IF EXISTS {$sitemeta}" );
    6785    }
     
    158176
    159177    /**
     178     * @ticket 44896
     179     * @group multisite
     180     * @group ms-required
     181     * @dataProvider data_populate_site_meta
     182     */
     183    function test_populate_site_meta( $meta, $expected ) {
     184        global $wpdb;
     185
     186        $orig_blogmeta  = $wpdb->blogmeta;
     187        $wpdb->blogmeta = self::$blogmeta;
     188
     189        populate_site_meta( 42, $meta );
     190
     191        $results = array();
     192        foreach ( $expected as $meta_key => $value ) {
     193            $results[ $meta_key ] = get_site_meta( 42, $meta_key, true );
     194        }
     195
     196        $wpdb->query( "TRUNCATE TABLE {$wpdb->blogmeta}" );
     197
     198        $wpdb->blogmeta = $orig_blogmeta;
     199
     200        $this->assertEquals( $expected, $results );
     201    }
     202
     203    public function data_populate_site_meta() {
     204        return array(
     205            array(
     206                array(),
     207                array(
     208                    'unknown_value' => '',
     209                ),
     210            ),
     211            array(
     212                array(
     213                    'custom_meta' => '1',
     214                ),
     215                array(
     216                    'custom_meta' => '1',
     217                ),
     218            ),
     219        );
     220    }
     221
     222    /**
    160223     * @ticket 44895
     224     * @group multisite
    161225     * @dataProvider data_populate_network_meta
    162226     */
Note: See TracChangeset for help on using the changeset viewer.