Compare commits

...

5 Commits

Author SHA1 Message Date
Sunny Side Up
cd27d5b68f
Merge 4a6a3d19af62708450dfcb8944d6ea72f2e1b4f2 into 483e944601b140cc891633048ba526037b6d3808 2024-10-02 05:30:34 +13:00
github-actions
483e944601 Merge branch '5.3' into 5 2024-09-30 20:34:55 +00:00
github-actions
d7fa53139f Merge branch '5.2' into 5.3 2024-09-30 20:34:54 +00:00
Guy Sartorelli
862a65eacc
MNT Fix unit tests (#11409) 2024-09-30 18:32:17 +13:00
Sunny Side Up
4a6a3d19af
MINOR: adding SpelledOut method in DBInt 2023-12-18 16:28:44 +13:00
6 changed files with 45 additions and 35 deletions

View File

@ -64,7 +64,13 @@ class DBInt extends DBField
{ {
return sprintf('%d', $this->value); return sprintf('%d', $this->value);
} }
public function SpelledOut()
{
$v = $this->prepValueForDB($this->value);
return (new NumberFormatter(i18n::get_locale(), NumberFormatter::SPELLOUT))->format($v);
}
public function scaffoldFormField($title = null, $params = null) public function scaffoldFormField($title = null, $params = null)
{ {
return NumericField::create($this->name, $title); return NumericField::create($this->name, $title);

View File

@ -12,7 +12,8 @@ class DateFieldDisabledTest extends SapphireTest
protected function setUp(): void protected function setUp(): void
{ {
parent::setUp(); 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'); DBDatetime::set_mock_now('2011-02-01 8:34:00');
} }
@ -22,7 +23,7 @@ class DateFieldDisabledTest extends SapphireTest
$actual = DateField_Disabled::create('Test') $actual = DateField_Disabled::create('Test')
->setValue('2011-02-01') ->setValue('2011-02-01')
->Field(); ->Field();
$expected = '<span class="readonly" id="Test">1/02/2011 (today)</span>'; $expected = '<span class="readonly" id="Test">Feb 1, 2011 (today)</span>';
$this->assertEquals($expected, $actual); $this->assertEquals($expected, $actual);
// Test today's date with time // Test today's date with time
@ -38,14 +39,14 @@ class DateFieldDisabledTest extends SapphireTest
$actual = DateField_Disabled::create('Test') $actual = DateField_Disabled::create('Test')
->setValue('2011-01-27') ->setValue('2011-01-27')
->Field(); ->Field();
$expected = '<span class="readonly" id="Test">27/01/2011, 5 days ago</span>'; $expected = '<span class="readonly" id="Test">Jan 27, 2011, 5 days ago</span>';
$this->assertEquals($expected, $actual); $this->assertEquals($expected, $actual);
// Test future // Test future
$actual = DateField_Disabled::create('Test') $actual = DateField_Disabled::create('Test')
->setValue('2011-02-06') ->setValue('2011-02-06')
->Field(); ->Field();
$expected = '<span class="readonly" id="Test">6/02/2011, in 5 days</span>'; $expected = '<span class="readonly" id="Test">Feb 6, 2011, in 5 days</span>';
$this->assertEquals($expected, $actual); $this->assertEquals($expected, $actual);
} }

View File

@ -21,7 +21,8 @@ class DatetimeFieldTest extends SapphireTest
protected function setUp(): void protected function setUp(): void
{ {
parent::setUp(); 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 // Fix now to prevent race conditions
DBDatetime::set_mock_now('2010-04-04'); DBDatetime::set_mock_now('2010-04-04');
$this->timezone = date_default_timezone_get(); $this->timezone = date_default_timezone_get();
@ -141,14 +142,14 @@ class DatetimeFieldTest extends SapphireTest
$datetimeField $datetimeField
->setHTML5(false) ->setHTML5(false)
->setLocale('en_NZ'); ->setLocale('de_DE');
$datetimeField->setSubmittedValue('29/03/2003 11:00:00 pm'); $datetimeField->setSubmittedValue('29/03/2003 23:00:00');
$this->assertEquals($datetimeField->dataValue(), '2003-03-29 23:00:00'); $this->assertEquals('2003-03-29 23:00:00', $datetimeField->dataValue());
// Some localisation packages exclude the ',' in default medium format // Some localisation packages exclude the ',' in default medium format
$this->assertMatchesRegularExpression( $this->assertMatchesRegularExpression(
'#29/03/2003(,)? 11:00:00 (PM|pm)#', '#29.03.2003(,)? 23:00:00#',
$datetimeField->Value(), $datetimeField->Value(),
'User value is formatted, and in user timezone' 'User value is formatted, and in user timezone'
); );

View File

@ -20,7 +20,8 @@ class DBDateTest extends SapphireTest
$this->oldError = error_reporting(); $this->oldError = error_reporting();
// Validate setup // Validate setup
assert(date_default_timezone_get() === 'UTC'); 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 protected function tearDown(): void
@ -48,42 +49,42 @@ class DBDateTest extends SapphireTest
public function testNiceDate() public function testNiceDate()
{ {
$this->assertEquals( $this->assertEquals(
'31/03/2008', 'Mar 31, 2008',
DBField::create_field('Date', 1206968400)->Nice(), DBField::create_field('Date', 1206968400)->Nice(),
"Date->Nice() works with timestamp integers" "Date->Nice() works with timestamp integers"
); );
$this->assertEquals( $this->assertEquals(
'30/03/2008', 'Mar 30, 2008',
DBField::create_field('Date', 1206882000)->Nice(), DBField::create_field('Date', 1206882000)->Nice(),
"Date->Nice() works with timestamp integers" "Date->Nice() works with timestamp integers"
); );
$this->assertEquals( $this->assertEquals(
'31/03/2008', 'Mar 31, 2008',
DBField::create_field('Date', '1206968400')->Nice(), DBField::create_field('Date', '1206968400')->Nice(),
"Date->Nice() works with timestamp strings" "Date->Nice() works with timestamp strings"
); );
$this->assertEquals( $this->assertEquals(
'30/03/2008', 'Mar 30, 2008',
DBField::create_field('Date', '1206882000')->Nice(), DBField::create_field('Date', '1206882000')->Nice(),
"Date->Nice() works with timestamp strings" "Date->Nice() works with timestamp strings"
); );
$this->assertEquals( $this->assertEquals(
'4/03/2003', 'Mar 4, 2003',
DBField::create_field('Date', '4.3.2003')->Nice(), DBField::create_field('Date', '4.3.2003')->Nice(),
"Date->Nice() works with D.M.YYYY format" "Date->Nice() works with D.M.YYYY format"
); );
$this->assertEquals( $this->assertEquals(
'4/03/2003', 'Mar 4, 2003',
DBField::create_field('Date', '04.03.2003')->Nice(), DBField::create_field('Date', '04.03.2003')->Nice(),
"Date->Nice() works with DD.MM.YYYY format" "Date->Nice() works with DD.MM.YYYY format"
); );
$this->assertEquals( $this->assertEquals(
'4/03/2003', 'Mar 4, 2003',
DBField::create_field('Date', '2003-3-4')->Nice(), DBField::create_field('Date', '2003-3-4')->Nice(),
"Date->Nice() works with YYYY-M-D format" "Date->Nice() works with YYYY-M-D format"
); );
$this->assertEquals( $this->assertEquals(
'4/03/2003', 'Mar 4, 2003',
DBField::create_field('Date', '2003-03-04')->Nice(), DBField::create_field('Date', '2003-03-04')->Nice(),
"Date->Nice() works with YYYY-MM-DD format" "Date->Nice() works with YYYY-MM-DD format"
); );
@ -107,7 +108,7 @@ class DBDateTest extends SapphireTest
{ {
// iso8601 expects year first, but support year last // iso8601 expects year first, but support year last
$this->assertEquals( $this->assertEquals(
'4/03/2003', 'Mar 4, 2003',
DBField::create_field('Date', '04-03-2003')->Nice(), DBField::create_field('Date', '04-03-2003')->Nice(),
"Date->Nice() works with DD-MM-YYYY format" "Date->Nice() works with DD-MM-YYYY format"
); );
@ -152,32 +153,32 @@ class DBDateTest extends SapphireTest
public function testLongDate() public function testLongDate()
{ {
$this->assertEquals( $this->assertEquals(
'31 March 2008', 'March 31, 2008',
DBField::create_field('Date', 1206968400)->Long(), DBField::create_field('Date', 1206968400)->Long(),
"Date->Long() works with numeric timestamp" "Date->Long() works with numeric timestamp"
); );
$this->assertEquals( $this->assertEquals(
'31 March 2008', 'March 31, 2008',
DBField::create_field('Date', '1206968400')->Long(), DBField::create_field('Date', '1206968400')->Long(),
"Date->Long() works with string timestamp" "Date->Long() works with string timestamp"
); );
$this->assertEquals( $this->assertEquals(
'30 March 2008', 'March 30, 2008',
DBField::create_field('Date', 1206882000)->Long(), DBField::create_field('Date', 1206882000)->Long(),
"Date->Long() works with numeric timestamp" "Date->Long() works with numeric timestamp"
); );
$this->assertEquals( $this->assertEquals(
'30 March 2008', 'March 30, 2008',
DBField::create_field('Date', '1206882000')->Long(), DBField::create_field('Date', '1206882000')->Long(),
"Date->Long() works with numeric timestamp" "Date->Long() works with numeric timestamp"
); );
$this->assertEquals( $this->assertEquals(
'3 April 2003', 'April 3, 2003',
DBField::create_field('Date', '2003-4-3')->Long(), DBField::create_field('Date', '2003-4-3')->Long(),
"Date->Long() works with YYYY-M-D" "Date->Long() works with YYYY-M-D"
); );
$this->assertEquals( $this->assertEquals(
'3 April 2003', 'April 3, 2003',
DBField::create_field('Date', '3.4.2003')->Long(), DBField::create_field('Date', '3.4.2003')->Long(),
"Date->Long() works with D.M.YYYY" "Date->Long() works with D.M.YYYY"
); );
@ -186,7 +187,7 @@ class DBDateTest extends SapphireTest
public function testFull() public function testFull()
{ {
$this->assertEquals( $this->assertEquals(
'Monday, 31 March 2008', 'Monday, March 31, 2008',
DBField::create_field('Date', 1206968400)->Full(), DBField::create_field('Date', 1206968400)->Full(),
"Date->Full() works with timestamp integers" "Date->Full() works with timestamp integers"
); );

View File

@ -14,7 +14,8 @@ class DBDatetimeTest extends SapphireTest
protected function setUp(): void protected function setUp(): void
{ {
parent::setUp(); 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() public function testNowWithSystemDate()
@ -126,23 +127,23 @@ class DBDatetimeTest extends SapphireTest
$date = DBDatetime::create_field('Datetime', '2001-12-11 22:10:59'); $date = DBDatetime::create_field('Datetime', '2001-12-11 22:10:59');
// note: Some localisation packages exclude the ',' in default medium format // note: Some localisation packages exclude the ',' in default medium format
i18n::set_locale('en_NZ'); i18n::set_locale('de_DE');
$this->assertMatchesRegularExpression('#11/12/2001(,)? 10:10 PM#i', $date->Nice()); $this->assertMatchesRegularExpression('#11.12.2001(,)? 22:10#i', $date->Nice());
i18n::set_locale('en_US'); 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() public function testDate()
{ {
$date = DBDatetime::create_field('Datetime', '2001-12-31 22:10:59'); $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() public function testTime()
{ {
$date = DBDatetime::create_field('Datetime', '2001-12-31 22:10:59'); $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() public function testTime24()

View File

@ -48,12 +48,12 @@ class DBTimeTest extends SapphireTest
public function testNice() public function testNice()
{ {
$time = DBTime::create_field('Time', '17:15:55'); $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() public function testShort()
{ {
$time = DBTime::create_field('Time', '17:15:55'); $time = DBTime::create_field('Time', '17:15:55');
$this->assertMatchesRegularExpression('#5:15 PM#i', $time->Short()); $this->assertMatchesRegularExpression('#5:15\hPM#iu', $time->Short());
} }
} }