mirror of
				https://github.com/e107inc/e107.git
				synced 2025-10-25 11:46:49 +02:00 
			
		
		
		
	Make sure e107_config.php backup functions correctly, even when the tests are halted.
This commit is contained in:
		| @@ -2,9 +2,6 @@ | ||||
| namespace Helper; | ||||
| include_once(codecept_root_dir() . "lib/preparers/PreparerFactory.php"); | ||||
|  | ||||
| // here you can define custom actions | ||||
| // all public methods declared in helper class will be available in $I | ||||
|  | ||||
| use Codeception\Lib\ModuleContainer; | ||||
| use PreparerFactory; | ||||
| use Twig\Environment; | ||||
| @@ -15,6 +12,7 @@ abstract class E107Base extends Base | ||||
|     const APP_PATH_E107_CONFIG = APP_PATH . "/e107_config.php"; | ||||
|     const E107_MYSQL_PREFIX = 'e107_'; | ||||
|     protected $preparer = null; | ||||
|     private $configBackedUp = false; // Track if we’ve backed up the config | ||||
|  | ||||
|     public function __construct(ModuleContainer $moduleContainer, $config = null) | ||||
|     { | ||||
| @@ -22,7 +20,7 @@ abstract class E107Base extends Base | ||||
|         $this->preparer = PreparerFactory::create(); | ||||
|     } | ||||
|  | ||||
| 	public function _beforeSuite($settings = array()) | ||||
|     public function _beforeSuite($settings = []) | ||||
|     { | ||||
|         $this->backupLocalE107Config(); | ||||
|         $this->preparer->snapshot(); | ||||
| @@ -32,9 +30,9 @@ abstract class E107Base extends Base | ||||
|  | ||||
|     protected function backupLocalE107Config() | ||||
|     { | ||||
| 		if(file_exists(self::APP_PATH_E107_CONFIG)) | ||||
| 		{ | ||||
|         if (file_exists(self::APP_PATH_E107_CONFIG)) { | ||||
|             rename(self::APP_PATH_E107_CONFIG, APP_PATH . '/e107_config.php.bak'); | ||||
|             $this->configBackedUp = true; // Mark as backed up | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @@ -66,29 +64,31 @@ abstract class E107Base extends Base | ||||
|         $this->restoreLocalE107Config(); | ||||
|         $this->workaroundOldPhpUnitPhpCodeCoverage(); | ||||
|     } | ||||
| /* | ||||
| 	public function _failed($test, $fail) | ||||
|  | ||||
|     /** | ||||
|      * Destructor: Ensures cleanup even on crashes or fatal errors. | ||||
|      */ | ||||
|     public function __destruct() | ||||
|     { | ||||
| 		parent::_failed($test, $fail); | ||||
|         // Only restore if we backed up and haven’t already restored | ||||
|         if ($this->configBackedUp && file_exists(APP_PATH . '/e107_config.php.bak')) { | ||||
|             $this->revokeLocalE107Config(); | ||||
| 		$this->preparer->rollback(); | ||||
|             $this->restoreLocalE107Config(); | ||||
| 		$this->workaroundOldPhpUnitPhpCodeCoverage(); | ||||
|  | ||||
| 	}*/ | ||||
|  | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     protected function revokeLocalE107Config() | ||||
|     { | ||||
| 		if (file_exists(self::APP_PATH_E107_CONFIG)) | ||||
|         if (file_exists(self::APP_PATH_E107_CONFIG)) { | ||||
|             unlink(self::APP_PATH_E107_CONFIG); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     protected function restoreLocalE107Config() | ||||
|     { | ||||
| 		if(file_exists(APP_PATH."/e107_config.php.bak")) | ||||
| 		{ | ||||
|         if (file_exists(APP_PATH . "/e107_config.php.bak")) { | ||||
|             rename(APP_PATH . '/e107_config.php.bak', self::APP_PATH_E107_CONFIG); | ||||
|             $this->configBackedUp = false; // Reset flag after restoration | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @@ -100,13 +100,11 @@ abstract class E107Base extends Base | ||||
|     { | ||||
|         $composer_installed_file = codecept_absolute_path("vendor/composer/installed.json"); | ||||
|         $composer_installed = json_decode(file_get_contents($composer_installed_file)); | ||||
| 		if (isset($composer_installed->packages)) | ||||
| 		{ | ||||
|         if (isset($composer_installed->packages)) { | ||||
|             // Composer 2 format for the installed packages manifest | ||||
|             $composer_installed = $composer_installed->packages; | ||||
|         } | ||||
| 		$installed_phpunit_php_code_coverage = current(array_filter($composer_installed, function ($element) | ||||
| 		{ | ||||
|         $installed_phpunit_php_code_coverage = current(array_filter($composer_installed, function ($element) { | ||||
|             return $element->name == 'phpunit/php-code-coverage'; | ||||
|         })); | ||||
|         if (version_compare($installed_phpunit_php_code_coverage->version_normalized, '6.0.8', '>=')) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user