summaryrefslogtreecommitdiff
path: root/tests/Unit
diff options
context:
space:
mode:
authorIgor Scheller <igor.scheller@igorshp.de>2018-09-24 14:19:13 +0200
committermsquare <msquare@notrademark.de>2018-10-30 21:13:56 +0100
commit63d1292bf80d88be40eec7695c1a59f29e6609c5 (patch)
tree0a17403ee3ebea784f3bab0ed4a158d645b450d5 /tests/Unit
parentc4867811e26bc32798ba24dd701bc2c35d49b027 (diff)
Added EventConfig model
Diffstat (limited to 'tests/Unit')
-rw-r--r--tests/Unit/HasDatabase.php1
-rw-r--r--tests/Unit/Models/EventConfigTest.php128
2 files changed, 129 insertions, 0 deletions
diff --git a/tests/Unit/HasDatabase.php b/tests/Unit/HasDatabase.php
index 467f95fc..264d0a9c 100644
--- a/tests/Unit/HasDatabase.php
+++ b/tests/Unit/HasDatabase.php
@@ -21,6 +21,7 @@ trait HasDatabase
{
$dbManager = new CapsuleManager();
$dbManager->addConnection(['driver' => 'sqlite', 'database' => ':memory:']);
+ $dbManager->bootEloquent();
$connection = $dbManager->getConnection();
$connection->getPdo()->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
diff --git a/tests/Unit/Models/EventConfigTest.php b/tests/Unit/Models/EventConfigTest.php
new file mode 100644
index 00000000..f08e8801
--- /dev/null
+++ b/tests/Unit/Models/EventConfigTest.php
@@ -0,0 +1,128 @@
+<?php
+
+namespace Engelsystem\Test\Unit\Models;
+
+use Carbon\Carbon;
+use Engelsystem\Models\EventConfig;
+use Engelsystem\Test\Unit\HasDatabase;
+use PHPUnit\Framework\TestCase;
+
+class EventConfigTest extends TestCase
+{
+ use HasDatabase;
+
+ /**
+ * @covers \Engelsystem\Models\EventConfig::setValueAttribute
+ */
+ public function testSetValueAttribute()
+ {
+ (new EventConfig())
+ ->setAttribute('name', 'foo')
+ ->setAttribute('value', 'bar')
+ ->save();
+ $this->assertEquals(
+ '"bar"',
+ $this->database
+ ->selectOne("SELECT `value` FROM event_config WHERE name='foo'")
+ ->value
+ );
+
+ (new EventConfig())
+ ->setAttribute('name', 'buildup_start')
+ ->setAttribute('value', new Carbon('2000-01-01 10:20'))
+ ->save();
+ $this->assertEquals(
+ '"2000-01-01"',
+ $this->database
+ ->selectOne("SELECT `value` FROM event_config WHERE name='buildup_start'")
+ ->value
+ );
+
+ ($this->getEventConfig())
+ ->setAttribute('name', 'event_start')
+ ->setValueCast('event_start', 'datetime')
+ ->setAttribute('value', new Carbon('2010-11-11 20:22'))
+ ->save();
+ $this->assertEquals(
+ '"' . (new Carbon('2010-11-11 20:22'))->format(Carbon::ATOM) . '"',
+ $this->database
+ ->selectOne("SELECT `value` FROM event_config WHERE name='event_start'")
+ ->value
+ );
+ }
+
+ /**
+ * @covers \Engelsystem\Models\EventConfig::getValueAttribute
+ */
+ public function testGetValueAttribute()
+ {
+ $model = new EventConfig(['name', 'buildup_start', 'value' => '']);
+ $this->assertEquals('', $model->value);
+
+ (new EventConfig())
+ ->setAttribute('name', 'buildup_start')
+ ->setAttribute('value', new Carbon('2001-02-03 11:12'))
+ ->save();
+ $this->assertEquals(
+ '2001-02-03 00:00',
+ EventConfig::find('buildup_start')
+ ->value
+ ->format('Y-m-d H:i')
+ );
+
+ ($this->getEventConfig())
+ ->setAttribute('name', 'event_start')
+ ->setValueCast('event_start', 'datetime')
+ ->setAttribute('value', new Carbon('2010-11-11 20:22'))
+ ->save();
+ $this->assertEquals(
+ '2010-11-11 20:22',
+ ($this->getEventConfig())->find('event_start')
+ ->setValueCast('event_start', 'datetime')
+ ->value
+ ->format('Y-m-d H:i')
+ );
+ }
+
+ /**
+ * @covers \Engelsystem\Models\EventConfig::getValueCast
+ */
+ public function testGetValueCast()
+ {
+ $model = new EventConfig(['value' => 'bar']);
+ $this->assertEquals('bar', $model->value);
+
+ return;
+ }
+
+ /**
+ * Init a new EventConfig class
+ *
+ * @return EventConfig
+ */
+ protected function getEventConfig()
+ {
+ return new class extends EventConfig
+ {
+ /**
+ * @param string $value
+ * @param string $type
+ * @return EventConfig
+ */
+ public function setValueCast($value, $type)
+ {
+ $this->valueCasts[$value] = $type;
+
+ return $this;
+ }
+ };
+ }
+
+ /**
+ * Prepare test
+ */
+ protected function setUp()
+ {
+ $this->initDatabase();
+ }
+}