Changeset 32239
- Timestamp:
- 04/21/2015 06:57:58 AM (10 years ago)
- Location:
- branches/3.9
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
branches/3.9/src/wp-includes/wp-db.php
r32224 r32239 2336 2336 return true; 2337 2337 } 2338 2339 // We don't need to check the collation for queries that don't read data. 2340 $query = ltrim( $query, "\r\n\t (" ); 2341 if ( preg_match( '/^(?:SHOW|DESCRIBE|DESC|EXPLAIN)\s/i', $query ) ) { 2342 return true; 2343 } 2344 2345 // All-ASCII queries don't need extra checking. 2346 if ( $this->check_ascii( $query ) ) { 2347 return true; 2348 } 2349 2338 2350 $table = $this->get_table_from_query( $query ); 2339 2351 if ( ! $table ) { … … 2342 2354 2343 2355 $this->checking_collation = true; 2344 $ this->get_table_charset( $table );2356 $collation = $this->get_table_charset( $table ); 2345 2357 $this->checking_collation = false; 2358 2359 // Tables with no collation, or latin1 only, don't need extra checking. 2360 if ( false === $collation || 'latin1' === $collation ) { 2361 return true; 2362 } 2346 2363 2347 2364 $table = strtolower( $table ); … … 2350 2367 } 2351 2368 2369 // If any of the columns don't have one of these collations, it needs more sanity checking. 2352 2370 foreach( $this->col_meta[ $table ] as $col ) { 2353 2371 if ( empty( $col->Collation ) ) { … … 2377 2395 * remove invalid characters, a {@see WP_Error} object is returned. 2378 2396 */ 2397 // If any of the columns don't have one of these collations, it needs more sanity checking. 2379 2398 protected function strip_invalid_text( $data ) { 2380 2399 // Some multibyte character sets that we can check in PHP. -
branches/3.9/tests/phpunit/tests/db/charset.php
r32237 r32239 500 500 501 501 $value[0] = "CREATE TABLE $this_table_name {$value[0]}"; 502 $value[2] = "SELECT * FROM $this_table_name ";502 $value[2] = "SELECT * FROM $this_table_name WHERE a='\xf0\x9f\x98\x88'"; 503 503 $value[3] = "DROP TABLE IF EXISTS $this_table_name"; 504 $value[4] = array( 505 "SELECT * FROM $this_table_name WHERE a='foo'", 506 "SHOW FULL TABLES LIKE $this_table_name", 507 "DESCRIBE $this_table_name", 508 "DESC $this_table_name", 509 "EXPLAIN SELECT * FROM $this_table_name", 510 ); 504 511 } 505 512 unset( $value ); … … 513 520 * @ticket 21212 514 521 */ 515 function test_table_collation_check( $create, $expected, $query, $drop ) {522 function test_table_collation_check( $create, $expected, $query, $drop, $always_true ) { 516 523 self::$_wpdb->query( $drop ); 517 524 … … 521 528 $this->assertEquals( $expected, $return ); 522 529 530 foreach( $always_true as $true_query ) { 531 $return = self::$_wpdb->check_safe_collation( $true_query ); 532 $this->assertTrue( $return ); 533 } 534 523 535 self::$_wpdb->query( $drop ); 524 536 }
Note: See TracChangeset
for help on using the changeset viewer.