mirror of
https://github.com/joomla-extensions/patchtester.git
synced 2025-01-25 16:18:26 +00:00
First attempt to move the patch_chain.json to database.
This commit is contained in:
parent
3b1f1578da
commit
26b5399df6
@ -13,7 +13,6 @@ use Joomla\CMS\Filesystem\Folder;
|
|||||||
use Joomla\CMS\Language\Text;
|
use Joomla\CMS\Language\Text;
|
||||||
use Joomla\CMS\Router\Route;
|
use Joomla\CMS\Router\Route;
|
||||||
use Joomla\Filesystem\File;
|
use Joomla\Filesystem\File;
|
||||||
use PatchTester\Helper;
|
|
||||||
use PatchTester\Model\PullModel;
|
use PatchTester\Model\PullModel;
|
||||||
use PatchTester\Model\PullsModel;
|
use PatchTester\Model\PullsModel;
|
||||||
use PatchTester\Model\TestsModel;
|
use PatchTester\Model\TestsModel;
|
||||||
@ -42,25 +41,10 @@ class ResetController extends AbstractController
|
|||||||
$pullsModel = new PullsModel($this->context, null, Factory::getDbo());
|
$pullsModel = new PullsModel($this->context, null, Factory::getDbo());
|
||||||
$testsModel = new TestsModel(null, Factory::getDbo());
|
$testsModel = new TestsModel(null, Factory::getDbo());
|
||||||
|
|
||||||
// Get the CIServer Registry
|
|
||||||
$ciSettings = Helper::initializeCISettings();
|
|
||||||
|
|
||||||
// Get PatchChain as array, remove any EOL set by php
|
|
||||||
$patchChainPath = $ciSettings->get('folder.backups') . '/' . $ciSettings->get('zip.chain.name');
|
|
||||||
$patchChain = array_reverse(json_decode(file_get_contents($patchChainPath)));
|
|
||||||
|
|
||||||
// Check the applied patches in the database first
|
// Check the applied patches in the database first
|
||||||
$appliedPatches = $testsModel->getAppliedPatches();
|
$appliedPatches = $pullModel->getPatchesDividedInProcs();
|
||||||
|
|
||||||
if (count($patchChain) && count($appliedPatches))
|
if (count($appliedPatches[0]))
|
||||||
{
|
|
||||||
// Get only the pull_id and remove all occurrences with patchChain
|
|
||||||
$appliedPatches = array_map(function($patch) { return $patch->id; }, $appliedPatches);
|
|
||||||
$patchChain = array_map(function($patch) { return $patch->id; }, $patchChain);
|
|
||||||
$appliedPatches = array_diff($appliedPatches, $patchChain);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (count($appliedPatches))
|
|
||||||
{
|
{
|
||||||
$revertErrored = false;
|
$revertErrored = false;
|
||||||
|
|
||||||
@ -69,7 +53,7 @@ class ResetController extends AbstractController
|
|||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
$pullModel->revertWithGitHub($patch);
|
$pullModel->revertWithGitHub($patch->id);
|
||||||
}
|
}
|
||||||
catch (\RuntimeException $e)
|
catch (\RuntimeException $e)
|
||||||
{
|
{
|
||||||
@ -78,16 +62,16 @@ class ResetController extends AbstractController
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (count($patchChain))
|
if (count($appliedPatches[1]))
|
||||||
{
|
{
|
||||||
$revertErrored = false;
|
$revertErrored = false;
|
||||||
|
|
||||||
// Let's try to cleanly revert all applied patches with ci
|
// Let's try to cleanly revert all applied patches with ci
|
||||||
foreach ($patchChain as $patch)
|
foreach ($appliedPatches as $patch)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
$pullModel->revertWithCIServer($patch);
|
$pullModel->revertWithCIServer($patch->id);
|
||||||
}
|
}
|
||||||
catch (\RuntimeException $e)
|
catch (\RuntimeException $e)
|
||||||
{
|
{
|
||||||
|
@ -208,7 +208,6 @@ class PullModel extends AbstractModel
|
|||||||
$tempPath = $ciSettings->get('folder.temp') . "/$id";
|
$tempPath = $ciSettings->get('folder.temp') . "/$id";
|
||||||
$backupsPath = $ciSettings->get('folder.backups') . "/$id";
|
$backupsPath = $ciSettings->get('folder.backups') . "/$id";
|
||||||
|
|
||||||
$patchChainPath = $ciSettings->get('folder.backups') . '/' . $ciSettings->get('zip.chain.name');
|
|
||||||
$delLogPath = $tempPath . '/' . $ciSettings->get('zip.log.name');
|
$delLogPath = $tempPath . '/' . $ciSettings->get('zip.log.name');
|
||||||
$zipPath = $tempPath . '/' . $ciSettings->get('zip.name');
|
$zipPath = $tempPath . '/' . $ciSettings->get('zip.name');
|
||||||
|
|
||||||
@ -319,17 +318,7 @@ class PullModel extends AbstractModel
|
|||||||
$lastInserted = $this->saveAppliedPatch($id, $files, $sha);
|
$lastInserted = $this->saveAppliedPatch($id, $files, $sha);
|
||||||
|
|
||||||
// Write or create patch chain for correct order of patching
|
// Write or create patch chain for correct order of patching
|
||||||
if (!file_exists($patchChainPath) || filesize($patchChainPath) === 0)
|
$this->appendPatchChain($lastInserted, $id);
|
||||||
{
|
|
||||||
File::write($patchChainPath, json_encode([["id" => $lastInserted, "pull_id" => $id]]));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// Remove any from php set EOL in log file, add id and rewrite file
|
|
||||||
$patchChain = json_decode(file_get_contents($patchChainPath));
|
|
||||||
$patchChain[] = ["id" => $lastInserted, "pull_id" => $id];
|
|
||||||
File::write($patchChainPath, json_encode($patchChain));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Change the media version
|
// Change the media version
|
||||||
$version = new Version;
|
$version = new Version;
|
||||||
@ -626,18 +615,16 @@ class PullModel extends AbstractModel
|
|||||||
$testRecord = $this->getTestRecord($id);
|
$testRecord = $this->getTestRecord($id);
|
||||||
|
|
||||||
// Get PatchChain as array, remove any EOL set by php
|
// Get PatchChain as array, remove any EOL set by php
|
||||||
$patchChainPath = $ciSettings->get('folder.backups') . '/' . $ciSettings->get('zip.chain.name');
|
$patchChain = $this->getLastChain();
|
||||||
$patchChain = array_reverse(json_decode(file_get_contents($patchChainPath)));
|
|
||||||
|
|
||||||
// Allow only reverts in order of the patch chain
|
// Allow only reverts in order of the patch chain
|
||||||
if ($patchChain[0]->id != $id)
|
if ($patchChain[0]->insert_id != $id)
|
||||||
{
|
{
|
||||||
throw new \RuntimeException(Text::sprintf('COM_PATCHTESTER_NOT_IN_ORDER_OF_PATCHCHAIN', $patchChain[0]->pull_id));
|
throw new \RuntimeException(Text::sprintf('COM_PATCHTESTER_NOT_IN_ORDER_OF_PATCHCHAIN', $patchChain[0]->pull_id));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
array_shift($patchChain);
|
$this->removeLastChain($patchChain[0]->insert_id);
|
||||||
File::write($patchChainPath, json_encode(array_reverse($patchChain)));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// We don't want to restore files from an older version
|
// We don't want to restore files from an older version
|
||||||
@ -867,4 +854,112 @@ class PullModel extends AbstractModel
|
|||||||
->where('id = ' . (int) $id)
|
->where('id = ' . (int) $id)
|
||||||
)->loadObject();
|
)->loadObject();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieves a list of patches in chain
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*
|
||||||
|
* @since 3.0
|
||||||
|
*/
|
||||||
|
private function getPatchChain()
|
||||||
|
{
|
||||||
|
$db = $this->getDb();
|
||||||
|
|
||||||
|
$db->setQuery(
|
||||||
|
$db->getQuery(true)
|
||||||
|
->select('*')
|
||||||
|
->from($db->quoteName('#__patchtester_chain'))
|
||||||
|
->order('id DESC')
|
||||||
|
);
|
||||||
|
|
||||||
|
return $db->loadObjectList('pull_id');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the last value of the ci patch chain
|
||||||
|
*
|
||||||
|
* @return stdClass $chain last chain of the table
|
||||||
|
*
|
||||||
|
* @since 3.0.0
|
||||||
|
*/
|
||||||
|
private function getLastChain()
|
||||||
|
{
|
||||||
|
$db = $this->getDb();
|
||||||
|
|
||||||
|
return $db->setQuery(
|
||||||
|
$db->getQuery(true)
|
||||||
|
->select('*')
|
||||||
|
->from('#__patchtester_chain')
|
||||||
|
->order('id DESC'), 0, 1
|
||||||
|
)->loadObject();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a two dimensional array with applied patches
|
||||||
|
* by the github or ci procedure
|
||||||
|
*
|
||||||
|
* @return array two-dimensional array with github patches
|
||||||
|
* and ci patches
|
||||||
|
*
|
||||||
|
* @since 3.0.0
|
||||||
|
*/
|
||||||
|
public function getPatchesDividedInProcs()
|
||||||
|
{
|
||||||
|
$db = $this->getDb();
|
||||||
|
|
||||||
|
$appliedByGit = $db->setQuery(
|
||||||
|
$db->getQuery(true)
|
||||||
|
->select('pulls.id, pulls.pull_id')
|
||||||
|
->from('#__patchtester_chain chain')
|
||||||
|
->leftJoin('#__patchtester_pulls pulls', 'chain.id != pulls.id')
|
||||||
|
)->loadObject();
|
||||||
|
|
||||||
|
$appliedByCI = $this->getPatchChain();
|
||||||
|
|
||||||
|
return [$appliedByGit, $appliedByCI];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds a value to the patch chain in the database
|
||||||
|
*
|
||||||
|
* @param integer $insertId ID of the patch in the database
|
||||||
|
* @param integer $pullId ID of the pull request
|
||||||
|
*
|
||||||
|
* @return integer $insertId last inserted element
|
||||||
|
*
|
||||||
|
* @since 3.0.0
|
||||||
|
*/
|
||||||
|
private function appendPatchChain($insertId, $pullId)
|
||||||
|
{
|
||||||
|
$record = (object) array(
|
||||||
|
'insert_id' => $insertId,
|
||||||
|
'pull_id' => $pullId,
|
||||||
|
);
|
||||||
|
|
||||||
|
$db = $this->getDb();
|
||||||
|
|
||||||
|
$db->insertObject('#__patchtester_chain', $record);
|
||||||
|
return $db->insertid();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes the last value of the chain
|
||||||
|
*
|
||||||
|
* @param integer $insertId ID of the patch in the database
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*
|
||||||
|
* @since 3.0.0
|
||||||
|
*/
|
||||||
|
private function removeLastChain($insertId)
|
||||||
|
{
|
||||||
|
$db = $this->getDb();
|
||||||
|
|
||||||
|
$db->setQuery(
|
||||||
|
$db->getQuery(true)
|
||||||
|
->delete('#__patchtester_chain')
|
||||||
|
->where('insert_id = ' . (int) $insertId)
|
||||||
|
)->execute();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,3 +19,10 @@ CREATE TABLE IF NOT EXISTS `#__patchtester_tests` (
|
|||||||
`applied_version` varchar(25) NOT NULL,
|
`applied_version` varchar(25) NOT NULL,
|
||||||
PRIMARY KEY (`id`)
|
PRIMARY KEY (`id`)
|
||||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 DEFAULT COLLATE=utf8mb4_unicode_ci;
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 DEFAULT COLLATE=utf8mb4_unicode_ci;
|
||||||
|
|
||||||
|
CREATE TABLE IF NOT EXISTS `#__patchtester_chain` (
|
||||||
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`insert_id` int(11) NOT NULL
|
||||||
|
`pull_id` int(11) NOT NULL
|
||||||
|
PRIMARY KEY (`id`)
|
||||||
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 DEFAULT COLLATE=utf8mb4_unicode_ci;
|
||||||
|
@ -1,2 +1,3 @@
|
|||||||
DROP TABLE IF EXISTS `#__patchtester_pulls`;
|
DROP TABLE IF EXISTS `#__patchtester_pulls`;
|
||||||
DROP TABLE IF EXISTS `#__patchtester_tests`;
|
DROP TABLE IF EXISTS `#__patchtester_tests`;
|
||||||
|
DROP TABLE IF EXISTS `#__patchtester_chain`;
|
||||||
|
@ -19,3 +19,10 @@ CREATE TABLE IF NOT EXISTS "#__patchtester_tests" (
|
|||||||
"applied_version" character varying(25) NOT NULL,
|
"applied_version" character varying(25) NOT NULL,
|
||||||
PRIMARY KEY ("id")
|
PRIMARY KEY ("id")
|
||||||
);
|
);
|
||||||
|
|
||||||
|
CREATE TABLE IF NOT EXISTS "#__patchtester_chain" (
|
||||||
|
"id" serial NOT NULL,
|
||||||
|
"insert_id" bigint NOT NULL,
|
||||||
|
"pull_id" bigint NOT NULL
|
||||||
|
PRIMARY KEY (`id`)
|
||||||
|
);
|
||||||
|
@ -1,2 +1,3 @@
|
|||||||
DROP TABLE IF EXISTS "#__patchtester_pulls";
|
DROP TABLE IF EXISTS "#__patchtester_pulls";
|
||||||
DROP TABLE IF EXISTS "#__patchtester_tests";
|
DROP TABLE IF EXISTS "#__patchtester_tests";
|
||||||
|
DROP TABLE IF EXISTS "#__patchtester_chain";
|
||||||
|
@ -25,3 +25,13 @@ CREATE TABLE [#__patchtester_tests](
|
|||||||
[id] ASC
|
[id] ASC
|
||||||
) WITH (STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF)
|
) WITH (STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
CREATE TABLE [#__patchtester_chain] (
|
||||||
|
[id] [bigint] IDENTITY(1,1) NOT NULL,
|
||||||
|
[insert_id] [bigint] NOT NULL
|
||||||
|
[pull_id] [bigint] NOT NULL
|
||||||
|
CONSTRAINT [PK_#__patchtester_chain] PRIMARY KEY CLUSTERED
|
||||||
|
(
|
||||||
|
[id] ASC
|
||||||
|
) WITH (STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF)
|
||||||
|
);
|
||||||
|
@ -1,2 +1,3 @@
|
|||||||
DROP TABLE [#__patchtester_pulls];
|
DROP TABLE [#__patchtester_pulls];
|
||||||
DROP TABLE [#__patchtester_tests];
|
DROP TABLE [#__patchtester_tests];
|
||||||
|
DROP TABLE [#__patchtester_chain];
|
||||||
|
@ -0,0 +1,6 @@
|
|||||||
|
CREATE TABLE IF NOT EXISTS `#__patchtester_chain` (
|
||||||
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`insert_id` int(11) NOT NULL
|
||||||
|
`pull_id` int(11) NOT NULL
|
||||||
|
PRIMARY KEY (`id`)
|
||||||
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 DEFAULT COLLATE=utf8mb4_unicode_ci;
|
@ -0,0 +1,6 @@
|
|||||||
|
CREATE TABLE IF NOT EXISTS "#__patchtester_chain" (
|
||||||
|
"id" serial NOT NULL,
|
||||||
|
"insert_id" bigint NOT NULL,
|
||||||
|
"pull_id" bigint NOT NULL
|
||||||
|
PRIMARY KEY (`id`)
|
||||||
|
);
|
@ -0,0 +1,9 @@
|
|||||||
|
CREATE TABLE [#__patchtester_chain] (
|
||||||
|
[id] [bigint] IDENTITY(1,1) NOT NULL,
|
||||||
|
[insert_id] [bigint] NOT NULL
|
||||||
|
[pull_id] [bigint] NOT NULL
|
||||||
|
CONSTRAINT [PK_#__patchtester_chain] PRIMARY KEY CLUSTERED
|
||||||
|
(
|
||||||
|
[id] ASC
|
||||||
|
) WITH (STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF)
|
||||||
|
);
|
Loading…
x
Reference in New Issue
Block a user