1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
<?php
use JsonApi\Routes\Schedule\UserScheduleShow;
class UserScheduleShowTest extends \Codeception\Test\Unit
{
/**
* @var \UnitTester
*/
protected $tester;
protected function _before()
{
\DBManager::getInstance()->setConnection('studip', $this->getModule('\\Helper\\StudipDb')->dbh);
}
protected function _after()
{
}
// tests
public function testGetUserSchedule()
{
$credentials = $this->tester->getCredentialsForTestAutor();
$stmt = \DBManager::get()->prepare(
"INSERT INTO schedule (start, end, day, title, content, color, user_id)
VALUES (?, ?, ?, ?, ?, ?, ?)"
);
$stmt->execute([
1000,
1200,
1,
'a title',
'some content',
1,
$credentials['id'],
]);
$scheduleId = \DBManager::get()->lastInsertId();
$app = $this->tester->createApp($credentials, 'get', '/users/{id}/schedule', UserScheduleShow::class, 'get-schedule');
$app->get('/xxx', function () {})->setName('get-semester');
$requestBuilder = $this->tester->createRequestBuilder($credentials);
$requestBuilder->setUri('/users/'.$credentials['id'].'/schedule')->fetch();
$requestBuilder->setUriQueryParam('filter[timestamp]', Semester::findOneBySQL('1')->beginn);
$response = $this->tester->sendMockRequest($app, $requestBuilder->getRequest());
$this->tester->assertTrue($response->isSuccessfulDocument([200]));
$document = $response->document();
$this->tester->assertTrue($document->isResourceCollectionDocument());
$ids = array_map(function ($property) { return $property->id(); }, $document->primaryResources());
$this->tester->assertContains($scheduleId, $ids);
}
}
|