Beispiel #1
0
 /**
  * Index Action
  *
  * @return JsonModel
  * @SuppressWarnings(PHPMD.NPathComplexity)
  */
 public function startAction()
 {
     $this->log->clear();
     $json = new JsonModel;
     try {
         $data = array_merge(
             $this->importDeploymentConfigForm(),
             $this->importUserConfigForm(),
             $this->importAdminUserForm()
         );
         $this->installer->install($data);
         $json->setVariable(
             'key',
             $this->installer->getInstallInfo()[SetupConfigOptionsList::KEY_ENCRYPTION_KEY]
         );
         $json->setVariable('success', true);
         $json->setVariable('messages', $this->installer->getInstallInfo()[Installer::INFO_MESSAGE]);
     } catch (\Exception $e) {
         $this->log->logError($e);
         $json->setVariable('success', false);
         if ($e instanceof \Magento\Setup\SampleDataException) {
             $json->setVariable('isSampleDataError', true);
         }
     }
     return $json;
 }
Beispiel #2
0
 /**
  * Index Action
  *
  * @return JsonModel
  */
 public function startAction()
 {
     $this->log->clear();
     $json = new JsonModel();
     try {
         $data = array_merge($this->importDeploymentConfigForm(), $this->importUserConfigForm(), $this->importAdminUserForm());
         $this->installer->install($data);
         $json->setVariable('key', $this->installer->getInstallInfo()[EncryptConfig::KEY_ENCRYPTION_KEY]);
         $json->setVariable('success', true);
         $json->setVariable('messages', $this->installer->getInstallInfo()[Installer::INFO_MESSAGE]);
     } catch (\Exception $e) {
         $this->log->logError($e);
         $json->setVariable('success', false);
     }
     return $json;
 }
 public function testInstall()
 {
     $request = [ConfigOptionsListConstants::INPUT_KEY_DB_HOST => '127.0.0.1', ConfigOptionsListConstants::INPUT_KEY_DB_NAME => 'magento', ConfigOptionsListConstants::INPUT_KEY_DB_USER => 'magento', ConfigOptionsListConstants::INPUT_KEY_ENCRYPTION_KEY => 'encryption_key', ConfigOptionsList::INPUT_KEY_BACKEND_FRONTNAME => 'backend'];
     $this->config->expects($this->atLeastOnce())->method('get')->willReturnMap([[ConfigOptionsListConstants::CONFIG_PATH_DB_CONNECTION_DEFAULT, null, true], [ConfigOptionsListConstants::CONFIG_PATH_CRYPT_KEY, null, true]]);
     $allModules = ['Foo_One' => [], 'Bar_Two' => []];
     $this->moduleLoader->expects($this->any())->method('load')->willReturn($allModules);
     $setup = $this->getMock('Magento\\Setup\\Module\\Setup', [], [], '', false);
     $table = $this->getMock('Magento\\Framework\\DB\\Ddl\\Table', [], [], '', false);
     $connection = $this->getMockForAbstractClass('Magento\\Framework\\DB\\Adapter\\AdapterInterface');
     $setup->expects($this->any())->method('getConnection')->willReturn($connection);
     $table->expects($this->any())->method('addColumn')->willReturn($table);
     $table->expects($this->any())->method('setComment')->willReturn($table);
     $table->expects($this->any())->method('addIndex')->willReturn($table);
     $connection->expects($this->any())->method('newTable')->willReturn($table);
     $resource = $this->getMock('Magento\\Framework\\App\\ResourceConnection', [], [], '', false);
     $this->contextMock->expects($this->any())->method('getResources')->willReturn($resource);
     $resource->expects($this->any())->method('getConnection')->will($this->returnValue($connection));
     $dataSetup = $this->getMock('Magento\\Setup\\Module\\DataSetup', [], [], '', false);
     $cacheManager = $this->getMock('Magento\\Framework\\App\\Cache\\Manager', [], [], '', false);
     $cacheManager->expects($this->any())->method('getAvailableTypes')->willReturn(['foo', 'bar']);
     $cacheManager->expects($this->once())->method('setEnabled')->willReturn(['foo', 'bar']);
     $cacheManager->expects($this->any())->method('clean');
     $appState = (new \Magento\Framework\TestFramework\Unit\Helper\ObjectManager($this))->getObject('Magento\\Framework\\App\\State');
     $this->setupFactory->expects($this->atLeastOnce())->method('create')->with($resource)->willReturn($setup);
     $this->dataSetupFactory->expects($this->atLeastOnce())->method('create')->willReturn($dataSetup);
     $this->objectManager->expects($this->any())->method('create')->will($this->returnValueMap([['Magento\\Framework\\App\\Cache\\Manager', [], $cacheManager], ['Magento\\Framework\\App\\State', [], $appState]]));
     $this->objectManager->expects($this->any())->method('get')->will($this->returnValueMap([['Magento\\Framework\\App\\State', $appState], ['Magento\\Framework\\App\\Cache\\Manager', $cacheManager]]));
     $this->adminFactory->expects($this->once())->method('create')->willReturn($this->getMock('Magento\\Setup\\Model\\AdminAccount', [], [], '', false));
     $this->sampleDataState->expects($this->once())->method('hasError')->willReturn(true);
     $this->logger->expects($this->at(0))->method('log')->with('Starting Magento installation:');
     $this->logger->expects($this->at(1))->method('log')->with('File permissions check...');
     // at(2) invokes logMeta()
     $this->logger->expects($this->at(3))->method('log')->with('Enabling Maintenance Mode...');
     // at(4) - logMeta and so on...
     $this->logger->expects($this->at(5))->method('log')->with('Installing deployment configuration...');
     $this->logger->expects($this->at(7))->method('log')->with('Installing database schema:');
     $this->logger->expects($this->at(9))->method('log')->with("Module 'Foo_One':");
     $this->logger->expects($this->at(11))->method('log')->with("Module 'Bar_Two':");
     $this->logger->expects($this->at(13))->method('log')->with('Schema post-updates:');
     $this->logger->expects($this->at(14))->method('log')->with("Module 'Foo_One':");
     $this->logger->expects($this->at(16))->method('log')->with("Module 'Bar_Two':");
     $this->logger->expects($this->at(19))->method('log')->with('Installing user configuration...');
     $this->logger->expects($this->at(21))->method('log')->with('Enabling caches:');
     $this->logger->expects($this->at(25))->method('log')->with('Installing data...');
     $this->logger->expects($this->at(26))->method('log')->with('Data install/update:');
     $this->logger->expects($this->at(27))->method('log')->with("Module 'Foo_One':");
     $this->logger->expects($this->at(29))->method('log')->with("Module 'Bar_Two':");
     $this->logger->expects($this->at(32))->method('log')->with('Installing admin user...');
     $this->logger->expects($this->at(34))->method('log')->with('Caches clearing:');
     $this->logger->expects($this->at(37))->method('log')->with('Disabling Maintenance Mode:');
     $this->logger->expects($this->at(39))->method('log')->with('Post installation file permissions check...');
     $this->logger->expects($this->at(41))->method('log')->with('Write installation date...');
     $this->logger->expects($this->at(43))->method('logSuccess')->with('Magento installation complete.');
     $this->logger->expects($this->at(45))->method('log')->with('Sample Data is installed with errors. See log file for details');
     $this->object->install($request);
 }
 public function testInstall()
 {
     $request = [DeploymentConfigMapper::KEY_DB_HOST => '127.0.0.1', DeploymentConfigMapper::KEY_DB_NAME => 'magento', DeploymentConfigMapper::KEY_DB_USER => 'magento', DeploymentConfigMapper::KEY_ENCRYPTION_KEY => 'encryption_key', DeploymentConfigMapper::KEY_BACKEND_FRONTNAME => 'backend'];
     $this->config->expects($this->atLeastOnce())->method('isAvailable')->willReturn(true);
     $this->config->expects($this->any())->method('getSegment')->will($this->returnValueMap([[DbConfig::CONFIG_KEY, self::$dbConfig], [EncryptConfig::CONFIG_KEY, [EncryptConfig::KEY_ENCRYPTION_KEY => 'encryption_key']]]));
     $allModules = ['Foo_One' => [], 'Bar_Two' => []];
     $this->moduleLoader->expects($this->any())->method('load')->willReturn($allModules);
     $modules = ['Foo_One' => 1, 'Bar_Two' => 1];
     $this->deploymentConfig->expects($this->any())->method('getData')->willReturn($modules);
     $this->deploymentConfigFactory->expects($this->any())->method('create')->with($modules)->willReturn($this->deploymentConfig);
     $setup = $this->getMock('Magento\\Setup\\Module\\Setup', [], [], '', false);
     $table = $this->getMock('Magento\\Framework\\DB\\Ddl\\Table', [], [], '', false);
     $connection = $this->getMockForAbstractClass('Magento\\Framework\\DB\\Adapter\\AdapterInterface');
     $setup->expects($this->any())->method('getConnection')->willReturn($connection);
     $table->expects($this->any())->method('addColumn')->willReturn($table);
     $table->expects($this->any())->method('setComment')->willReturn($table);
     $table->expects($this->any())->method('addIndex')->willReturn($table);
     $connection->expects($this->any())->method('newTable')->willReturn($table);
     $resource = $this->getMock('Magento\\Framework\\App\\Resource', [], [], '', false);
     $this->contextMock->expects($this->any())->method('getResources')->willReturn($resource);
     $resource->expects($this->any())->method('getConnection')->will($this->returnValue($connection));
     $dataSetup = $this->getMock('Magento\\Setup\\Module\\DataSetup', [], [], '', false);
     $cacheManager = $this->getMock('Magento\\Framework\\App\\Cache\\Manager', [], [], '', false);
     $cacheManager->expects($this->once())->method('getAvailableTypes')->willReturn(['foo', 'bar']);
     $cacheManager->expects($this->once())->method('setEnabled')->willReturn(['foo', 'bar']);
     $this->objectManager->expects($this->any())->method('create')->will($this->returnValueMap([['Magento\\Setup\\Module\\Setup', ['resource' => $resource], $setup], ['Magento\\Setup\\Module\\DataSetup', [], $dataSetup], ['Magento\\Framework\\App\\Cache\\Manager', [], $cacheManager]]));
     $this->adminFactory->expects($this->once())->method('create')->willReturn($this->getMock('Magento\\Setup\\Model\\AdminAccount', [], [], '', false));
     $this->logger->expects($this->at(0))->method('log')->with('Starting Magento installation:');
     $this->logger->expects($this->at(1))->method('log')->with('File permissions check...');
     // at(2) invokes logMeta()
     $this->logger->expects($this->at(3))->method('log')->with('Enabling Maintenance Mode...');
     // at(4) - logMeta and so on...
     $this->logger->expects($this->at(5))->method('log')->with('Installing deployment configuration...');
     $this->logger->expects($this->at(7))->method('log')->with('Installing database schema:');
     $this->logger->expects($this->at(9))->method('log')->with("Module 'Foo_One':");
     $this->logger->expects($this->at(11))->method('log')->with("Module 'Bar_Two':");
     $this->logger->expects($this->at(13))->method('log')->with('Schema post-updates:');
     $this->logger->expects($this->at(14))->method('log')->with("Module 'Foo_One':");
     $this->logger->expects($this->at(16))->method('log')->with("Module 'Bar_Two':");
     $this->logger->expects($this->at(19))->method('log')->with('Installing user configuration...');
     $this->logger->expects($this->at(21))->method('log')->with('Installing data...');
     $this->logger->expects($this->at(22))->method('log')->with('Data install/update:');
     $this->logger->expects($this->at(23))->method('log')->with("Module 'Foo_One':");
     $this->logger->expects($this->at(25))->method('log')->with("Module 'Bar_Two':");
     $this->logger->expects($this->at(28))->method('log')->with('Installing admin user...');
     $this->logger->expects($this->at(30))->method('log')->with('Enabling caches:');
     $this->logger->expects($this->at(31))->method('log')->with('Current status:');
     $this->logger->expects($this->at(34))->method('log')->with('Disabling Maintenance Mode:');
     $this->logger->expects($this->at(36))->method('log')->with('Post installation file permissions check...');
     $this->logger->expects($this->once())->method('logSuccess')->with('Magento installation complete.');
     $this->object->install($request);
 }
Beispiel #5
0
 /**
  * Index Action
  *
  * @return JsonModel
  */
 public function startAction()
 {
     $this->log->clear();
     $json = new JsonModel();
     try {
         $this->checkForPriorInstall();
         $content = $this->getRequest()->getContent();
         $source = $content ? $source = Json::decode($content, Json::TYPE_ARRAY) : [];
         $data = $this->requestDataConverter->convert($source);
         $this->installer->install($data);
         $json->setVariable('key', $this->installer->getInstallInfo()[SetupConfigOptionsList::KEY_ENCRYPTION_KEY]);
         $json->setVariable('success', true);
         if ($this->sampleDataState->hasError()) {
             $json->setVariable('isSampleDataError', true);
         }
         $json->setVariable('messages', $this->installer->getInstallInfo()[Installer::INFO_MESSAGE]);
     } catch (\Exception $e) {
         $this->log->logError($e);
         $json->setVariable('messages', $e->getMessage());
         $json->setVariable('success', false);
     }
     return $json;
 }
 /**
  * Controller for Install Command
  *
  * @return void
  */
 public function installAction()
 {
     /** @var \Zend\Console\Request $request */
     $request = $this->getRequest();
     $this->installer->install($request->getParams());
 }