addTestUser(); $trackId = $this->addTestTrack($userId); $this->assertEquals(1, $this->getConnection()->getRowCount('tracks'), "Wrong row count"); $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); $this->assertEquals(0, $this->getConnection()->getRowCount('positions'), "Wrong row count"); $this->assertFalse($posId, "Adding position with nonexistant track should fail"); $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); $this->assertEquals(0, $this->getConnection()->getRowCount('positions'), "Wrong row count"); $this->assertFalse($posId, "Adding position with wrong user should fail"); $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); $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", "SELECT id, user_id, track_id, " . $this->unix_timestamp('time') . " AS time, latitude, longitude, altitude, speed, bearing, accuracy, provider, comment, image_id FROM positions" ); $this->assertTableContains($expected, $actual, "Wrong actual table data"); $posId = uPosition::add($userId, $trackId, NULL, $this->testLat, $this->testLon); $this->assertFalse($posId, "Adding position with null time stamp should fail"); $posId = uPosition::add($userId, $trackId, $this->testTimestamp, NULL, $this->testLon); $this->assertFalse($posId, "Adding position with null latitude should fail"); $posId = uPosition::add($userId, $trackId, $this->testTimestamp, $this->testLat, NULL); $this->assertFalse($posId, "Adding position with null longitude should fail"); $posId = uPosition::add($userId, $trackId, "", $this->testLat, $this->testLon); $this->assertFalse($posId, "Adding position with empty time stamp should fail"); $posId = uPosition::add($userId, $trackId, $this->testTimestamp, "", $this->testLon); $this->assertFalse($posId, "Adding position with empty latitude should fail"); $posId = uPosition::add($userId, $trackId, $this->testTimestamp, $this->testLat, ""); $this->assertFalse($posId, "Adding position with empty longitude should fail"); } public function testDeleteAll() { $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); $this->assertEquals(3, $this->getConnection()->getRowCount('tracks'), "Wrong row count"); $this->assertEquals(3, $this->getConnection()->getRowCount('positions'), "Wrong row count"); $this->assertTrue(uPosition::deleteAll($userId), "Deleting failed"); $this->assertEquals(1, $this->getConnection()->getRowCount('positions'), "Wrong row count"); } public function testDeleteAllWIthTrackId() { $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); $this->assertEquals(3, $this->getConnection()->getRowCount('tracks'), "Wrong row count"); $this->assertEquals(3, $this->getConnection()->getRowCount('positions'), "Wrong row count"); $this->assertTrue(uPosition::deleteAll($userId, $trackId), "Deleting failed"); $this->assertEquals(2, $this->getConnection()->getRowCount('positions'), "Wrong row count"); } public function testGetLast() { $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"); $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)"); } 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: $this->assertTrue(false, "Unexpected position: {$position->id}"); } } } public function testGetAll() { $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); $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"); $posArr = uPosition::getAll($userId); $this->assertEquals(2, count($posArr), "Wrong row count"); $posArr = uPosition::getAll($userId, $trackId); $this->assertEquals(1, count($posArr), "Wrong row count"); $posArr = uPosition::getAll(NULL, $trackId); $this->assertEquals(1, count($posArr), "Wrong row count"); $posArr = uPosition::getAll($userId3); $this->assertEquals(0, count($posArr), "Wrong row count"); } public function testDistanceTo() { $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); $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() { $userId = $this->addTestUser(); $trackId = $this->addTestTrack($userId); $pos1 = $this->addTestPosition($userId, $trackId, $this->testTimestamp); $pos2 = $this->addTestPosition($userId, $trackId, $this->testTimestamp + 1); $posArr = uPosition::getAll(); $this->assertEquals(2, count($posArr), "Wrong row count"); $this->assertEquals(-1, $posArr[0]->secondsTo($posArr[1]), "Wrong time difference"); } } ?>