From 862a65eaccefe2a141d070b2e0083948f1fa1eb8 Mon Sep 17 00:00:00 2001
From: Guy Sartorelli <36352093+GuySartorelli@users.noreply.github.com>
Date: Mon, 30 Sep 2024 18:32:17 +1300
Subject: [PATCH] MNT Fix unit tests (#11409)
---
tests/php/Forms/DateFieldDisabledTest.php | 9 +++---
tests/php/Forms/DatetimeFieldTest.php | 11 +++----
tests/php/ORM/DBDateTest.php | 35 ++++++++++++-----------
tests/php/ORM/DBDatetimeTest.php | 13 +++++----
tests/php/ORM/DBTimeTest.php | 4 +--
5 files changed, 38 insertions(+), 34 deletions(-)
diff --git a/tests/php/Forms/DateFieldDisabledTest.php b/tests/php/Forms/DateFieldDisabledTest.php
index 207c9b652ae..3cb107b183c 100644
--- a/tests/php/Forms/DateFieldDisabledTest.php
+++ b/tests/php/Forms/DateFieldDisabledTest.php
@@ -12,7 +12,8 @@ class DateFieldDisabledTest extends SapphireTest
protected function setUp(): void
{
parent::setUp();
- i18n::set_locale('en_NZ');
+ // Set to an explicit locale so project-level locale swapping doesn't affect tests
+ i18n::set_locale('en_US');
DBDatetime::set_mock_now('2011-02-01 8:34:00');
}
@@ -22,7 +23,7 @@ public function testFieldToday()
$actual = DateField_Disabled::create('Test')
->setValue('2011-02-01')
->Field();
- $expected = '1/02/2011 (today)';
+ $expected = 'Feb 1, 2011 (today)';
$this->assertEquals($expected, $actual);
// Test today's date with time
@@ -38,14 +39,14 @@ public function testFieldWithDifferentDay()
$actual = DateField_Disabled::create('Test')
->setValue('2011-01-27')
->Field();
- $expected = '27/01/2011, 5 days ago';
+ $expected = 'Jan 27, 2011, 5 days ago';
$this->assertEquals($expected, $actual);
// Test future
$actual = DateField_Disabled::create('Test')
->setValue('2011-02-06')
->Field();
- $expected = '6/02/2011, in 5 days';
+ $expected = 'Feb 6, 2011, in 5 days';
$this->assertEquals($expected, $actual);
}
diff --git a/tests/php/Forms/DatetimeFieldTest.php b/tests/php/Forms/DatetimeFieldTest.php
index 3f28a251557..01c129f3d46 100644
--- a/tests/php/Forms/DatetimeFieldTest.php
+++ b/tests/php/Forms/DatetimeFieldTest.php
@@ -21,7 +21,8 @@ class DatetimeFieldTest extends SapphireTest
protected function setUp(): void
{
parent::setUp();
- i18n::set_locale('en_NZ');
+ // Set to an explicit locale so project-level locale swapping doesn't affect tests
+ i18n::set_locale('en_US');
// Fix now to prevent race conditions
DBDatetime::set_mock_now('2010-04-04');
$this->timezone = date_default_timezone_get();
@@ -141,14 +142,14 @@ public function testSetValueWithLocalised()
$datetimeField
->setHTML5(false)
- ->setLocale('en_NZ');
+ ->setLocale('de_DE');
- $datetimeField->setSubmittedValue('29/03/2003 11:00:00 pm');
- $this->assertEquals($datetimeField->dataValue(), '2003-03-29 23:00:00');
+ $datetimeField->setSubmittedValue('29/03/2003 23:00:00');
+ $this->assertEquals('2003-03-29 23:00:00', $datetimeField->dataValue());
// Some localisation packages exclude the ',' in default medium format
$this->assertMatchesRegularExpression(
- '#29/03/2003(,)? 11:00:00 (PM|pm)#',
+ '#29.03.2003(,)? 23:00:00#',
$datetimeField->Value(),
'User value is formatted, and in user timezone'
);
diff --git a/tests/php/ORM/DBDateTest.php b/tests/php/ORM/DBDateTest.php
index d91360155cc..0f729cc949c 100644
--- a/tests/php/ORM/DBDateTest.php
+++ b/tests/php/ORM/DBDateTest.php
@@ -20,7 +20,8 @@ protected function setUp(): void
$this->oldError = error_reporting();
// Validate setup
assert(date_default_timezone_get() === 'UTC');
- i18n::set_locale('en_NZ');
+ // Set to an explicit locale so project-level locale swapping doesn't affect tests
+ i18n::set_locale('en_US');
}
protected function tearDown(): void
@@ -48,42 +49,42 @@ protected function restoreNotices()
public function testNiceDate()
{
$this->assertEquals(
- '31/03/2008',
+ 'Mar 31, 2008',
DBField::create_field('Date', 1206968400)->Nice(),
"Date->Nice() works with timestamp integers"
);
$this->assertEquals(
- '30/03/2008',
+ 'Mar 30, 2008',
DBField::create_field('Date', 1206882000)->Nice(),
"Date->Nice() works with timestamp integers"
);
$this->assertEquals(
- '31/03/2008',
+ 'Mar 31, 2008',
DBField::create_field('Date', '1206968400')->Nice(),
"Date->Nice() works with timestamp strings"
);
$this->assertEquals(
- '30/03/2008',
+ 'Mar 30, 2008',
DBField::create_field('Date', '1206882000')->Nice(),
"Date->Nice() works with timestamp strings"
);
$this->assertEquals(
- '4/03/2003',
+ 'Mar 4, 2003',
DBField::create_field('Date', '4.3.2003')->Nice(),
"Date->Nice() works with D.M.YYYY format"
);
$this->assertEquals(
- '4/03/2003',
+ 'Mar 4, 2003',
DBField::create_field('Date', '04.03.2003')->Nice(),
"Date->Nice() works with DD.MM.YYYY format"
);
$this->assertEquals(
- '4/03/2003',
+ 'Mar 4, 2003',
DBField::create_field('Date', '2003-3-4')->Nice(),
"Date->Nice() works with YYYY-M-D format"
);
$this->assertEquals(
- '4/03/2003',
+ 'Mar 4, 2003',
DBField::create_field('Date', '2003-03-04')->Nice(),
"Date->Nice() works with YYYY-MM-DD format"
);
@@ -107,7 +108,7 @@ public function testInvertedYearCorrection()
{
// iso8601 expects year first, but support year last
$this->assertEquals(
- '4/03/2003',
+ 'Mar 4, 2003',
DBField::create_field('Date', '04-03-2003')->Nice(),
"Date->Nice() works with DD-MM-YYYY format"
);
@@ -152,32 +153,32 @@ public function testShortMonth()
public function testLongDate()
{
$this->assertEquals(
- '31 March 2008',
+ 'March 31, 2008',
DBField::create_field('Date', 1206968400)->Long(),
"Date->Long() works with numeric timestamp"
);
$this->assertEquals(
- '31 March 2008',
+ 'March 31, 2008',
DBField::create_field('Date', '1206968400')->Long(),
"Date->Long() works with string timestamp"
);
$this->assertEquals(
- '30 March 2008',
+ 'March 30, 2008',
DBField::create_field('Date', 1206882000)->Long(),
"Date->Long() works with numeric timestamp"
);
$this->assertEquals(
- '30 March 2008',
+ 'March 30, 2008',
DBField::create_field('Date', '1206882000')->Long(),
"Date->Long() works with numeric timestamp"
);
$this->assertEquals(
- '3 April 2003',
+ 'April 3, 2003',
DBField::create_field('Date', '2003-4-3')->Long(),
"Date->Long() works with YYYY-M-D"
);
$this->assertEquals(
- '3 April 2003',
+ 'April 3, 2003',
DBField::create_field('Date', '3.4.2003')->Long(),
"Date->Long() works with D.M.YYYY"
);
@@ -186,7 +187,7 @@ public function testLongDate()
public function testFull()
{
$this->assertEquals(
- 'Monday, 31 March 2008',
+ 'Monday, March 31, 2008',
DBField::create_field('Date', 1206968400)->Full(),
"Date->Full() works with timestamp integers"
);
diff --git a/tests/php/ORM/DBDatetimeTest.php b/tests/php/ORM/DBDatetimeTest.php
index 71b24be225b..778b875dc07 100644
--- a/tests/php/ORM/DBDatetimeTest.php
+++ b/tests/php/ORM/DBDatetimeTest.php
@@ -14,7 +14,8 @@ class DBDatetimeTest extends SapphireTest
protected function setUp(): void
{
parent::setUp();
- i18n::set_locale('en_NZ');
+ // Set to an explicit locale so project-level locale swapping doesn't affect tests
+ i18n::set_locale('en_US');
}
public function testNowWithSystemDate()
@@ -126,23 +127,23 @@ public function testNice()
$date = DBDatetime::create_field('Datetime', '2001-12-11 22:10:59');
// note: Some localisation packages exclude the ',' in default medium format
- i18n::set_locale('en_NZ');
- $this->assertMatchesRegularExpression('#11/12/2001(,)? 10:10 PM#i', $date->Nice());
+ i18n::set_locale('de_DE');
+ $this->assertMatchesRegularExpression('#11.12.2001(,)? 22:10#i', $date->Nice());
i18n::set_locale('en_US');
- $this->assertMatchesRegularExpression('#Dec 11(,)? 2001(,)? 10:10 PM#i', $date->Nice());
+ $this->assertMatchesRegularExpression('#Dec 11(,)? 2001(,)? 10:10\hPM#iu', $date->Nice());
}
public function testDate()
{
$date = DBDatetime::create_field('Datetime', '2001-12-31 22:10:59');
- $this->assertEquals('31/12/2001', $date->Date());
+ $this->assertEquals('Dec 31, 2001', $date->Date());
}
public function testTime()
{
$date = DBDatetime::create_field('Datetime', '2001-12-31 22:10:59');
- $this->assertMatchesRegularExpression('#10:10:59 PM#i', $date->Time());
+ $this->assertMatchesRegularExpression('#10:10:59\hPM#iu', $date->Time());
}
public function testTime24()
diff --git a/tests/php/ORM/DBTimeTest.php b/tests/php/ORM/DBTimeTest.php
index fa2420c5f8f..3bab67ba796 100644
--- a/tests/php/ORM/DBTimeTest.php
+++ b/tests/php/ORM/DBTimeTest.php
@@ -48,12 +48,12 @@ public function testParse($input, $expected)
public function testNice()
{
$time = DBTime::create_field('Time', '17:15:55');
- $this->assertMatchesRegularExpression('#5:15:55 PM#i', $time->Nice());
+ $this->assertMatchesRegularExpression('#5:15:55\hPM#iu', $time->Nice());
}
public function testShort()
{
$time = DBTime::create_field('Time', '17:15:55');
- $this->assertMatchesRegularExpression('#5:15 PM#i', $time->Short());
+ $this->assertMatchesRegularExpression('#5:15\hPM#iu', $time->Short());
}
}