123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- <?php
- /**
- * Copyright © Magento, Inc. All rights reserved.
- * See COPYING.txt for license details.
- */
- namespace Magento\Developer\Test\Unit\Console\Command;
- use Magento\Developer\Console\Command\QueryLogEnableCommand;
- use Magento\Framework\App\DeploymentConfig\Writer;
- use Magento\Framework\Config\File\ConfigFilePool;
- use Magento\Framework\DB\Logger\LoggerProxy;
- use Symfony\Component\Console\Tester\CommandTester;
- /**
- * Class QueryLogEnableCommandTest
- *
- * Tests dev:query-log:enable command.
- * Tests that the correct configuration is passed to the deployment config writer with and without parameters.
- */
- class QueryLogEnableCommandTest extends \PHPUnit\Framework\TestCase
- {
- /**
- * @var \PHPUnit_Framework_MockObject_MockObject|\Magento\Framework\App\DeploymentConfig\Writer
- */
- private $configWriter;
- /**
- * @var \PHPUnit_Framework_MockObject_MockObject|\Magento\Developer\Console\Command\QueryLogEnableCommand
- */
- private $command;
- /**
- * {@inheritdoc}
- */
- public function setUp()
- {
- $this->configWriter = $this->getMockBuilder(Writer::class)
- ->disableOriginalConstructor()
- ->getMock();
- $this->command = new QueryLogEnableCommand($this->configWriter);
- }
- /**
- * Test execute() without parameters.
- */
- public function testExecuteWithNoParams()
- {
- $data = [LoggerProxy::PARAM_ALIAS => LoggerProxy::LOGGER_ALIAS_FILE];
- $data[LoggerProxy::PARAM_LOG_ALL] = 1;
- $data[LoggerProxy::PARAM_QUERY_TIME] = 0.001;
- $data[LoggerProxy::PARAM_CALL_STACK] = 1;
- $this->configWriter = $this->getMockBuilder(Writer::class)
- ->disableOriginalConstructor()
- ->getMock();
- $this->configWriter
- ->expects($this->any())
- ->method('saveConfig')
- ->with([ConfigFilePool::APP_ENV => [LoggerProxy::CONF_GROUP_NAME => $data]]);
- $commandTester = new CommandTester($this->command);
- $commandTester->execute([]);
- $this->assertSame(
- QueryLogEnableCommand::SUCCESS_MESSAGE . PHP_EOL,
- $commandTester->getDisplay()
- );
- }
- /**
- * Test execute() with parameters.
- */
- public function testExecuteWithParams()
- {
- $data = [LoggerProxy::PARAM_ALIAS => LoggerProxy::LOGGER_ALIAS_FILE];
- $data[LoggerProxy::PARAM_LOG_ALL] = 0;
- $data[LoggerProxy::PARAM_QUERY_TIME] = '0.05';
- $data[LoggerProxy::PARAM_CALL_STACK] = 0;
- $this->configWriter = $this->getMockBuilder(Writer::class)
- ->disableOriginalConstructor()
- ->getMock();
- $this->configWriter
- ->expects($this->any())
- ->method('saveConfig')
- ->with([ConfigFilePool::APP_ENV => [LoggerProxy::CONF_GROUP_NAME => $data]]);
- $commandTester = new CommandTester($this->command);
- $commandTester->execute(
- [
- '--include-all-queries' => 'false',
- '--include-call-stack' => 'false',
- '--query-time-threshold' => '0.05',
- ]
- );
- $this->assertSame(
- QueryLogEnableCommand::SUCCESS_MESSAGE . PHP_EOL,
- $commandTester->getDisplay()
- );
- }
- }
|