You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Web/Sources/vendor/adriangibbons/php-fit-file-analysis/tests/pFFA-Basic-Test.php

93 lines
3.7 KiB

<?php
error_reporting(E_ALL);
if(!class_exists('adriangibbons\phpFITFileAnalysis')) {
require __DIR__ . '/../src/phpFITFileAnalysis.php';
}
class BasicTest extends PHPUnit_Framework_TestCase
{
private $base_dir;
private $demo_files = [];
private $valid_files = ['mountain-biking.fit', 'power-analysis.fit', 'road-cycling.fit', 'swim.fit'];
public function setUp()
{
$this->base_dir = __DIR__ . '/../demo/fit_files/';
}
public function testDemoFilesExist()
{
$this->demo_files = array_values(array_diff(scandir($this->base_dir), array('..', '.')));
sort($this->demo_files);
sort($this->valid_files);
$this->assertEquals($this->valid_files, $this->demo_files);
var_dump($this->demo_files);
}
/**
* @expectedException Exception
*/
public function testEmptyFilepath()
{
$pFFA = new adriangibbons\phpFITFileAnalysis('');
}
/**
* @expectedException Exception
*/
public function testFileDoesntExist()
{
$pFFA = new adriangibbons\phpFITFileAnalysis('file_doesnt_exist.fit');
}
/**
* @expectedException Exception
*/
public function testInvalidFitFile()
{
$file_path = $this->base_dir . '../composer.json';
$pFFA = new adriangibbons\phpFITFileAnalysis($file_path);
}
public function testDemoFileBasics()
{
foreach($this->demo_files as $filename) {
$pFFA = new adriangibbons\phpFITFileAnalysis($this->base_dir . $filename);
$this->assertGreaterThan(0, $pFFA->data_mesgs['activity']['timestamp'], 'No Activity timestamp!');
if (isset($pFFA->data_mesgs['record'])) {
$this->assertGreaterThan(0, count($pFFA->data_mesgs['record']['timestamp']), 'No Record timestamps!');
// Check if distance from record messages is +/- 2% of distance from session message
if (is_array($pFFA->data_mesgs['record']['distance'])) {
$distance_difference = abs(end($pFFA->data_mesgs['record']['distance']) - $pFFA->data_mesgs['session']['total_distance'] / 1000);
$this->assertLessThan(0.02 * end($pFFA->data_mesgs['record']['distance']), $distance_difference, 'Session distance should be similar to last Record distance');
}
// Look for big jumps in latitude and longitude
if (isset($pFFA->data_mesgs['record']['position_lat']) && is_array($pFFA->data_mesgs['record']['position_lat'])) {
foreach ($pFFA->data_mesgs['record']['position_lat'] as $key => $value) {
if (isset($pFFA->data_mesgs['record']['position_lat'][$key - 1])) {
if (abs($pFFA->data_mesgs['record']['position_lat'][$key - 1] - $pFFA->data_mesgs['record']['position_lat'][$key]) > 1) {
$this->assertTrue(false, 'Too big a jump in latitude');
}
}
}
}
if (isset($pFFA->data_mesgs['record']['position_long']) && is_array($pFFA->data_mesgs['record']['position_long'])) {
foreach ($pFFA->data_mesgs['record']['position_long'] as $key => $value) {
if (isset($pFFA->data_mesgs['record']['position_long'][$key - 1])) {
if (abs($pFFA->data_mesgs['record']['position_long'][$key - 1] - $pFFA->data_mesgs['record']['position_long'][$key]) > 1) {
$this->assertTrue(false, 'Too big a jump in longitude');
}
}
}
}
}
}
}
}