summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorIgor Scheller <igor.scheller@igorshp.de>2018-12-21 20:09:15 +0100
committermsquare <msquare@notrademark.de>2018-12-22 11:31:33 +0100
commitb3f059ad04fc0f54282aea98c5c2af8d7e46867a (patch)
tree9a69e1bfb482fc5abb35d7c6f42355b290c21024 /tests
parent482721eb1ba0ee21a3f75a8465fcf53ae08a1603 (diff)
metrics: Added vouchers and tshirts
Diffstat (limited to 'tests')
-rw-r--r--tests/Unit/Controllers/Metrics/ControllerTest.php13
-rw-r--r--tests/Unit/Controllers/Metrics/StatsTest.php63
2 files changed, 71 insertions, 5 deletions
diff --git a/tests/Unit/Controllers/Metrics/ControllerTest.php b/tests/Unit/Controllers/Metrics/ControllerTest.php
index 37310ddf..56415e23 100644
--- a/tests/Unit/Controllers/Metrics/ControllerTest.php
+++ b/tests/Unit/Controllers/Metrics/ControllerTest.php
@@ -10,6 +10,7 @@ use Engelsystem\Http\Exceptions\HttpForbidden;
use Engelsystem\Http\Request;
use Engelsystem\Http\Response;
use Engelsystem\Test\Unit\TestCase;
+use Illuminate\Support\Collection;
use PHPUnit\Framework\MockObject\MockObject;
use Psr\Log\LogLevel;
use Symfony\Component\HttpFoundation\ServerBag;
@@ -41,6 +42,9 @@ class ControllerTest extends TestCase
$this->assertArrayHasKey('users_working', $data);
$this->assertArrayHasKey('work_seconds', $data);
$this->assertArrayHasKey('worklog_seconds', $data);
+ $this->assertArrayHasKey('vouchers', $data);
+ $this->assertArrayHasKey('tshirts_issued', $data);
+ $this->assertArrayHasKey('tshirt_sizes', $data);
$this->assertArrayHasKey('shifts', $data);
$this->assertArrayHasKey('announcements', $data);
$this->assertArrayHasKey('questions', $data);
@@ -102,12 +106,21 @@ class ControllerTest extends TestCase
->willReturnOnConsecutiveCalls(0, 1, 0, 5, 999, 4, 55, 3);
$this->setExpects($stats, 'newUsers', null, 9);
$this->setExpects($stats, 'worklogSeconds', null, 39 * 60 * 60);
+ $this->setExpects($stats, 'vouchers', null, 17);
+ $this->setExpects($stats, 'tshirts', null, 3);
+ $this->setExpects($stats, 'tshirtSizes', null, new Collection([
+ (object)['shirt_size' => 'L', 'count' => 2],
+ ]));
$this->setExpects($stats, 'shifts', null, 142);
$this->setExpects($stats, 'messages', null, 3);
$this->setExpects($stats, 'passwordResets', null, 1);
$this->setExpects($stats, 'sessions', null, 1234);
$config->set('registration_enabled', 1);
+ $config->set('tshirt_sizes', [
+ 'L' => 'Large',
+ 'XL' => 'X Large',
+ ]);
$controller = new Controller($response, $engine, $config, $request, $stats);
$controller->metrics();
diff --git a/tests/Unit/Controllers/Metrics/StatsTest.php b/tests/Unit/Controllers/Metrics/StatsTest.php
index 2ebe52ae..8dc7459e 100644
--- a/tests/Unit/Controllers/Metrics/StatsTest.php
+++ b/tests/Unit/Controllers/Metrics/StatsTest.php
@@ -6,10 +6,12 @@ use Carbon\Carbon;
use Engelsystem\Controllers\Metrics\Stats;
use Engelsystem\Models\LogEntry;
use Engelsystem\Models\User\PasswordReset;
+use Engelsystem\Models\User\PersonalData;
use Engelsystem\Models\User\State;
use Engelsystem\Models\User\User;
use Engelsystem\Test\Unit\HasDatabase;
use Engelsystem\Test\Unit\TestCase;
+use Illuminate\Support\Collection;
use Illuminate\Support\Str;
use Psr\Log\LogLevel;
@@ -32,6 +34,48 @@ class StatsTest extends TestCase
}
/**
+ * @covers \Engelsystem\Controllers\Metrics\Stats::vouchers
+ */
+ public function testVouchers()
+ {
+ $this->initDatabase();
+ $this->addUsers();
+
+ $stats = new Stats($this->database);
+ $this->assertEquals(14, $stats->vouchers());
+ }
+
+ /**
+ * @covers \Engelsystem\Controllers\Metrics\Stats::tshirts
+ */
+ public function testTshirts()
+ {
+ $this->initDatabase();
+ $this->addUsers();
+
+ $stats = new Stats($this->database);
+ $this->assertEquals(2, $stats->tshirts());
+ }
+
+ /**
+ * @covers \Engelsystem\Controllers\Metrics\Stats::tshirtSizes
+ * @covers \Engelsystem\Controllers\Metrics\Stats::raw
+ */
+ public function testTshirtSizes()
+ {
+ $this->initDatabase();
+ $this->addUsers();
+
+ $stats = new Stats($this->database);
+ $sizes = $stats->tshirtSizes();
+ $this->assertCount(2, $sizes);
+ $this->assertEquals(new Collection([
+ (object)['shirt_size' => 'L', 'count' => 2],
+ (object)['shirt_size' => 'XXL', 'count' => 1],
+ ]), $sizes);
+ }
+
+ /**
* @covers \Engelsystem\Controllers\Metrics\Stats::arrivedUsers
*/
public function testArrivedUsers()
@@ -40,7 +84,7 @@ class StatsTest extends TestCase
$this->addUsers();
$stats = new Stats($this->database);
- $this->assertEquals(3, $stats->arrivedUsers());
+ $this->assertEquals(6, $stats->arrivedUsers());
}
/**
@@ -105,16 +149,20 @@ class StatsTest extends TestCase
protected function addUsers()
{
$this->addUser();
- $this->addUser();
+ $this->addUser([], ['shirt_size' => 'L']);
$this->addUser(['arrived' => 1]);
- $this->addUser(['arrived' => 1, 'active' => 1]);
- $this->addUser(['arrived' => 1, 'active' => 1]);
+ $this->addUser(['arrived' => 1, 'got_voucher' => 2], ['shirt_size' => 'XXL']);
+ $this->addUser(['arrived' => 1, 'got_voucher' => 9]);
+ $this->addUser(['arrived' => 1, 'got_voucher' => 3]);
+ $this->addUser(['arrived' => 1, 'active' => 1, 'got_shirt' => true]);
+ $this->addUser(['arrived' => 1, 'active' => 1, 'got_shirt' => true], ['shirt_size' => 'L']);
}
/**
* @param array $state
+ * @param array $personalData
*/
- protected function addUser(array $state = [])
+ protected function addUser(array $state = [], $personalData = [])
{
$name = 'user_' . Str::random(5);
@@ -130,5 +178,10 @@ class StatsTest extends TestCase
$state->user()
->associate($user)
->save();
+
+ $personalData = new PersonalData($personalData);
+ $personalData->user()
+ ->associate($user)
+ ->save();
}
}