Skip to content
Snippets Groups Projects
Commit 13251a46 authored by Vitaliy Goncharenko's avatar Vitaliy Goncharenko
Browse files

MAGETWO-60201: Test UnsecureFunctionsUsageTest fails in case of changes in files with unsecure code

parent 81c6cce2
No related merge requests found
...@@ -3,6 +3,7 @@ ...@@ -3,6 +3,7 @@
* Copyright © 2016 Magento. All rights reserved. * Copyright © 2016 Magento. All rights reserved.
* See COPYING.txt for license details. * See COPYING.txt for license details.
*/ */
namespace Magento\TestFramework\Utility; namespace Magento\TestFramework\Utility;
use Magento\Framework\App\Utility\Files; use Magento\Framework\App\Utility\Files;
...@@ -15,6 +16,11 @@ use Magento\TestFramework\Utility\File\RegexIteratorFactory; ...@@ -15,6 +16,11 @@ use Magento\TestFramework\Utility\File\RegexIteratorFactory;
*/ */
class ChangedFiles class ChangedFiles
{ {
/**
* File path with changed files content.
*/
const CHANGED_FILES_CONTENT_FILE = '/dev/tests/static/testsuite/Magento/Test/_files/changed_%s_files_content.json';
/** /**
* Returns array of PHP-files, that use or declare Magento application classes and Magento libs * Returns array of PHP-files, that use or declare Magento application classes and Magento libs
* *
...@@ -45,4 +51,32 @@ class ChangedFiles ...@@ -45,4 +51,32 @@ class ChangedFiles
return $phpFiles; return $phpFiles;
} }
/**
* Get changed content.
*
* @param string $fileName
* @return string|null
*/
public static function getChangedContent($fileName)
{
$extension = self::getFileExtension($fileName);
$fileName = ltrim(str_replace(BP, '', $fileName), DIRECTORY_SEPARATOR);
$changedContent = file_get_contents(BP . sprintf(self::CHANGED_FILES_CONTENT_FILE, $extension));
$data = json_decode($changedContent, true);
return isset($data[$fileName]) ? $data[$fileName] : [];
}
/**
* Get file extension.
*
* @param string $fileName
* @return string
*/
public static function getFileExtension($fileName)
{
$fileInfo = pathinfo($fileName);
return isset($fileInfo['extension']) ? $fileInfo['extension'] : 'unknown';
}
} }
...@@ -35,16 +35,20 @@ class FunctionDetector ...@@ -35,16 +35,20 @@ class FunctionDetector
{ {
$result = []; $result = [];
$regexp = $this->composeRegexp($functions); $regexp = $this->composeRegexp($functions);
if ($regexp) { if ($regexp) {
$fileContent = \Magento\TestFramework\Utility\ChangedFiles::getChangedContent($filePath);
$matches = preg_grep($regexp, explode("\n", $fileContent));
$file = file($filePath); $file = file($filePath);
array_unshift($file, ''); if (!empty($matches)) {
$lines = preg_grep( foreach ($matches as $line) {
$regexp, $actualFunctions = [];
$file foreach ($functions as $function) {
); if (false !== strpos($line, $function)) {
foreach ($lines as $lineNumber => $line) { $actualFunctions[] = $function;
if (preg_match_all($regexp, $line, $matches)) { }
$result[$lineNumber] = $matches[1]; }
$result[array_search($line . "\n", $file) + 1] = $actualFunctions;
} }
} }
} }
......
...@@ -34,6 +34,8 @@ if (!validateInput($options, $requiredOptions)) { ...@@ -34,6 +34,8 @@ if (!validateInput($options, $requiredOptions)) {
$fileExtensions = explode(',', isset($options['file-extensions']) ? $options['file-extensions'] : 'php'); $fileExtensions = explode(',', isset($options['file-extensions']) ? $options['file-extensions'] : 'php');
include_once __DIR__ . '/framework/autoload.php';
$mainline = 'mainline_' . (string)rand(0, 9999); $mainline = 'mainline_' . (string)rand(0, 9999);
$repo = getRepo($options, $mainline); $repo = getRepo($options, $mainline);
$branches = $repo->getBranches('--remotes'); $branches = $repo->getBranches('--remotes');
...@@ -41,8 +43,23 @@ generateBranchesList($options['output-file'], $branches, $options['branch']); ...@@ -41,8 +43,23 @@ generateBranchesList($options['output-file'], $branches, $options['branch']);
$changes = retrieveChangesAcrossForks($mainline, $repo, $options['branch']); $changes = retrieveChangesAcrossForks($mainline, $repo, $options['branch']);
$changedFiles = getChangedFiles($changes, $fileExtensions); $changedFiles = getChangedFiles($changes, $fileExtensions);
generateChangedFilesList($options['output-file'], $changedFiles); generateChangedFilesList($options['output-file'], $changedFiles);
saveChangedFileContent($repo);
cleanup($repo, $mainline); cleanup($repo, $mainline);
/**
* Save changed file content.
*
* @param GitRepo $repo
* @return void
*/
function saveChangedFileContent(GitRepo $repo)
{
$changedFilesContentFileName = BP . Magento\TestFramework\Utility\ChangedFiles::CHANGED_FILES_CONTENT_FILE;
foreach ($repo->getChangedContentFiles() as $key => $changedContentFile) {
file_put_contents(sprintf($changedFilesContentFileName, $key), json_encode($changedContentFile), FILE_APPEND);
}
}
/** /**
* Generates a file containing changed files * Generates a file containing changed files
* *
...@@ -170,6 +187,18 @@ class GitRepo ...@@ -170,6 +187,18 @@ class GitRepo
*/ */
private $remoteList = []; private $remoteList = [];
/**
* Array of changed content files.
*
* Example:
* 'extension' =>
* 'path_to_file/filename' => 'Content that was edited',
* 'path_to_file/filename2' => 'Content that was edited',
*
* @var array
*/
private $changedContentFiles = [];
/** /**
* @param string $workTree absolute path to git project * @param string $workTree absolute path to git project
*/ */
...@@ -285,6 +314,9 @@ class GitRepo ...@@ -285,6 +314,9 @@ class GitRepo
'diff HEAD %s/%s -- %s', $remoteAlias, $remoteBranch, $this->workTree . '/' . $fileName) 'diff HEAD %s/%s -- %s', $remoteAlias, $remoteBranch, $this->workTree . '/' . $fileName)
); );
if ($result) { if ($result) {
if (!(isset($this->changedContentFiles[$fileName]))) {
$this->setChangedContentFile($result, $fileName);
}
$filteredChanges[] = $fileName; $filteredChanges[] = $fileName;
} }
} }
...@@ -295,6 +327,38 @@ class GitRepo ...@@ -295,6 +327,38 @@ class GitRepo
return $filteredChanges; return $filteredChanges;
} }
/**
* Set changed content for file.
*
* @param array $content
* @param string $fileName
* @return void
*/
private function setChangedContentFile(array $content, $fileName)
{
$changedContent = '';
$extension = Magento\TestFramework\Utility\ChangedFiles::getFileExtension($fileName);
foreach ($content as $item) {
if (strpos($item, '---') !== 0 && strpos($item, '-') === 0 && $line = ltrim($item, '-')) {
$changedContent .= $line . "\n";
}
}
if ($changedContent !== '') {
$this->changedContentFiles[$extension][$fileName] = $changedContent;
}
}
/**
* Get changed content files collection.
*
* @return array
*/
public function getChangedContentFiles()
{
return $this->changedContentFiles;
}
/** /**
* Makes call ro git cli * Makes call ro git cli
* *
......
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment