mirror of
https://github.com/gosticks/wordpress-develop.git
synced 2025-10-16 12:05:38 +00:00
These calls are intentional and required for the tests. See #49222. git-svn-id: https://develop.svn.wordpress.org/trunk@47118 602fd350-edb4-49c9-b593-d223f7449a82
74 lines
2.3 KiB
PHP
74 lines
2.3 KiB
PHP
<?php
|
|
|
|
/**
|
|
* @group date
|
|
* @group datetime
|
|
*/
|
|
class Tests_Date_mysql2date extends WP_UnitTestCase {
|
|
|
|
function tearDown() {
|
|
// phpcs:ignore WordPress.DateTime.RestrictedFunctions.timezone_change_date_default_timezone_set
|
|
date_default_timezone_set( 'UTC' );
|
|
|
|
parent::tearDown();
|
|
}
|
|
|
|
/**
|
|
* @ticket 28992
|
|
*/
|
|
function test_mysql2date_should_format_time() {
|
|
$timezone = 'Europe/Kiev';
|
|
update_option( 'timezone_string', $timezone );
|
|
$datetime = new DateTime( 'now', new DateTimeZone( $timezone ) );
|
|
$rfc3339 = $datetime->format( DATE_RFC3339 );
|
|
$mysql = $datetime->format( 'Y-m-d H:i:s' );
|
|
|
|
$this->assertEquals( $rfc3339, mysql2date( DATE_RFC3339, $mysql ) );
|
|
$this->assertEquals( $rfc3339, mysql2date( DATE_RFC3339, $mysql, false ) );
|
|
}
|
|
|
|
/**
|
|
* @ticket 28992
|
|
*/
|
|
function test_mysql2date_should_format_time_with_changed_time_zone() {
|
|
$timezone = 'Europe/Kiev';
|
|
// phpcs:ignore WordPress.DateTime.RestrictedFunctions.timezone_change_date_default_timezone_set
|
|
date_default_timezone_set( $timezone );
|
|
update_option( 'timezone_string', $timezone );
|
|
$datetime = new DateTime( 'now', new DateTimeZone( $timezone ) );
|
|
$rfc3339 = $datetime->format( DATE_RFC3339 );
|
|
$mysql = $datetime->format( 'Y-m-d H:i:s' );
|
|
|
|
$this->assertEquals( $rfc3339, mysql2date( DATE_RFC3339, $mysql ) );
|
|
$this->assertEquals( $rfc3339, mysql2date( DATE_RFC3339, $mysql, false ) );
|
|
}
|
|
|
|
/**
|
|
* @ticket 28992
|
|
*/
|
|
function test_mysql2date_should_return_wp_timestamp() {
|
|
$timezone = 'Europe/Kiev';
|
|
update_option( 'timezone_string', $timezone );
|
|
$datetime = new DateTime( 'now', new DateTimeZone( $timezone ) );
|
|
$wp_timestamp = $datetime->getTimestamp() + $datetime->getOffset();
|
|
$mysql = $datetime->format( 'Y-m-d H:i:s' );
|
|
|
|
$this->assertEquals( $wp_timestamp, mysql2date( 'U', $mysql, false ) );
|
|
$this->assertEquals( $wp_timestamp, mysql2date( 'G', $mysql, false ) );
|
|
}
|
|
|
|
/**
|
|
* @ticket 28992
|
|
*/
|
|
function test_mysql2date_should_return_unix_timestamp_for_gmt_time() {
|
|
$timezone = 'Europe/Kiev';
|
|
update_option( 'timezone_string', $timezone );
|
|
$datetime = new DateTime( 'now', new DateTimeZone( 'UTC' ) );
|
|
$timestamp = $datetime->getTimestamp();
|
|
$mysql = $datetime->format( 'Y-m-d H:i:s' );
|
|
|
|
$this->assertEquals( $timestamp, mysql2date( 'U', $mysql, false ) );
|
|
$this->assertEquals( $timestamp, mysql2date( 'G', $mysql, false ) );
|
|
}
|
|
}
|