if (false == $dir) die('skip no driver');
require_once $dir . 'pdo_test.inc';
PDOTest::skip();
-/* TODO:
+
$db = PDOTest::factory();
try {
$db->beginTransaction();
} catch (PDOException $e) {
- # check sqlstate to see if transactions
- # are not implemented; if so, skip
+ die('skip no working transactions: ' . $e->getMessage());
+}
+
+if ($db->getAttribute(PDO_ATTR_DRIVER_NAME) == 'mysql') {
+ if (false === PDOTest::detect_transactional_mysql_engine($db)) {
+ die('skip your mysql configuration does not support working transactions');
+ }
}
-*/
?>
--FILE--
<?php
$db = PDOTest::factory();
if ($db->getAttribute(PDO_ATTR_DRIVER_NAME) == 'mysql') {
- $suf = ' Type=InnoDB';
+ $suf = ' Type=' . PDOTest::detect_transactional_mysql_engine($db);
} else {
$suf = '';
}
die("skip " . $e->getMessage());
}
}
+
+ static function detect_transactional_mysql_engine($db) {
+ foreach ($db->query('show engines') as $row) {
+ if ($row[1] == 'YES' && ($row[0] == 'INNOBASE' || $row[0] == 'BDB')) {
+ return $row[0];
+ }
+ }
+ return false;
+ }
}