2017-09-05 09:36:10 +02:00
|
|
|
<?php
|
|
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
|
|
|
|
require_once(__DIR__ . "/../lib/UloggerDatabaseTestCase.php");
|
|
|
|
require_once(__DIR__ . "/../../helpers/track.php");
|
|
|
|
|
|
|
|
class PositionTest extends UloggerDatabaseTestCase {
|
|
|
|
|
|
|
|
public function testAddPosition() {
|
2019-01-24 19:07:41 +01:00
|
|
|
$userId = $this->addTestUser();
|
|
|
|
$trackId = $this->addTestTrack($userId);
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertEquals(1, $this->getConnection()->getRowCount('tracks'), "Wrong row count");
|
|
|
|
|
2019-01-24 19:07:41 +01:00
|
|
|
$posId = uPosition::add($userId, $trackId + 1, $this->testTimestamp, $this->testLat, $this->testLon, $this->testAltitude, $this->testSpeed, $this->testBearing, $this->testAccuracy, $this->testProvider, $this->testComment, $this->testImageId);
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertEquals(0, $this->getConnection()->getRowCount('positions'), "Wrong row count");
|
|
|
|
$this->assertFalse($posId, "Adding position with nonexistant track should fail");
|
|
|
|
|
2019-01-24 19:07:41 +01:00
|
|
|
$posId = uPosition::add($userId + 1, $trackId, $this->testTimestamp, $this->testLat, $this->testLon, $this->testAltitude, $this->testSpeed, $this->testBearing, $this->testAccuracy, $this->testProvider, $this->testComment, $this->testImageId);
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertEquals(0, $this->getConnection()->getRowCount('positions'), "Wrong row count");
|
|
|
|
$this->assertFalse($posId, "Adding position with wrong user should fail");
|
|
|
|
|
2019-01-24 19:07:41 +01:00
|
|
|
$posId = uPosition::add($userId, $trackId, $this->testTimestamp, $this->testLat, $this->testLon, $this->testAltitude, $this->testSpeed, $this->testBearing, $this->testAccuracy, $this->testProvider, $this->testComment, $this->testImageId);
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertEquals(1, $this->getConnection()->getRowCount('positions'), "Wrong row count");
|
|
|
|
$expected = [
|
|
|
|
"id" => $posId,
|
|
|
|
"user_id" => $this->testUserId,
|
|
|
|
"track_id" => $trackId,
|
|
|
|
"time" => $this->testTimestamp,
|
|
|
|
"latitude" => $this->testLat,
|
|
|
|
"longitude" => $this->testLon,
|
|
|
|
"altitude" => $this->testAltitude,
|
|
|
|
"speed" => $this->testSpeed,
|
|
|
|
"bearing" => $this->testBearing,
|
|
|
|
"accuracy" => $this->testAccuracy,
|
|
|
|
"provider" => $this->testProvider,
|
|
|
|
"comment" => $this->testComment,
|
|
|
|
"image_id" => $this->testImageId
|
|
|
|
];
|
|
|
|
$actual = $this->getConnection()->createQueryTable(
|
|
|
|
"positions",
|
2019-01-24 19:07:41 +01:00
|
|
|
"SELECT id, user_id, track_id, " . $this->unix_timestamp('time') . " AS time, latitude, longitude, altitude, speed, bearing, accuracy, provider, comment, image_id FROM positions"
|
2017-09-05 09:36:10 +02:00
|
|
|
);
|
|
|
|
$this->assertTableContains($expected, $actual, "Wrong actual table data");
|
|
|
|
|
2019-01-24 19:07:41 +01:00
|
|
|
$posId = uPosition::add($userId, $trackId, NULL, $this->testLat, $this->testLon);
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertFalse($posId, "Adding position with null time stamp should fail");
|
2019-01-24 19:07:41 +01:00
|
|
|
$posId = uPosition::add($userId, $trackId, $this->testTimestamp, NULL, $this->testLon);
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertFalse($posId, "Adding position with null latitude should fail");
|
2019-01-24 19:07:41 +01:00
|
|
|
$posId = uPosition::add($userId, $trackId, $this->testTimestamp, $this->testLat, NULL);
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertFalse($posId, "Adding position with null longitude should fail");
|
|
|
|
|
2019-01-24 19:07:41 +01:00
|
|
|
$posId = uPosition::add($userId, $trackId, "", $this->testLat, $this->testLon);
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertFalse($posId, "Adding position with empty time stamp should fail");
|
2019-01-24 19:07:41 +01:00
|
|
|
$posId = uPosition::add($userId, $trackId, $this->testTimestamp, "", $this->testLon);
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertFalse($posId, "Adding position with empty latitude should fail");
|
2019-01-24 19:07:41 +01:00
|
|
|
$posId = uPosition::add($userId, $trackId, $this->testTimestamp, $this->testLat, "");
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertFalse($posId, "Adding position with empty longitude should fail");
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testDeleteAll() {
|
2019-01-24 19:07:41 +01:00
|
|
|
$userId = $this->addTestUser();
|
|
|
|
$userId2 = $this->addTestUser($this->testUser2);
|
|
|
|
$trackId = $this->addTestTrack($userId);
|
|
|
|
$this->addTestPosition($userId, $trackId);
|
|
|
|
$trackId2 = $this->addTestTrack($userId);
|
|
|
|
$this->addTestPosition($userId, $trackId2);
|
|
|
|
$trackId3 = $this->addTestTrack($userId2);
|
|
|
|
$this->addTestPosition($userId2, $trackId3);
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertEquals(3, $this->getConnection()->getRowCount('tracks'), "Wrong row count");
|
|
|
|
$this->assertEquals(3, $this->getConnection()->getRowCount('positions'), "Wrong row count");
|
|
|
|
|
2019-01-24 19:07:41 +01:00
|
|
|
$this->assertTrue(uPosition::deleteAll($userId), "Deleting failed");
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertEquals(1, $this->getConnection()->getRowCount('positions'), "Wrong row count");
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testDeleteAllWIthTrackId() {
|
2019-01-24 19:07:41 +01:00
|
|
|
$userId = $this->addTestUser();
|
|
|
|
$userId2 = $this->addTestUser($this->testUser2);
|
|
|
|
$trackId = $this->addTestTrack($userId);
|
|
|
|
$this->addTestPosition($userId, $trackId);
|
|
|
|
$trackId2 = $this->addTestTrack($userId);
|
|
|
|
$this->addTestPosition($userId, $trackId2);
|
|
|
|
$trackId3 = $this->addTestTrack($userId2);
|
|
|
|
$this->addTestPosition($userId2, $trackId3);
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertEquals(3, $this->getConnection()->getRowCount('tracks'), "Wrong row count");
|
|
|
|
$this->assertEquals(3, $this->getConnection()->getRowCount('positions'), "Wrong row count");
|
|
|
|
|
2019-01-24 19:07:41 +01:00
|
|
|
$this->assertTrue(uPosition::deleteAll($userId, $trackId), "Deleting failed");
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertEquals(2, $this->getConnection()->getRowCount('positions'), "Wrong row count");
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testGetLast() {
|
2019-01-24 19:07:41 +01:00
|
|
|
$userId = $this->addTestUser();
|
|
|
|
$userId2 = $this->addTestUser($this->testUser2);
|
|
|
|
$trackId1 = $this->addTestTrack($userId);
|
|
|
|
$trackId2 = $this->addTestTrack($userId);
|
|
|
|
$pos1 = $this->addTestPosition($userId, $trackId1, $this->testTimestamp + 3);
|
|
|
|
$pos2 = $this->addTestPosition($userId2, $trackId2, $this->testTimestamp + 1);
|
|
|
|
$pos3 = $this->addTestPosition($userId, $trackId1, $this->testTimestamp);
|
|
|
|
$pos4 = $this->addTestPosition($userId2, $trackId2, $this->testTimestamp + 2);
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertEquals(2, $this->getConnection()->getRowCount('tracks'), "Wrong row count");
|
|
|
|
$this->assertEquals(4, $this->getConnection()->getRowCount('positions'), "Wrong row count");
|
|
|
|
$lastPosition = uPosition::getLast();
|
|
|
|
$this->assertEquals($lastPosition->id, $pos1, "Wrong last position");
|
|
|
|
$lastPosition = uPosition::getLast($this->testUserId2);
|
|
|
|
$this->assertEquals($lastPosition->id, $pos4, "Wrong last position (user)");
|
|
|
|
}
|
|
|
|
|
2019-03-02 23:53:45 +01:00
|
|
|
public function testGetLastAllUsers() {
|
|
|
|
$userId = $this->addTestUser();
|
|
|
|
$userId2 = $this->addTestUser($this->testUser2);
|
|
|
|
$trackId1 = $this->addTestTrack($userId);
|
|
|
|
$trackId2 = $this->addTestTrack($userId);
|
|
|
|
$pos1 = $this->addTestPosition($userId, $trackId1, $this->testTimestamp + 3);
|
|
|
|
$pos2 = $this->addTestPosition($userId2, $trackId2, $this->testTimestamp + 1);
|
|
|
|
$pos3 = $this->addTestPosition($userId, $trackId1, $this->testTimestamp);
|
|
|
|
$pos4 = $this->addTestPosition($userId2, $trackId2, $this->testTimestamp + 2);
|
|
|
|
$this->assertEquals(2, $this->getConnection()->getRowCount('tracks'), "Wrong row count");
|
|
|
|
$this->assertEquals(4, $this->getConnection()->getRowCount('positions'), "Wrong row count");
|
|
|
|
$posArr = uPosition::getLastAllUsers();
|
|
|
|
$this->assertEquals(2, count($posArr), "Wrong row count");
|
|
|
|
foreach ($posArr as $position) {
|
|
|
|
/** @var uPosition $position */
|
|
|
|
switch ($position->id) {
|
|
|
|
case 1:
|
|
|
|
$this->assertEquals($this->testTimestamp + 3, $position->timestamp);
|
|
|
|
$this->assertEquals($userId, $position->userId);
|
|
|
|
$this->assertEquals($trackId1, $position->trackId);
|
|
|
|
break;
|
|
|
|
case 4:
|
|
|
|
$this->assertEquals($this->testTimestamp + 2, $position->timestamp);
|
|
|
|
$this->assertEquals($userId2, $position->userId);
|
|
|
|
$this->assertEquals($trackId2, $position->trackId);
|
|
|
|
break;
|
|
|
|
default:
|
2019-05-23 10:58:57 +02:00
|
|
|
$this->assertTrue(false, "Unexpected position: {$position->id}");
|
2019-03-02 23:53:45 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-09-05 09:36:10 +02:00
|
|
|
public function testGetAll() {
|
2019-01-24 19:07:41 +01:00
|
|
|
$userId = $this->addTestUser();
|
|
|
|
$userId2 = $this->addTestUser($this->testUser2);
|
|
|
|
$userId3 = $this->addTestUser("testUser3");
|
|
|
|
$trackId = $this->addTestTrack($userId);
|
|
|
|
$this->addTestPosition($userId, $trackId);
|
|
|
|
$trackId2 = $this->addTestTrack($userId);
|
|
|
|
$this->addTestPosition($userId, $trackId2);
|
|
|
|
$trackId3 = $this->addTestTrack($userId2);
|
|
|
|
$this->addTestPosition($userId2, $trackId3);
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertEquals(3, $this->getConnection()->getRowCount('tracks'), "Wrong row count");
|
|
|
|
$this->assertEquals(3, $this->getConnection()->getRowCount('positions'), "Wrong row count");
|
|
|
|
|
|
|
|
$posArr = uPosition::getAll();
|
|
|
|
$this->assertEquals(3, count($posArr), "Wrong row count");
|
2019-01-24 19:07:41 +01:00
|
|
|
$posArr = uPosition::getAll($userId);
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertEquals(2, count($posArr), "Wrong row count");
|
2019-01-24 19:07:41 +01:00
|
|
|
$posArr = uPosition::getAll($userId, $trackId);
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertEquals(1, count($posArr), "Wrong row count");
|
|
|
|
$posArr = uPosition::getAll(NULL, $trackId);
|
|
|
|
$this->assertEquals(1, count($posArr), "Wrong row count");
|
2019-01-24 19:07:41 +01:00
|
|
|
$posArr = uPosition::getAll($userId3);
|
2017-09-05 09:36:10 +02:00
|
|
|
$this->assertEquals(0, count($posArr), "Wrong row count");
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testDistanceTo() {
|
2019-01-24 19:07:41 +01:00
|
|
|
$userId = $this->addTestUser();
|
|
|
|
$trackId = $this->addTestTrack($userId);
|
|
|
|
$pos1 = $this->addTestPosition($userId, $trackId, $this->testTimestamp, 0, 0);
|
|
|
|
$pos2 = $this->addTestPosition($userId, $trackId, $this->testTimestamp, 0, 1);
|
2017-09-05 09:36:10 +02:00
|
|
|
$posArr = uPosition::getAll();
|
|
|
|
$this->assertEquals(2, count($posArr), "Wrong row count");
|
|
|
|
$this->assertEquals(111195, round($posArr[0]->distanceTo($posArr[1])), "Wrong distance");
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSecondsTo() {
|
2019-01-24 19:07:41 +01:00
|
|
|
$userId = $this->addTestUser();
|
|
|
|
$trackId = $this->addTestTrack($userId);
|
|
|
|
$pos1 = $this->addTestPosition($userId, $trackId, $this->testTimestamp);
|
|
|
|
$pos2 = $this->addTestPosition($userId, $trackId, $this->testTimestamp + 1);
|
2017-09-05 09:36:10 +02:00
|
|
|
$posArr = uPosition::getAll();
|
|
|
|
$this->assertEquals(2, count($posArr), "Wrong row count");
|
|
|
|
$this->assertEquals(-1, $posArr[0]->secondsTo($posArr[1]), "Wrong time difference");
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
?>
|