forked from friendica/php-json-ld
		
	Rewrite test runner.
- Use PHPUnit. There are many different ways to use PHPUnit, unfortunately, none of them seem to fit quite right with the JSON-LD test suite -- without requiring a lot of extra and/or duplicated effort. A middle ground was chosen.
This commit is contained in:
		
					parent
					
						
							
								9ca43c5a40
							
						
					
				
			
			
				commit
				
					
						f5eeb7c3ad
					
				
			
		
					 1 changed files with 644 additions and 0 deletions
				
			
		
							
								
								
									
										644
									
								
								test.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										644
									
								
								test.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,644 @@ | |||
| <?php | ||||
| /** | ||||
|  * PHP unit tests for JSON-LD. | ||||
|  * | ||||
|  * @author Dave Longley | ||||
|  * | ||||
|  * Copyright (c) 2013 Digital Bazaar, Inc. All rights reserved. | ||||
|  */ | ||||
| require_once('jsonld.php'); | ||||
| 
 | ||||
| class JsonLdTestCase extends PHPUnit_Framework_TestCase { | ||||
|   /** | ||||
|    * Called after all tests; optionally outputs an earl report. | ||||
|    */ | ||||
|   public static function tearDownAfterClass() { | ||||
|     global $EARL, $OPTIONS; | ||||
|     if(isset($OPTIONS['-e'])) { | ||||
|       $filename = $OPTIONS['-e']; | ||||
|       echo "Writing EARL report to: $filename\n"; | ||||
|       $EARL->write($filename); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Runs this test case. Overridden to attach to EARL report w/o need for | ||||
|    * an external XML configuration file. | ||||
|    * | ||||
|    * @param PHPUnit_Framework_TestResult $result the test result. | ||||
|    */ | ||||
|   public function run(PHPUnit_Framework_TestResult $result = NULL) { | ||||
|     global $EARL; | ||||
|     $EARL->attach($result); | ||||
|     parent::run($result); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Tests expansion. | ||||
|    * | ||||
|    * @param JsonLdTest $test the test to run. | ||||
|    * | ||||
|    * @group expand | ||||
|    * @dataProvider expandProvider | ||||
|    */ | ||||
|   public function testExpand($test) { | ||||
|     $this->test = $test; | ||||
|     $input = $test->readProperty('input'); | ||||
|     $options = $test->createOptions(); | ||||
|     $test->run('jsonld_expand', array($input, $options)); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Tests compaction. | ||||
|    * | ||||
|    * @param JsonLdTest $test the test to run. | ||||
|    * | ||||
|    * @group compact | ||||
|    * @dataProvider compactProvider | ||||
|    */ | ||||
|   public function testCompact($test) { | ||||
|     $this->test = $test; | ||||
|     $input = $test->readProperty('input'); | ||||
|     $context = $test->readProperty('context'); | ||||
|     $options = $test->createOptions(); | ||||
|     $test->run('jsonld_compact', array($input, $context, $options)); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Tests flatten. | ||||
|    * | ||||
|    * @param JsonLdTest $test the test to run. | ||||
|    * | ||||
|    * @group flatten | ||||
|    * @dataProvider flattenProvider | ||||
|    */ | ||||
|   public function testFlatten($test) { | ||||
|     $this->test = $test; | ||||
|     $input = $test->readProperty('input'); | ||||
|     $context = $test->readProperty('context'); | ||||
|     $options = $test->createOptions(); | ||||
|     $test->run('jsonld_flatten', array($input, $context, $options)); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Tests serialization to RDF. | ||||
|    * | ||||
|    * @param JsonLdTest $test the test to run. | ||||
|    * | ||||
|    * @group toRdf | ||||
|    * @dataProvider toRdfProvider | ||||
|    */ | ||||
|   public function testToRdf($test) { | ||||
|     $this->test = $test; | ||||
|     $input = $test->readProperty('input'); | ||||
|     $options = $test->createOptions(array('format' => 'application/nquads')); | ||||
|     $test->run('jsonld_to_rdf', array($input, $options)); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Tests deserialization from RDF. | ||||
|    * | ||||
|    * @param JsonLdTest $test the test to run. | ||||
|    * | ||||
|    * @group fromRdf | ||||
|    * @dataProvider fromRdfProvider | ||||
|    */ | ||||
|   public function testFromRdf($test) { | ||||
|     $this->test = $test; | ||||
|     $input = $test->readProperty('input'); | ||||
|     $options = $test->createOptions(array('format' => 'application/nquads')); | ||||
|     $test->run('jsonld_from_rdf', array($input, $options)); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Tests framing. | ||||
|    * | ||||
|    * @param JsonLdTest $test the test to run. | ||||
|    * | ||||
|    * @group frame | ||||
|    * @dataProvider frameProvider | ||||
|    */ | ||||
|   public function testFrame($test) { | ||||
|     $this->test = $test; | ||||
|     $input = $test->readProperty('input'); | ||||
|     $frame = $test->readProperty('frame'); | ||||
|     $options = $test->createOptions(); | ||||
|     $test->run('jsonld_frame', array($input, $frame, $options)); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Tests normalization. | ||||
|    * | ||||
|    * @param JsonLdTest $test the test to run. | ||||
|    * | ||||
|    * @group normalize | ||||
|    * @depends toRdf | ||||
|    * @dataProvider normalizeProvider | ||||
|    */ | ||||
|   public function testNormalize($test) { | ||||
|     $this->test = $test; | ||||
|     $input = $test->readProperty('input'); | ||||
|     $options = $test->createOptions(array('format' => 'application/nquads')); | ||||
|     $test->run('jsonld_compact', array($input, $options)); | ||||
|   } | ||||
| 
 | ||||
|   public function expandProvider() { | ||||
|     return new JsonLdTestIterator('jld:ExpandTest'); | ||||
|   } | ||||
| 
 | ||||
|   public function compactProvider() { | ||||
|     return new JsonLdTestIterator('jld:CompactTest'); | ||||
|   } | ||||
| 
 | ||||
|   public function flattenProvider() { | ||||
|     return new JsonLdTestIterator('jld:FlattenTest'); | ||||
|   } | ||||
| 
 | ||||
|   public function toRdfProvider() { | ||||
|     return new JsonLdTestIterator('jld:ToRDFTest'); | ||||
|   } | ||||
| 
 | ||||
|   public function fromRdfProvider() { | ||||
|     return new JsonLdTestIterator('jld:fromRDFTest'); | ||||
|   } | ||||
| 
 | ||||
|   public function normalizeProvider() { | ||||
|     return new JsonLdTestIterator('jld:NormalizeTest'); | ||||
|   } | ||||
| 
 | ||||
|   public function frameProvider() { | ||||
|     return new JsonLdTestIterator('jld:FrameTest'); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| class JsonLdManifest { | ||||
|   public function __construct($data, $filename) { | ||||
|     $this->data = $data; | ||||
|     $this->filename = $filename; | ||||
|     $this->dirname = dirname($filename); | ||||
|   } | ||||
| 
 | ||||
|   public function load(&$tests) { | ||||
|     $sequence = JsonLdProcessor::getValues($this->data, 'sequence'); | ||||
|     foreach($sequence as $entry) { | ||||
|       if(is_string($entry)) { | ||||
|         $filename = join( | ||||
|           DIRECTORY_SEPARATOR, array($this->dirname, $entry)); | ||||
|         $entry = Util::readJson($filename); | ||||
|       } | ||||
|       else { | ||||
|         $filename = $this->filename; | ||||
|       } | ||||
| 
 | ||||
|       // entry is another manifest
 | ||||
|       if(JsonLdProcessor::hasValue($entry, '@type', 'mf:Manifest')) { | ||||
|         $manifest = new JsonLdManifest($entry, $filename); | ||||
|         $manifest->load($tests); | ||||
|       } | ||||
|       // assume entry is a test
 | ||||
|       else { | ||||
|         $test = new JsonLdTest($this, $entry, $filename); | ||||
|         $types = JsonLdProcessor::getValues($test->data, '@type'); | ||||
|         foreach($types as $type) { | ||||
|           if(!isset($tests[$type])) { | ||||
|             $tests[$type] = array(); | ||||
|           } | ||||
|           $tests[$type][] = $test; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| class JsonLdTest { | ||||
|   public function __construct($manifest, $data, $filename) { | ||||
|     $this->manifest = $manifest; | ||||
|     $this->data = $data; | ||||
|     $this->filename = $filename; | ||||
|     $this->dirname = dirname($filename); | ||||
|     $this->isPositive = JsonLdProcessor::hasValue( | ||||
|       $data, '@type', 'jld:PositiveEvaluationTest'); | ||||
|     $this->isNegative = JsonLdProcessor::hasValue( | ||||
|       $data, '@type', 'jld:NegativeEvaluationTest'); | ||||
| 
 | ||||
|     // generate test name
 | ||||
|     $this->name = $manifest->data->name . ' ' . substr($data->{'@id'}, 2); | ||||
| 
 | ||||
|     // expand @id and input base
 | ||||
|     $data->{'@id'} = ($manifest->data->baseIri . | ||||
|       basename($manifest->filename) . $data->{'@id'}); | ||||
|     $this->base = $manifest->data->baseIri . $data->input; | ||||
|   } | ||||
| 
 | ||||
|   public function run($fn, $params) { | ||||
|     // read expected data
 | ||||
|     if($this->isNegative) { | ||||
|       $this->expected = $this->data->expect; | ||||
|     } | ||||
|     else { | ||||
|       $this->expected = $this->readProperty('expect'); | ||||
|     } | ||||
| 
 | ||||
|     try { | ||||
|       $this->actual = call_user_func_array($fn, $params); | ||||
|       if($this->isNegative) { | ||||
|         throw new Exception('Expected an error; one was not raised.'); | ||||
|       } | ||||
|       PHPUnit_Framework_TestCase::assertEquals($this->expected, $this->actual); | ||||
|     } | ||||
|     catch(Exception $e) { | ||||
|       if($this->isPositive) { | ||||
|         throw $e; | ||||
|       } | ||||
|       $this->actual = $this->getJsonLdErrorCode($e); | ||||
|       PHPUnit_Framework_TestCase::assertEquals($this->expected, $this->actual); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   public function readProperty($property) { | ||||
|     $data = $this->data; | ||||
|     if(!property_exists($data, $property)) { | ||||
|       return null; | ||||
|     } | ||||
|     $filename = join( | ||||
|       DIRECTORY_SEPARATOR, array($this->dirname, $data->{$property})); | ||||
|     $extension = pathinfo($filename, PATHINFO_EXTENSION); | ||||
|     if($extension === 'jsonld') { | ||||
|       return Util::readJson($filename); | ||||
|     } | ||||
|     return Util::readFile($filename); | ||||
|   } | ||||
| 
 | ||||
|   public function createOptions($opts=array()) { | ||||
|     $http_options = array( | ||||
|       'contentType', 'httpLink', 'httpStatus', 'redirectTo'); | ||||
|     $test_options = (property_exists($this->data, 'option') ? | ||||
|       $this->data->option : array()); | ||||
|     $options = array(); | ||||
|     foreach($test_options as $k => $v) { | ||||
|       if(!in_array($k, $http_options)) { | ||||
|         $options[$k] = $v; | ||||
|       } | ||||
|     } | ||||
|     $options['documentLoader'] = $this->createDocumentLoader(); | ||||
|     $options = array_merge($options, $opts); | ||||
|     if(isset($options['expandContext'])) { | ||||
|       $filename = join( | ||||
|         DIRECTORY_SEPARATOR, array($this->dirname, $options['expandContext'])); | ||||
|       $options['expandContext'] = Util::readJson($filename); | ||||
|     } | ||||
|     return $options; | ||||
|   } | ||||
| 
 | ||||
|   public function createDocumentLoader() { | ||||
|     global $jsonld_default_load_document; | ||||
|     $base = 'http://json-ld.org/test-suite'; | ||||
|     $loader = $jsonld_default_load_document; | ||||
|     $test = $this; | ||||
| 
 | ||||
|     $load_locally = function($url) use ($test, $base) { | ||||
|       $doc = (object)array( | ||||
|         'contextUrl' => null, 'documentUrl' => $url, 'document' => null); | ||||
|       $options = (property_exists($test->data, 'option') ? | ||||
|         $test->data->option : null); | ||||
|       if($options and $url === $test->base) { | ||||
|         if(property_exists($options, 'redirectTo') && | ||||
|           property_exists($options, 'httpStatus') && | ||||
|           $options->httpStatus >= '300') { | ||||
|           $doc->documentUrl = ($test->manifest->data->{'baseIri'} . | ||||
|             $options->redirectTo); | ||||
|         } | ||||
|         else if(property_exists($options, 'httpLink')) { | ||||
|           $content_type = (property_exists($options, 'contentType') ? | ||||
|             $options->contentType : null); | ||||
|           $extension = pathinfo($url, PATHINFO_EXTENSION); | ||||
|           if(!$content_type && $extension === '.jsonld') { | ||||
|             $content_type = 'application/ld+json'; | ||||
|           } | ||||
|           $link_header = $options->httpLink; | ||||
|           if(is_array($link_header)) { | ||||
|             $link_header = join(',', $link_header); | ||||
|           } | ||||
|           $link_header = jsonld_parse_link_header( | ||||
|             $link_header)['http://www.w3.org/ns/json-ld#context'] ?: null; | ||||
|           if($link_header && $content_type !== 'application/ld+json') { | ||||
|             if(is_array($link_header)) { | ||||
|               throw new Exception('multiple context link headers'); | ||||
|             } | ||||
|             $doc->{'contextUrl'} = $link_header['target']; | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|       global $ROOT_MANIFEST_DIR; | ||||
|       $filename = $ROOT_MANIFEST_DIR . | ||||
|         substr($doc->{'documentUrl'}, strlen($base)); | ||||
|       try { | ||||
|         $doc->{'document'} = Util::readJson($filename); | ||||
|       } | ||||
|       catch(Exception $e) { | ||||
|         throw new Exception('loading document failed'); | ||||
|       } | ||||
|       return $doc; | ||||
|     }; | ||||
| 
 | ||||
|     $local_loader = function($url) use ($loader, $load_locally) { | ||||
|       // always load remote-doc and non-base tests remotely
 | ||||
|       /*if(strpos($url, $base) !== 0 || | ||||
|         $test->manifest->data['name'] === 'Remote document') { | ||||
|         return call_user_func($loader, $url); | ||||
|       }*/ | ||||
| 
 | ||||
|       // attempt to load locally
 | ||||
|       return call_user_func($load_locally, $url); | ||||
|     }; | ||||
| 
 | ||||
|     return $local_loader; | ||||
|   } | ||||
| 
 | ||||
|   public function getJsonLdErrorCode($err) { | ||||
|     if($err instanceof JsonLdException) { | ||||
|       if($err->getCode()) { | ||||
|         return $err->getCode(); | ||||
|       } | ||||
|       if($err->cause) { | ||||
|         return $this->getJsonLdErrorCode($err); | ||||
|       } | ||||
|     } | ||||
|     return $err->getMessage(); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| class JsonLdTestIterator implements Iterator { | ||||
|   /** | ||||
|    * The current test index. | ||||
|    */ | ||||
|   protected $index = 0; | ||||
| 
 | ||||
|   /** | ||||
|    * The total number of tests. | ||||
|    */ | ||||
|   protected $count = 0; | ||||
| 
 | ||||
|   /** | ||||
|    * Creates a TestIterator. | ||||
|    * | ||||
|    * @param string $type the type of tests to iterate over. | ||||
|    */ | ||||
|   public function __construct($type) { | ||||
|     global $TESTS; | ||||
|     if(isset($TESTS[$type])) { | ||||
|       $this->tests = $TESTS[$type]; | ||||
|     } | ||||
|     else { | ||||
|       $this->tests = array(); | ||||
|     } | ||||
|     $this->count = count($this->tests); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Gets the parameters for the next test. | ||||
|    * | ||||
|    * @return assoc the parameters for the next test. | ||||
|    */ | ||||
|   public function current() { | ||||
|     return array('test' => $this->tests[$this->index]); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Gets the current test number. | ||||
|    * | ||||
|    * @return int the current test number. | ||||
|    */ | ||||
|   public function key() { | ||||
|     return $this->index; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Proceeds to the next test. | ||||
|    */ | ||||
|   public function next() { | ||||
|     $this->index += 1; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Rewinds to the first test. | ||||
|    */ | ||||
|   public function rewind() { | ||||
|     $this->index = 0; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Returns true if there are more tests to be run. | ||||
|    * | ||||
|    * @return bool true if there are more tests to be run. | ||||
|    */ | ||||
|   public function valid() { | ||||
|     return $this->index < $this->count; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| class EarlReport implements PHPUnit_Framework_TestListener { | ||||
|   public function __construct() { | ||||
|     $this->result = null; | ||||
|     $this->report = (object)array( | ||||
|       '@context' => (object)array( | ||||
|         'doap' => 'http://usefulinc.com/ns/doap#', | ||||
|         'foaf' => 'http://xmlns.com/foaf/0.1/', | ||||
|         'dc' => 'http://purl.org/dc/terms/', | ||||
|         'earl' => 'http://www.w3.org/ns/earl#', | ||||
|         'xsd' => 'http://www.w3.org/2001/XMLSchema#', | ||||
|         'doap:homepage' => (object)array('@type' => '@id'), | ||||
|         'doap:license' => (object)array('@type' => '@id'), | ||||
|         'dc:creator' => (object)array('@type' => '@id'), | ||||
|         'foaf:homepage' => (object)array('@type' => '@id'), | ||||
|         'subjectOf' => (object)array('@reverse' => 'earl:subject'), | ||||
|         'earl:assertedBy' => (object)array('@type' => '@id'), | ||||
|         'earl:mode' => (object)array('@type' => '@id'), | ||||
|         'earl:test' => (object)array('@type' => '@id'), | ||||
|         'earl:outcome' => (object)array('@type' => '@id'), | ||||
|         'dc:date' => (object)array('@type' => 'xsd:date') | ||||
|       ), | ||||
|       '@id' => 'https://github.com/digitalbazaar/php-json-ld', | ||||
|       '@type' => array('doap:Project', 'earl:TestSubject', 'earl:Software'), | ||||
|       'doap:name' => 'php-json-ld', | ||||
|       'dc:title' => 'php-json-ld', | ||||
|       'doap:homepage' => 'https://github.com/digitalbazaar/php-json-ld', | ||||
|       'doap:license' => 'https://github.com/digitalbazaar/php-json-ld/blob/master/LICENSE', | ||||
|       'doap:description' => 'A JSON-LD processor for PHP', | ||||
|       'doap:programming-language' => 'PHP', | ||||
|       'dc:creator' => 'https://github.com/dlongley', | ||||
|       'doap:developer' => (object)array( | ||||
|         '@id' => 'https://github.com/dlongley', | ||||
|         '@type' => array('foaf:Person', 'earl:Assertor'), | ||||
|         'foaf:name' => 'Dave Longley', | ||||
|         'foaf:homepage' => 'https://github.com/dlongley' | ||||
|       ), | ||||
|       'dc:date' => array( | ||||
|         '@value' => gmdate('Y-m-d'), | ||||
|         '@type' => 'xsd:date' | ||||
|       ), | ||||
|       'subjectOf' => array() | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Attaches to the given test result, if not yet attached. | ||||
|    * | ||||
|    * @param PHPUnit_Framework_Test $result the result to attach to. | ||||
|    */ | ||||
|   public function attach(PHPUnit_Framework_TestResult $result) { | ||||
|     if(!$this->result) { | ||||
|       $this->result = $result; | ||||
|       $result->addListener($this); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Adds an assertion to this EARL report. | ||||
|    * | ||||
|    * @param JsonLdTest $test the JsonLdTest for the assertion is for. | ||||
|    * @param bool $passed whether or not the test passed. | ||||
|    */ | ||||
|   public function addAssertion($test, $passed) { | ||||
|     $this->report->{'subjectOf'}[] = (object)array( | ||||
|       '@type' => 'earl:Assertion', | ||||
|       'earl:assertedBy' => $this->report->{'doap:developer'}->{'@id'}, | ||||
|       'earl:mode' => 'earl:automatic', | ||||
|       'earl:test' => $test->data->{'@id'}, | ||||
|       'earl:result' => (object)array( | ||||
|         '@type' => 'earl:TestResult', | ||||
|         'dc:date' => gmdate(DateTime::ISO8601), | ||||
|         'earl:outcome' => $passed ? 'earl:passed' : 'earl:failed' | ||||
|       ) | ||||
|     ); | ||||
|     return $this; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Writes this EARL report to a file. | ||||
|    * | ||||
|    * @param string $filename the name of the file to write to. | ||||
|    */ | ||||
|   public function write($filename) { | ||||
|     $fd = fopen($filename, 'w'); | ||||
|     fwrite($fd, Util::jsonldEncode($this->report)); | ||||
|     fclose($fd); | ||||
|   } | ||||
| 
 | ||||
|   public function endTest(PHPUnit_Framework_Test $test, $time) { | ||||
|     $this->addAssertion($test->test, true); | ||||
|   } | ||||
| 
 | ||||
|   public function addError( | ||||
|     PHPUnit_Framework_Test $test, Exception $e, $time) { | ||||
|     $this->addAssertion($test->test, false); | ||||
|   } | ||||
| 
 | ||||
|   public function addFailure( | ||||
|     PHPUnit_Framework_Test $test, | ||||
|     PHPUnit_Framework_AssertionFailedError $e, $time) { | ||||
|     $this->addAssertion($test->test, false); | ||||
|     if($this->result->shouldStop()) { | ||||
|       printf("\nFAILED Test: %s\n", $test->test->name); | ||||
|       printf("EXPECTED: %s\n", Util::jsonldEncode($test->test->expected)); | ||||
|       printf("ACTUAL: %s\n", Util::jsonldEncode($test->test->actual)); | ||||
|       exit(0); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   public function addIncompleteTest( | ||||
|     PHPUnit_Framework_Test $test, Exception $e, $time) { | ||||
|     $this->addAssertion($test->test, false); | ||||
|   } | ||||
| 
 | ||||
|   public function addSkippedTest( | ||||
|     PHPUnit_Framework_Test $test, Exception $e, $time) { | ||||
|     printf("Test '%s' has been skipped.\n", $test->test->data->{'@id'}); | ||||
|   } | ||||
| 
 | ||||
|   public function startTest(PHPUnit_Framework_Test $test) {} | ||||
|   public function startTestSuite(PHPUnit_Framework_TestSuite $suite) {} | ||||
|   public function endTestSuite(PHPUnit_Framework_TestSuite $suite) {} | ||||
| } | ||||
| 
 | ||||
| class Util { | ||||
|   public static function readFile($filename) { | ||||
|     return file_get_contents($filename); | ||||
|   } | ||||
| 
 | ||||
|   public static function readJson($filename) { | ||||
|     return json_decode(file_get_contents($filename)); | ||||
|   } | ||||
| 
 | ||||
|   public static function readNQuads($filename) { | ||||
|     return readFile($filename); | ||||
|   } | ||||
| 
 | ||||
|   public static function jsonldEncode($input) { | ||||
|     // newer PHP has a flag to avoid escaped '/'
 | ||||
|     if(defined('JSON_UNESCAPED_SLASHES')) { | ||||
|       $options = JSON_UNESCAPED_SLASHES; | ||||
|       if(defined('JSON_PRETTY_PRINT')) { | ||||
|         $options |= JSON_PRETTY_PRINT; | ||||
|       } | ||||
|       $json = json_encode($input, $options); | ||||
|     } | ||||
|     else { | ||||
|       // use a simple string replacement of '\/' to '/'.
 | ||||
|       $json = str_replace('\\/', '/', json_encode($input)); | ||||
|     } | ||||
|     return $json; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| // tests to skip
 | ||||
| $SKIP_TESTS = array(); | ||||
| 
 | ||||
| // root manifest directory
 | ||||
| $ROOT_MANIFEST_DIR; | ||||
| 
 | ||||
| // parsed tests; keyed by type
 | ||||
| $TESTS = array(); | ||||
| 
 | ||||
| // parsed command line options
 | ||||
| $OPTIONS = array(); | ||||
| 
 | ||||
| // EARL Report
 | ||||
| $EARL = new EarlReport(); | ||||
| 
 | ||||
| // parse command line options
 | ||||
| global $argv; | ||||
| $args = $argv; | ||||
| $total = count($args); | ||||
| $start = false; | ||||
| for($i = 0; $i < $total; ++$i) { | ||||
|   $arg = $args[$i]; | ||||
|   if(!$start) { | ||||
|     if(realpath($arg) === realpath(__FILE__)) { | ||||
|       $start = true; | ||||
|     } | ||||
|     continue; | ||||
|   } | ||||
|   if($arg[0] !== '-') { | ||||
|     break; | ||||
|   } | ||||
|   $i += 1; | ||||
|   $OPTIONS[$arg] = $args[$i]; | ||||
| } | ||||
| if(!isset($OPTIONS['-d'])) { | ||||
|   $dvar = 'path to json-ld.org/test-suite'; | ||||
|   $evar = 'file to write EARL report to'; | ||||
|   echo "php-json-ld Tests\n"; | ||||
|   echo "Usage: phpunit test.php -d <$dvar> [-e <$evar>]\n\n"; | ||||
|   exit(0); | ||||
| } | ||||
| 
 | ||||
| // load root manifest
 | ||||
| $ROOT_MANIFEST_DIR = realpath($OPTIONS['-d']); | ||||
| $filename = join( | ||||
|   DIRECTORY_SEPARATOR, array($ROOT_MANIFEST_DIR, 'manifest.jsonld')); | ||||
| $root_manifest = Util::readJson($filename); | ||||
| $manifest = new JsonLdManifest($root_manifest, $filename); | ||||
| $manifest->load($TESTS); | ||||
| 
 | ||||
| /* end of file, omit ?> */ | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue