summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorIgor Scheller <igor.scheller@igorshp.de>2018-09-25 17:33:31 +0200
committermsquare <msquare@notrademark.de>2018-10-30 21:13:56 +0100
commit7f61dc95be4ac543986c7df2459532fd8f81368d (patch)
tree930497c659bbaa3e073313a261f3458348fd423d /tests
parent63d1292bf80d88be40eec7695c1a59f29e6609c5 (diff)
EventConfig: Merge event configuration from database to global config
Diffstat (limited to 'tests')
-rw-r--r--tests/Unit/Config/ConfigServiceProviderTest.php81
-rw-r--r--tests/Unit/Renderer/Twig/Extensions/GlobalsTest.php31
2 files changed, 75 insertions, 37 deletions
diff --git a/tests/Unit/Config/ConfigServiceProviderTest.php b/tests/Unit/Config/ConfigServiceProviderTest.php
index 925854be..b93e1b97 100644
--- a/tests/Unit/Config/ConfigServiceProviderTest.php
+++ b/tests/Unit/Config/ConfigServiceProviderTest.php
@@ -5,18 +5,22 @@ namespace Engelsystem\Test\Unit\Config;
use Engelsystem\Application;
use Engelsystem\Config\Config;
use Engelsystem\Config\ConfigServiceProvider;
+use Engelsystem\Models\EventConfig;
use Engelsystem\Test\Unit\ServiceProviderTest;
use Exception;
-use PHPUnit_Framework_MockObject_MockObject;
+use Illuminate\Database\Eloquent\Builder as EloquentBuilder;
+use Illuminate\Database\QueryException;
+use PHPUnit\Framework\MockObject\MockObject;
class ConfigServiceProviderTest extends ServiceProviderTest
{
/**
- * @covers \Engelsystem\Config\ConfigServiceProvider::register()
+ * @covers \Engelsystem\Config\ConfigServiceProvider::register
+ * @covers \Engelsystem\Config\ConfigServiceProvider::getConfigPath
*/
public function testRegister()
{
- /** @var PHPUnit_Framework_MockObject_MockObject|Config $config */
+ /** @var MockObject|Config $config */
$config = $this->getMockBuilder(Config::class)
->getMock();
@@ -53,11 +57,11 @@ class ConfigServiceProviderTest extends ServiceProviderTest
}
/**
- * @covers \Engelsystem\Config\ConfigServiceProvider::register()
+ * @covers \Engelsystem\Config\ConfigServiceProvider::register
*/
public function testRegisterException()
{
- /** @var PHPUnit_Framework_MockObject_MockObject|Config $config */
+ /** @var MockObject|Config $config */
$config = $this->getMockBuilder(Config::class)
->getMock();
@@ -68,8 +72,8 @@ class ConfigServiceProviderTest extends ServiceProviderTest
$app->expects($this->exactly(2))
->method('instance')
->withConsecutive(
- [Config::class, $config],
- ['config', $config]
+ [Config::class, $config],
+ ['config', $config]
);
$this->setExpects($app, 'get', ['path.config'], __DIR__ . '/not_existing', $this->atLeastOnce());
@@ -81,4 +85,67 @@ class ConfigServiceProviderTest extends ServiceProviderTest
$serviceProvider = new ConfigServiceProvider($app);
$serviceProvider->register();
}
+
+ /**
+ * @covers \Engelsystem\Config\ConfigServiceProvider::__construct
+ * @covers \Engelsystem\Config\ConfigServiceProvider::boot
+ */
+ public function testBoot()
+ {
+ $app = $this->getApp(['get']);
+
+ /** @var EventConfig|MockObject $eventConfig */
+ $eventConfig = $this->createMock(EventConfig::class);
+ /** @var EloquentBuilder|MockObject $eloquentBuilder */
+ $eloquentBuilder = $this->getMockBuilder(EloquentBuilder::class)
+ ->disableOriginalConstructor()
+ ->getMock();
+ $config = new Config(['foo' => 'bar', 'lorem' => ['ipsum' => 'dolor', 'bla' => 'foo']]);
+
+ $configs = [
+ new EventConfig(['name' => 'test', 'value' => 'testing']),
+ new EventConfig(['name' => 'lorem', 'value' => ['ipsum' => 'tester']]),
+ ];
+
+ $returnValue = $eloquentBuilder;
+ $eventConfig
+ ->expects($this->exactly(3))
+ ->method('newQuery')
+ ->willReturnCallback(function () use (&$returnValue) {
+ if ($returnValue instanceof EloquentBuilder) {
+ $return = $returnValue;
+ $returnValue = null;
+ return $return;
+ }
+
+ if (is_null($returnValue)) {
+ throw new QueryException('', [], new Exception());
+ }
+
+ return null;
+ });
+
+ $this->setExpects($eloquentBuilder, 'get', [['name', 'value']], $configs);
+ $this->setExpects($app, 'get', ['config'], $config, $this->exactly(3));
+
+ $serviceProvider = new ConfigServiceProvider($app);
+ $serviceProvider->boot();
+
+ $serviceProvider = new ConfigServiceProvider($app, $eventConfig);
+ $serviceProvider->boot();
+ $serviceProvider->boot();
+ $serviceProvider->boot();
+
+ $this->assertArraySubset(
+ [
+ 'foo' => 'bar',
+ 'lorem' => [
+ 'ipsum' => 'tester',
+ 'bla' => 'foo',
+ ],
+ 'test' => 'testing',
+ ],
+ $config->get(null)
+ );
+ }
}
diff --git a/tests/Unit/Renderer/Twig/Extensions/GlobalsTest.php b/tests/Unit/Renderer/Twig/Extensions/GlobalsTest.php
index cdd9cd2a..6441904b 100644
--- a/tests/Unit/Renderer/Twig/Extensions/GlobalsTest.php
+++ b/tests/Unit/Renderer/Twig/Extensions/GlobalsTest.php
@@ -2,54 +2,25 @@
namespace Engelsystem\Test\Unit\Renderer\Twig\Extensions;
-use Carbon\Carbon;
use Engelsystem\Renderer\Twig\Extensions\Globals;
-use PHPUnit\Framework\MockObject\MockObject;
class GlobalsTest extends ExtensionTest
{
/**
* @covers \Engelsystem\Renderer\Twig\Extensions\Globals::getGlobals
- * @covers \Engelsystem\Renderer\Twig\Extensions\Globals::filterEventConfig
*/
public function testGetGlobals()
{
global $user;
$user = [];
- /** @var Globals|MockObject $extension */
- $extension = $this->getMockBuilder(Globals::class)
- ->setMethods(['getEventConfig'])
- ->getMock();
-
- $extension->expects($this->exactly(2))
- ->method('getEventConfig')
- ->willReturnOnConsecutiveCalls(
- null,
- [
- 'lorem' => 'ipsum',
- 'event_end_date' => 1234567890,
- ]
- );
+ $extension = new Globals();
$globals = $extension->getGlobals();
-
$this->assertGlobalsExists('user', [], $globals);
- $this->assertGlobalsExists('event_config', [], $globals);
$user['foo'] = 'bar';
-
$globals = $extension->getGlobals();
$this->assertGlobalsExists('user', ['foo' => 'bar'], $globals);
- $this->assertGlobalsExists('event_config', ['lorem' => 'ipsum'], $globals);
-
- $config = $globals['event_config'];
- $this->assertArrayHasKey('event_end_date', $config);
- /** @var Carbon $eventEndDate */
- $eventEndDate = $config['event_end_date'];
- $this->assertInstanceOf(Carbon::class, $eventEndDate);
-
- $eventEndDate->setTimezone('UTC');
- $this->assertEquals('2009-02-13 23:31:30', $eventEndDate->format('Y-m-d H:i:s'));
}
}