2011-10-19 18:26:21 -07:00
|
|
|
<?php
|
|
|
|
|
|
|
|
final class PhabricatorInfrastructureTestCase
|
|
|
|
extends PhabricatorTestCase {
|
|
|
|
|
2014-02-23 16:20:38 -08:00
|
|
|
protected function getPhabricatorTestCaseConfiguration() {
|
|
|
|
return array(
|
|
|
|
self::PHABRICATOR_TESTCONFIG_BUILD_STORAGE_FIXTURES => true,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2011-10-19 18:26:21 -07:00
|
|
|
/**
|
|
|
|
* This is more of an acceptance test case instead of a unittest. It verifies
|
2013-05-16 12:25:26 -07:00
|
|
|
* that all symbols can be loaded correctly. It can catch problems like
|
|
|
|
* missing methods in descendants of abstract base classes.
|
2011-10-19 18:26:21 -07:00
|
|
|
*/
|
|
|
|
public function testEverythingImplemented() {
|
2013-05-16 12:25:26 -07:00
|
|
|
id(new PhutilSymbolLoader())->selectAndLoadSymbols();
|
2014-03-07 10:02:46 -08:00
|
|
|
$this->assertEqual(true, true);
|
2011-10-19 18:26:21 -07:00
|
|
|
}
|
2013-05-16 12:25:26 -07:00
|
|
|
|
|
|
|
public function testApplicationsInstalled() {
|
|
|
|
$all = PhabricatorApplication::getAllApplications();
|
|
|
|
$installed = PhabricatorApplication::getAllInstalledApplications();
|
|
|
|
|
|
|
|
$this->assertEqual(
|
|
|
|
count($all),
|
|
|
|
count($installed),
|
|
|
|
'In test cases, all applications should default to installed.');
|
|
|
|
}
|
|
|
|
|
2014-02-23 16:20:38 -08:00
|
|
|
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->assertEqual(true, 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());
|
|
|
|
}
|
2013-05-16 12:25:26 -07:00
|
|
|
|
2014-02-23 16:20:46 -08:00
|
|
|
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->assertEqual(
|
|
|
|
true,
|
|
|
|
($caught instanceof AphrontQueryCharacterSetException));
|
|
|
|
}
|
|
|
|
|
2011-10-19 18:26:21 -07:00
|
|
|
}
|