本文整理匯總了PHP中PHPUnit_Util_CodeCoverage::getCoveringTests方法的典型用法代碼示例。如果您正苦於以下問題:PHP PHPUnit_Util_CodeCoverage::getCoveringTests方法的具體用法?PHP PHPUnit_Util_CodeCoverage::getCoveringTests怎麽用?PHP PHPUnit_Util_CodeCoverage::getCoveringTests使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類PHPUnit_Util_CodeCoverage
的用法示例。
在下文中一共展示了PHPUnit_Util_CodeCoverage::getCoveringTests方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: storeCodeCoverage
/**
* Stores code coverage information.
*
* @param PHPUnit_Framework_TestResult $result
* @param integer $revision
* @access public
*/
public function storeCodeCoverage(PHPUnit_Framework_TestResult $result, $revision)
{
$codeCoverage = $result->getCodeCoverageInformation(FALSE, TRUE);
$summary = PHPUnit_Util_CodeCoverage::getSummary($codeCoverage);
$files = array_keys($summary);
$commonPath = PHPUnit_Util_Filesystem::getCommonPath($files);
$this->dbh->beginTransaction();
foreach ($files as $file) {
$filename = str_replace($commonPath, '', $file);
$fileId = FALSE;
$lines = file($file);
$numLines = count($lines);
$stmt = $this->dbh->query(sprintf('SELECT code_file_id
FROM code_file
WHERE code_file_name = "%s"
AND revision = %d;', $filename, $revision));
if ($stmt) {
$fileId = (int) $stmt->fetchColumn();
}
unset($stmt);
if ($fileId == 0) {
$this->dbh->exec(sprintf('INSERT INTO code_file
(code_file_name, code_file_md5, revision)
VALUES("%s", "%s", %d);', $filename, md5_file($file), $revision));
$fileId = $this->dbh->lastInsertId();
$classes = PHPUnit_Util_Class::getClassesInFile($file, $commonPath);
foreach ($classes as $class) {
$this->dbh->exec(sprintf('INSERT INTO code_class
(code_file_id, code_class_name,
code_class_start_line, code_class_end_line)
VALUES(%d, "%s", %d, %d);', $fileId, $class->getName(), $class->getStartLine(), $class->getEndLine()));
$classId = $this->dbh->lastInsertId();
foreach ($class->getMethods() as $method) {
if ($class->getName() != $method->getDeclaringClass()->getName()) {
continue;
}
$this->dbh->exec(sprintf('INSERT INTO code_method
(code_class_id, code_method_name,
code_method_start_line, code_method_end_line)
VALUES(%d, "%s", %d, %d);', $classId, $method->getName(), $method->getStartLine(), $method->getEndLine()));
}
}
$i = 1;
foreach ($lines as $line) {
$this->dbh->exec(sprintf('INSERT INTO code_line
(code_file_id, code_line_number, code_line,
code_line_covered)
VALUES(%d, %d, "%s", %d);', $fileId, $i, trim($line), isset($summary[$file][$i]) ? $summary[$file][$i] : 0));
$i++;
}
}
for ($lineNumber = 1; $lineNumber <= $numLines; $lineNumber++) {
$coveringTests = PHPUnit_Util_CodeCoverage::getCoveringTests($codeCoverage, $file, $lineNumber);
if (is_array($coveringTests)) {
$stmt = $this->dbh->query(sprintf('SELECT code_line_id, code_line_covered
FROM code_line
WHERE code_file_id = %d
AND code_line_number = %d;', $fileId, $lineNumber));
$codeLineId = (int) $stmt->fetchColumn(0);
$oldCoverageFlag = (int) $stmt->fetchColumn(1);
unset($stmt);
$newCoverageFlag = $summary[$file][$lineNumber];
if ($oldCoverageFlag == 0 && $newCoverageFlag != 0 || $oldCoverageFlag < 0 && $newCoverageFlag > 0) {
$this->dbh->exec(sprintf('UPDATE code_line
SET code_line_covered = %d
WHERE code_line_id = %d;', $newCoverageFlag, $codeLineId));
}
foreach ($coveringTests as $test) {
$this->dbh->exec(sprintf('INSERT INTO code_coverage
(test_id, code_line_id)
VALUES(%d, %d);', $test->__db_id, $codeLineId));
}
}
}
}
foreach ($result->topTestSuite() as $test) {
if ($test instanceof PHPUnit_Framework_TestCase) {
$stmt = $this->dbh->query(sprintf('SELECT code_method.code_method_id
FROM code_class, code_method
WHERE code_class.code_class_id = code_method.code_class_id
AND code_class.code_class_name = "%s"
AND code_method.code_method_name = "%s";', get_class($test), $test->getName()));
$methodId = (int) $stmt->fetchColumn();
unset($stmt);
$this->dbh->exec(sprintf('UPDATE test
SET code_method_id = %d
WHERE test_id = %d;', $methodId, $test->__db_id));
}
}
$this->dbh->commit();
}
示例2: storeCodeCoverage
//.........這裏部分代碼省略.........
$methodLocExecuted = $methodMetrics->getLocExecuted();
$methodCcn = $methodMetrics->getCCN();
$methodCrap = $methodMetrics->getCrapIndex();
$methodNpath = $methodMetrics->getNPath();
$stmtInsertMethod->bindParam(':runId', $runId, PDO::PARAM_INT);
$stmtInsertMethod->bindParam(':methodId', $methodId, PDO::PARAM_INT);
$stmtInsertMethod->bindParam(':coverage', $methodCoverage);
$stmtInsertMethod->bindParam(':loc', $methodLoc, PDO::PARAM_INT);
$stmtInsertMethod->bindParam(':locExecutable', $methodLocExecutable, PDO::PARAM_INT);
$stmtInsertMethod->bindParam(':locExecuted', $methodLocExecuted, PDO::PARAM_INT);
$stmtInsertMethod->bindParam(':ccn', $methodCcn, PDO::PARAM_INT);
$stmtInsertMethod->bindParam(':crap', $methodCrap);
$stmtInsertMethod->bindParam(':npath', $methodNpath, PDO::PARAM_INT);
$stmtInsertMethod->execute();
}
}
unset($stmtSelectFunctionId);
unset($stmtInsertFunction);
unset($stmtSelectClassId);
unset($stmtInsertClass);
unset($stmtSelectMethodId);
unset($stmtInsertMethod);
$stmt = $this->dbh->prepare('SELECT code_line_id, code_line_covered
FROM code_line
WHERE code_file_id = :fileId
AND code_line_number = :lineNumber;');
$stmt2 = $this->dbh->prepare('UPDATE code_line
SET code_line_covered = :lineCovered
WHERE code_line_id = :lineId;');
$stmt3 = $this->dbh->prepare('INSERT INTO code_coverage
(test_id, code_line_id)
VALUES(:testId, :lineId);');
for ($lineNumber = 1; $lineNumber <= $fileLoc; $lineNumber++) {
$coveringTests = PHPUnit_Util_CodeCoverage::getCoveringTests($codeCoverage, $fileName, $lineNumber);
if (is_array($coveringTests)) {
$stmt->bindParam(':fileId', $fileId, PDO::PARAM_INT);
$stmt->bindParam(':lineNumber', $lineNumber, PDO::PARAM_INT);
$stmt->execute();
$codeLineId = (int) $stmt->fetchColumn(0);
$oldCoverageFlag = (int) $stmt->fetchColumn(1);
$newCoverageFlag = isset($summary[$fileName][$lineNumber]) ? 1 : 0;
if ($oldCoverageFlag == 0 && $newCoverageFlag != 0 || $oldCoverageFlag < 0 && $newCoverageFlag > 0) {
$stmt2->bindParam(':lineCovered', $newCoverageFlag, PDO::PARAM_INT);
$stmt2->bindParam(':lineId', $codeLineId, PDO::PARAM_INT);
$stmt2->execute();
}
foreach ($coveringTests as $test) {
$stmt3->bindParam(':testId', $test->__db_id, PDO::PARAM_INT);
$stmt3->bindParam(':lineId', $codeLineId, PDO::PARAM_INT);
$stmt3->execute();
}
}
}
}
unset($stmt);
unset($stmt2);
unset($stmt3);
$stmt = $this->dbh->prepare('SELECT code_method.code_method_id
FROM code_class, code_method
WHERE code_class.code_class_id = code_method.code_class_id
AND code_class.code_class_name = :className
AND code_method.code_method_name = :methodName;');
$stmt2 = $this->dbh->prepare('UPDATE test
SET code_method_id = :methodId
WHERE test_id = :testId;');
foreach ($result->topTestSuite() as $test) {