2018-12-18 02:23:44 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Engelsystem\Test\Unit\Controllers\Metrics;
|
|
|
|
|
2020-04-19 19:18:56 +02:00
|
|
|
use DMS\PHPUnitExtensions\ArraySubset\ArraySubsetAsserts;
|
2018-12-18 02:23:44 +01:00
|
|
|
use Engelsystem\Config\Config;
|
|
|
|
use Engelsystem\Controllers\Metrics\Controller;
|
|
|
|
use Engelsystem\Controllers\Metrics\MetricsEngine;
|
|
|
|
use Engelsystem\Controllers\Metrics\Stats;
|
2019-07-21 02:34:52 +02:00
|
|
|
use Engelsystem\Helpers\Version;
|
2018-12-18 02:23:44 +01:00
|
|
|
use Engelsystem\Http\Exceptions\HttpForbidden;
|
|
|
|
use Engelsystem\Http\Request;
|
|
|
|
use Engelsystem\Http\Response;
|
|
|
|
use Engelsystem\Test\Unit\TestCase;
|
2018-12-21 20:09:15 +01:00
|
|
|
use Illuminate\Support\Collection;
|
2018-12-18 02:23:44 +01:00
|
|
|
use PHPUnit\Framework\MockObject\MockObject;
|
2018-12-18 04:43:13 +01:00
|
|
|
use Psr\Log\LogLevel;
|
2018-12-18 02:23:44 +01:00
|
|
|
use Symfony\Component\HttpFoundation\ServerBag;
|
|
|
|
|
|
|
|
class ControllerTest extends TestCase
|
|
|
|
{
|
2020-04-19 19:18:56 +02:00
|
|
|
use ArraySubsetAsserts;
|
|
|
|
|
2018-12-18 02:23:44 +01:00
|
|
|
/**
|
|
|
|
* @covers \Engelsystem\Controllers\Metrics\Controller::__construct
|
|
|
|
* @covers \Engelsystem\Controllers\Metrics\Controller::metrics
|
2020-04-19 19:18:56 +02:00
|
|
|
* @covers \Engelsystem\Controllers\Metrics\Controller::formatStats
|
2018-12-18 02:23:44 +01:00
|
|
|
*/
|
2022-12-14 19:15:20 +01:00
|
|
|
public function testMetrics(): void
|
2018-12-18 02:23:44 +01:00
|
|
|
{
|
|
|
|
/** @var Response|MockObject $response */
|
|
|
|
/** @var Request|MockObject $request */
|
|
|
|
/** @var MetricsEngine|MockObject $engine */
|
|
|
|
/** @var Stats|MockObject $stats */
|
|
|
|
/** @var Config $config */
|
2019-07-21 02:34:52 +02:00
|
|
|
/** @var Version|MockObject $version */
|
|
|
|
list($response, $request, $engine, $stats, $config, $version) = $this->getMocks();
|
2018-12-18 02:23:44 +01:00
|
|
|
|
|
|
|
$request->server = new ServerBag();
|
|
|
|
$request->server->set('REQUEST_TIME_FLOAT', 0.0123456789);
|
|
|
|
|
|
|
|
$engine->expects($this->once())
|
|
|
|
->method('get')
|
2022-12-04 14:08:06 +01:00
|
|
|
->willReturnCallback(function ($path, $data) {
|
2018-12-18 02:23:44 +01:00
|
|
|
$this->assertEquals('/metrics', $path);
|
2019-07-21 02:34:52 +02:00
|
|
|
$this->assertArrayHasKey('info', $data);
|
2018-12-18 02:23:44 +01:00
|
|
|
$this->assertArrayHasKey('users', $data);
|
2018-12-18 04:43:13 +01:00
|
|
|
$this->assertArrayHasKey('licenses', $data);
|
2018-12-18 02:23:44 +01:00
|
|
|
$this->assertArrayHasKey('users_working', $data);
|
|
|
|
$this->assertArrayHasKey('work_seconds', $data);
|
2018-12-18 04:43:13 +01:00
|
|
|
$this->assertArrayHasKey('worklog_seconds', $data);
|
2018-12-21 20:09:15 +01:00
|
|
|
$this->assertArrayHasKey('vouchers', $data);
|
|
|
|
$this->assertArrayHasKey('tshirts_issued', $data);
|
|
|
|
$this->assertArrayHasKey('tshirt_sizes', $data);
|
2020-04-19 19:18:56 +02:00
|
|
|
$this->assertArrayHasKey('locales', $data);
|
|
|
|
$this->assertArrayHasKey('themes', $data);
|
2018-12-18 04:43:13 +01:00
|
|
|
$this->assertArrayHasKey('shifts', $data);
|
|
|
|
$this->assertArrayHasKey('announcements', $data);
|
|
|
|
$this->assertArrayHasKey('questions', $data);
|
|
|
|
$this->assertArrayHasKey('messages', $data);
|
|
|
|
$this->assertArrayHasKey('password_resets', $data);
|
2018-12-18 02:23:44 +01:00
|
|
|
$this->assertArrayHasKey('registration_enabled', $data);
|
2019-08-21 14:22:31 +02:00
|
|
|
$this->assertArrayHasKey('database', $data);
|
2018-12-18 04:43:13 +01:00
|
|
|
$this->assertArrayHasKey('sessions', $data);
|
2020-11-22 14:45:24 +01:00
|
|
|
$this->assertArrayHasKey('oauth', $data);
|
2018-12-18 04:43:13 +01:00
|
|
|
$this->assertArrayHasKey('log_entries', $data);
|
2018-12-18 02:23:44 +01:00
|
|
|
$this->assertArrayHasKey('scrape_duration_seconds', $data);
|
|
|
|
|
2020-04-19 19:18:56 +02:00
|
|
|
$this->assertArraySubset(['tshirt_sizes' => [
|
|
|
|
'type' => 'gauge',
|
|
|
|
['labels' => ['size' => 'L'], 2],
|
|
|
|
['labels' => ['size' => 'XL'], 0]
|
|
|
|
]], $data);
|
|
|
|
|
2018-12-18 02:23:44 +01:00
|
|
|
return 'metrics return';
|
|
|
|
});
|
|
|
|
|
|
|
|
$response->expects($this->once())
|
|
|
|
->method('withHeader')
|
|
|
|
->with('Content-Type', 'text/plain; version=0.0.4')
|
|
|
|
->willReturn($response);
|
|
|
|
$response->expects($this->once())
|
|
|
|
->method('withContent')
|
|
|
|
->with('metrics return')
|
|
|
|
->willReturn($response);
|
|
|
|
|
2021-12-19 18:38:42 +01:00
|
|
|
$stats->expects($this->exactly(6))
|
2018-12-18 04:43:13 +01:00
|
|
|
->method('licenses')
|
2021-12-19 18:38:42 +01:00
|
|
|
->withConsecutive(['has_car'], ['forklift'], ['car'], ['3.5t'], ['7.5t'], ['12t'])
|
|
|
|
->willReturnOnConsecutiveCalls(6, 3, 15, 9, 7, 1);
|
2018-12-18 02:23:44 +01:00
|
|
|
$stats->expects($this->exactly(2))
|
|
|
|
->method('arrivedUsers')
|
|
|
|
->withConsecutive([false], [true])
|
|
|
|
->willReturnOnConsecutiveCalls(7, 43);
|
|
|
|
$stats->expects($this->exactly(2))
|
|
|
|
->method('currentlyWorkingUsers')
|
|
|
|
->withConsecutive([false], [true])
|
|
|
|
->willReturnOnConsecutiveCalls(10, 1);
|
|
|
|
$stats->expects($this->exactly(3))
|
|
|
|
->method('workSeconds')
|
|
|
|
->withConsecutive([true, false], [false, false], [null, true])
|
|
|
|
->willReturnOnConsecutiveCalls(60 * 37, 60 * 251, 60 * 3);
|
2018-12-18 04:43:13 +01:00
|
|
|
$stats->expects($this->exactly(2))
|
|
|
|
->method('announcements')
|
|
|
|
->withConsecutive([false], [true])
|
|
|
|
->willReturnOnConsecutiveCalls(18, 7);
|
|
|
|
$stats->expects($this->exactly(2))
|
|
|
|
->method('questions')
|
|
|
|
->withConsecutive([true], [false])
|
|
|
|
->willReturnOnConsecutiveCalls(5, 0);
|
|
|
|
$stats->expects($this->exactly(8))
|
|
|
|
->method('logEntries')
|
|
|
|
->withConsecutive(
|
|
|
|
[LogLevel::EMERGENCY],
|
|
|
|
[LogLevel::ALERT],
|
|
|
|
[LogLevel::CRITICAL],
|
|
|
|
[LogLevel::ERROR],
|
|
|
|
[LogLevel::WARNING],
|
|
|
|
[LogLevel::NOTICE],
|
|
|
|
[LogLevel::INFO],
|
|
|
|
[LogLevel::DEBUG]
|
|
|
|
)
|
|
|
|
->willReturnOnConsecutiveCalls(0, 1, 0, 5, 999, 4, 55, 3);
|
2018-12-18 02:23:44 +01:00
|
|
|
$this->setExpects($stats, 'newUsers', null, 9);
|
2018-12-18 04:43:13 +01:00
|
|
|
$this->setExpects($stats, 'worklogSeconds', null, 39 * 60 * 60);
|
2018-12-21 20:09:15 +01:00
|
|
|
$this->setExpects($stats, 'vouchers', null, 17);
|
|
|
|
$this->setExpects($stats, 'tshirts', null, 3);
|
|
|
|
$this->setExpects($stats, 'tshirtSizes', null, new Collection([
|
2020-04-19 19:18:56 +02:00
|
|
|
['shirt_size' => 'L', 'count' => 2],
|
|
|
|
]));
|
|
|
|
$this->setExpects($stats, 'languages', null, new Collection([
|
|
|
|
['language' => 'en_US', 'count' => 5],
|
|
|
|
]));
|
|
|
|
$this->setExpects($stats, 'themes', null, new Collection([
|
|
|
|
['theme' => '1', 'count' => 3],
|
2018-12-21 20:09:15 +01:00
|
|
|
]));
|
2020-11-22 14:45:24 +01:00
|
|
|
$this->setExpects($stats, 'oauth', null, new Collection([
|
|
|
|
['provider' => 'test', 'count' => 2],
|
|
|
|
]));
|
2018-12-18 04:43:13 +01:00
|
|
|
$this->setExpects($stats, 'shifts', null, 142);
|
|
|
|
$this->setExpects($stats, 'messages', null, 3);
|
|
|
|
$this->setExpects($stats, 'passwordResets', null, 1);
|
|
|
|
$this->setExpects($stats, 'sessions', null, 1234);
|
2018-12-18 02:23:44 +01:00
|
|
|
|
|
|
|
$config->set('registration_enabled', 1);
|
2018-12-21 20:09:15 +01:00
|
|
|
$config->set('tshirt_sizes', [
|
|
|
|
'L' => 'Large',
|
|
|
|
'XL' => 'X Large',
|
|
|
|
]);
|
2020-04-19 19:18:56 +02:00
|
|
|
$config->set('locales', [
|
|
|
|
'de_DE' => 'German',
|
|
|
|
'en_US' => 'US English',
|
|
|
|
]);
|
2021-04-29 21:58:20 +02:00
|
|
|
$config->set('themes', [
|
|
|
|
0 => ['name' => 'Nothing'],
|
|
|
|
1 => ['name' => 'Testing'],
|
2020-04-19 19:18:56 +02:00
|
|
|
]);
|
2020-08-20 14:29:27 +02:00
|
|
|
$config->set('metrics', [
|
|
|
|
'work' => [60 * 60],
|
2020-11-22 14:45:24 +01:00
|
|
|
'voucher' => [1],
|
|
|
|
]);
|
|
|
|
$config->set('oauth', [
|
|
|
|
'test' => ['name' => 'Test'],
|
2020-08-20 14:29:27 +02:00
|
|
|
]);
|
2018-12-18 02:23:44 +01:00
|
|
|
|
2019-07-21 02:34:52 +02:00
|
|
|
$this->setExpects($version, 'getVersion', [], '0.42.42');
|
|
|
|
|
|
|
|
$controller = new Controller($response, $engine, $config, $request, $stats, $version);
|
2018-12-18 02:23:44 +01:00
|
|
|
$controller->metrics();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @covers \Engelsystem\Controllers\Metrics\Controller::checkAuth
|
2019-04-24 11:01:37 +02:00
|
|
|
* @covers \Engelsystem\Controllers\Metrics\Controller::stats
|
2018-12-18 02:23:44 +01:00
|
|
|
*/
|
2022-12-14 19:15:20 +01:00
|
|
|
public function testStats(): void
|
2018-12-18 02:23:44 +01:00
|
|
|
{
|
|
|
|
/** @var Response|MockObject $response */
|
|
|
|
/** @var Request|MockObject $request */
|
|
|
|
/** @var MetricsEngine|MockObject $engine */
|
|
|
|
/** @var Stats|MockObject $stats */
|
|
|
|
/** @var Config $config */
|
2019-07-21 02:34:52 +02:00
|
|
|
/** @var Version|MockObject $version */
|
|
|
|
list($response, $request, $engine, $stats, $config, $version) = $this->getMocks();
|
2018-12-18 02:23:44 +01:00
|
|
|
|
|
|
|
$response->expects($this->once())
|
|
|
|
->method('withHeader')
|
|
|
|
->with('Content-Type', 'application/json')
|
|
|
|
->willReturn($response);
|
|
|
|
$response->expects($this->once())
|
|
|
|
->method('withContent')
|
|
|
|
->with(json_encode([
|
|
|
|
'user_count' => 13,
|
|
|
|
'arrived_user_count' => 10,
|
|
|
|
'done_work_hours' => 99,
|
2019-04-24 11:01:37 +02:00
|
|
|
'users_in_action' => 5,
|
2018-12-18 02:23:44 +01:00
|
|
|
]))
|
|
|
|
->willReturn($response);
|
|
|
|
|
|
|
|
$request->expects($this->once())
|
|
|
|
->method('get')
|
|
|
|
->with('api_key')
|
|
|
|
->willReturn('ApiKey987');
|
|
|
|
|
|
|
|
$config->set('api_key', 'ApiKey987');
|
|
|
|
|
|
|
|
$stats->expects($this->once())
|
|
|
|
->method('workSeconds')
|
|
|
|
->with(true)
|
2019-06-12 02:46:13 +02:00
|
|
|
->willReturn((int)(60 * 60 * 99.47));
|
2018-12-18 02:23:44 +01:00
|
|
|
$this->setExpects($stats, 'newUsers', null, 3);
|
|
|
|
$this->setExpects($stats, 'arrivedUsers', null, 10, $this->exactly(2));
|
|
|
|
$this->setExpects($stats, 'currentlyWorkingUsers', null, 5);
|
|
|
|
|
2019-07-21 02:34:52 +02:00
|
|
|
$controller = new Controller($response, $engine, $config, $request, $stats, $version);
|
2018-12-18 02:23:44 +01:00
|
|
|
$controller->stats();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @covers \Engelsystem\Controllers\Metrics\Controller::checkAuth
|
|
|
|
*/
|
2022-12-14 19:15:20 +01:00
|
|
|
public function testCheckAuth(): void
|
2018-12-18 02:23:44 +01:00
|
|
|
{
|
|
|
|
/** @var Response|MockObject $response */
|
|
|
|
/** @var Request|MockObject $request */
|
|
|
|
/** @var MetricsEngine|MockObject $engine */
|
|
|
|
/** @var Stats|MockObject $stats */
|
|
|
|
/** @var Config $config */
|
2019-07-21 02:34:52 +02:00
|
|
|
/** @var Version|MockObject $version */
|
|
|
|
list($response, $request, $engine, $stats, $config, $version) = $this->getMocks();
|
2018-12-18 02:23:44 +01:00
|
|
|
|
|
|
|
$request->expects($this->once())
|
|
|
|
->method('get')
|
|
|
|
->with('api_key')
|
|
|
|
->willReturn('LoremIpsum!');
|
|
|
|
|
|
|
|
$config->set('api_key', 'fooBar!');
|
|
|
|
|
2019-07-21 02:34:52 +02:00
|
|
|
$controller = new Controller($response, $engine, $config, $request, $stats, $version);
|
2018-12-18 02:23:44 +01:00
|
|
|
|
|
|
|
$this->expectException(HttpForbidden::class);
|
|
|
|
$this->expectExceptionMessage(json_encode(['error' => 'The api_key is invalid']));
|
|
|
|
$controller->stats();
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function getMocks(): array
|
|
|
|
{
|
|
|
|
/** @var Response|MockObject $response */
|
|
|
|
$response = $this->createMock(Response::class);
|
|
|
|
/** @var Request|MockObject $request */
|
|
|
|
$request = $this->createMock(Request::class);
|
|
|
|
/** @var MetricsEngine|MockObject $engine */
|
|
|
|
$engine = $this->createMock(MetricsEngine::class);
|
|
|
|
/** @var Stats|MockObject $stats */
|
|
|
|
$stats = $this->createMock(Stats::class);
|
|
|
|
$config = new Config();
|
2019-07-21 02:34:52 +02:00
|
|
|
$version = $this->createMock(Version::class);
|
2018-12-18 02:23:44 +01:00
|
|
|
|
2019-07-21 02:34:52 +02:00
|
|
|
return [$response, $request, $engine, $stats, $config, $version];
|
2018-12-18 02:23:44 +01:00
|
|
|
}
|
|
|
|
}
|