mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-08 13:51:02 +01:00
e11adc4ad7
Summary: There are quite a few tests in Arcanist, libphutil and Phabricator that do something similar to `$this->assertEqual(false, ...)` or `$this->assertEqual(true, ...)`. This is unnecessarily verbose and it would be cleaner if we had `assertFalse` and `assertTrue` methods. Test Plan: I contemplated adding a unit test for the `getCallerInfo` method but wasn't sure if it was required / where it should live. Reviewers: epriestley, #blessed_reviewers Reviewed By: epriestley CC: Korvin, epriestley, aran Differential Revision: https://secure.phabricator.com/D8460
102 lines
2.9 KiB
PHP
102 lines
2.9 KiB
PHP
<?php
|
|
|
|
final class PhabricatorInfrastructureTestCase
|
|
extends PhabricatorTestCase {
|
|
|
|
protected function getPhabricatorTestCaseConfiguration() {
|
|
return array(
|
|
self::PHABRICATOR_TESTCONFIG_BUILD_STORAGE_FIXTURES => true,
|
|
);
|
|
}
|
|
|
|
/**
|
|
* This is more of an acceptance test case instead of a unittest. It verifies
|
|
* that all symbols can be loaded correctly. It can catch problems like
|
|
* missing methods in descendants of abstract base classes.
|
|
*/
|
|
public function testEverythingImplemented() {
|
|
id(new PhutilSymbolLoader())->selectAndLoadSymbols();
|
|
$this->assertTrue(true);
|
|
}
|
|
|
|
public function testApplicationsInstalled() {
|
|
$all = PhabricatorApplication::getAllApplications();
|
|
$installed = PhabricatorApplication::getAllInstalledApplications();
|
|
|
|
$this->assertEqual(
|
|
count($all),
|
|
count($installed),
|
|
'In test cases, all applications should default to installed.');
|
|
}
|
|
|
|
public function testMySQLAgreesWithUsAboutBMP() {
|
|
// Build a string with every BMP character in it, then insert it into MySQL
|
|
// and read it back. We expect to get the same string out that we put in,
|
|
// demonstrating that strings which pass our BMP checks are also valid in
|
|
// MySQL and no silent data truncation will occur.
|
|
|
|
$buf = '';
|
|
|
|
for ($ii = 0x01; $ii <= 0x7F; $ii++) {
|
|
$buf .= chr($ii);
|
|
}
|
|
|
|
for ($ii = 0xC2; $ii <= 0xDF; $ii++) {
|
|
for ($jj = 0x80; $jj <= 0xBF; $jj++) {
|
|
$buf .= chr($ii).chr($jj);
|
|
}
|
|
}
|
|
|
|
// NOTE: This is \xE0\xA0\xZZ.
|
|
for ($ii = 0xE0; $ii <= 0xE0; $ii++) {
|
|
for ($jj = 0xA0; $jj <= 0xBF; $jj++) {
|
|
for ($kk = 0x80; $kk <= 0xBF; $kk++) {
|
|
$buf .= chr($ii).chr($jj).chr($kk);
|
|
}
|
|
}
|
|
}
|
|
|
|
// NOTE: This is \xE1\xZZ\xZZ through \xEF\xZZ\xZZ.
|
|
for ($ii = 0xE1; $ii <= 0xEF; $ii++) {
|
|
for ($jj = 0x80; $jj <= 0xBF; $jj++) {
|
|
for ($kk = 0x80; $kk <= 0xBF; $kk++) {
|
|
$buf .= chr($ii).chr($jj).chr($kk);
|
|
}
|
|
}
|
|
}
|
|
|
|
$this->assertEqual(194431, strlen($buf));
|
|
$this->assertTrue(phutil_is_utf8_with_only_bmp_characters($buf));
|
|
|
|
$write = id(new HarbormasterScratchTable())
|
|
->setData('all.utf8.bmp')
|
|
->setBigData($buf)
|
|
->save();
|
|
|
|
$read = id(new HarbormasterScratchTable())->load($write->getID());
|
|
|
|
$this->assertEqual($buf, $read->getBigData());
|
|
}
|
|
|
|
public function testRejectMySQLBMPQueries() {
|
|
$table = new HarbormasterScratchTable();
|
|
$conn_r = $table->establishConnection('w');
|
|
|
|
$snowman = "\xE2\x98\x83";
|
|
$gclef = "\xF0\x9D\x84\x9E";
|
|
|
|
qsprintf($conn_r, 'SELECT %B', $snowman);
|
|
qsprintf($conn_r, 'SELECT %s', $snowman);
|
|
qsprintf($conn_r, 'SELECT %B', $gclef);
|
|
|
|
$caught = null;
|
|
try {
|
|
qsprintf($conn_r, 'SELECT %s', $gclef);
|
|
} catch (AphrontQueryCharacterSetException $ex) {
|
|
$caught = $ex;
|
|
}
|
|
|
|
$this->assertTrue($caught instanceof AphrontQueryCharacterSetException);
|
|
}
|
|
|
|
}
|