1 | <?PHP
|
---|
2 |
|
---|
3 | /* RDFInt.php - RDF Interfaces for PHP
|
---|
4 | * Copyright 2011 netlabs.org
|
---|
5 | * Author: Christian Langanke, Adrian Gschwend
|
---|
6 | *
|
---|
7 | * Licensed under the Apache License, Version 2.0 (the "License");
|
---|
8 | * you may not use this file except in compliance with the License.
|
---|
9 | * You may obtain a copy of the License at
|
---|
10 | *
|
---|
11 | * http://www.apache.org/licenses/LICENSE-2.0
|
---|
12 | *
|
---|
13 | * Unless required by applicable law or agreed to in writing, software
|
---|
14 | * distributed under the License is distributed on an "AS IS" BASIS,
|
---|
15 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
---|
16 | * See the License for the specific language governing permissions and
|
---|
17 | * limitations under the License.
|
---|
18 | */
|
---|
19 |
|
---|
20 | // load library setup
|
---|
21 | define( 'RDFINT', getenv( 'PHP_LIBROOT_RDFINT'));
|
---|
22 | define( 'FDEBUG_SESSION_NAME', 'RDF Test Cases Unittest');
|
---|
23 | require_once( RDFINT.'/rdfa.php');
|
---|
24 | require_once( 'rdftestcases.php');
|
---|
25 |
|
---|
26 | class UnitTest extends PHPUnit_Framework_TestCase {
|
---|
27 |
|
---|
28 | static protected $manifest;
|
---|
29 |
|
---|
30 | // --------------------------------------------------------
|
---|
31 |
|
---|
32 | // rune once initializer
|
---|
33 | public static function setUpBeforeClass() {
|
---|
34 |
|
---|
35 | // create manifest data object
|
---|
36 | self::$manifest = new RDFTestCasesManifest;
|
---|
37 |
|
---|
38 | }
|
---|
39 |
|
---|
40 | // --------------------------------------------------------
|
---|
41 |
|
---|
42 | // helper: adjusts serialization results so that comparison can work
|
---|
43 | // - make all blank node identifiers unique
|
---|
44 | // - sort the n-triple lines
|
---|
45 | private function _refineResult( $data) {
|
---|
46 | // replace all blank nodes by one ID
|
---|
47 | // NOTE: thi sis not accurate, but not much better
|
---|
48 | // possible without access to the triple data
|
---|
49 | $data = preg_replace( '/_:[^ ]*/', '_:a', $data);
|
---|
50 |
|
---|
51 | // sort the data
|
---|
52 | $adata = explode( "\n", $data);
|
---|
53 | sort( &$adata);
|
---|
54 | $data = implode( "\n", $adata);
|
---|
55 |
|
---|
56 | return $data;
|
---|
57 | }
|
---|
58 |
|
---|
59 | // --------------------------------------------------------
|
---|
60 | // helper: write input and output data to new output
|
---|
61 | // directory for manual examination
|
---|
62 | private function _writeErrorData( $testcase, $source, $result) {
|
---|
63 | if (!is_dir( $testcase->name))
|
---|
64 | mkdir( $testcase->name, NULL, true);
|
---|
65 |
|
---|
66 | $orgsource = file_get_contents( $testcase->input);
|
---|
67 | file_put_contents ( $testcase->name."/org_source.txt" , $orgsource);
|
---|
68 |
|
---|
69 | $orgresult = file_get_contents( $testcase->output);
|
---|
70 | file_put_contents ( $testcase->name."/org_result.txt" , $orgresult);
|
---|
71 |
|
---|
72 | file_put_contents ( $testcase->name."/parsed_source.txt" , $source);
|
---|
73 | file_put_contents ( $testcase->name."/parsed_result.txt" , $result);
|
---|
74 | }
|
---|
75 |
|
---|
76 | // --------------------------------------------------------
|
---|
77 |
|
---|
78 | // helper: serialize data from URI to N3
|
---|
79 | private function _getSerializedData( $uri) {
|
---|
80 |
|
---|
81 | $rdfaData = new \rdfa\Data();
|
---|
82 | $this->assertInstanceOf( '\rdfa\Data', $rdfaData);
|
---|
83 | $rdfaData->parse( $uri);
|
---|
84 | return $rdfaData->_serialize( 'n3');
|
---|
85 |
|
---|
86 | } // private function _getSerializedData
|
---|
87 |
|
---|
88 | // --------------------------------------------------------
|
---|
89 |
|
---|
90 | public function _executePositiveParserTest( $testcase) {
|
---|
91 |
|
---|
92 | // read source data
|
---|
93 | $source = $this->_getSerializedData( $testcase->input);
|
---|
94 | $this->assertEquals( ($source !== false), true);
|
---|
95 |
|
---|
96 | // read target data
|
---|
97 | $result = $this->_getSerializedData( $testcase->output);
|
---|
98 | $this->assertEquals( ($result !== false), true);
|
---|
99 |
|
---|
100 | // resolve problems with blnak node identifiers
|
---|
101 | // and different sorting of triples
|
---|
102 | $source = $this->_refineResult( $source);
|
---|
103 | $result = $this->_refineResult( $result);
|
---|
104 |
|
---|
105 | // check if results are equal
|
---|
106 | $success = ($source == $result);
|
---|
107 |
|
---|
108 | // in case of error, write serialized data to subdirectory
|
---|
109 | if (!$success)
|
---|
110 | $this->_writeErrorData( $testcase,
|
---|
111 | $source,
|
---|
112 | $result);
|
---|
113 |
|
---|
114 | // compare source and target data
|
---|
115 | $this->assertEquals( $success, true);
|
---|
116 |
|
---|
117 | } // public function test_parse_sparql()
|
---|
118 |
|
---|
119 |
|
---|
120 | // --------------------------------------------------------
|
---|
121 |
|
---|
122 | public function test() {
|
---|
123 |
|
---|
124 | $category = trim( getenv( 'CATEGORY'));
|
---|
125 | if ($category == '')
|
---|
126 | $categories = self::$manifest->getCategories();
|
---|
127 | else
|
---|
128 | $categories = array( $type);
|
---|
129 |
|
---|
130 | // run test
|
---|
131 | // NOTE: all assertions are made in the specific test routine
|
---|
132 | foreach ($categories as $category) {
|
---|
133 | echo "\nExecuting RDF Test Cases of category: $category\n\n";
|
---|
134 | $testcases = self::$manifest->getParserTests( $category);
|
---|
135 | foreach ($testcases as $testcase) {
|
---|
136 |
|
---|
137 | echo " Executing: " . $testcase->name . "\n";
|
---|
138 | switch ($category) {
|
---|
139 | case 'PositiveParserTest':
|
---|
140 | $result = $this->_executePositiveParserTest( $testcase);
|
---|
141 | break;
|
---|
142 | } // switch ($category)
|
---|
143 | }
|
---|
144 | }
|
---|
145 |
|
---|
146 | } // public function test
|
---|
147 |
|
---|
148 | // --------------------------------------------------------
|
---|
149 |
|
---|
150 | public function disabled_test() {
|
---|
151 |
|
---|
152 | // get testcase name again in object context
|
---|
153 | $testcase = trim( getenv( 'TESTCASE'));
|
---|
154 | $this->assertGreaterThan( 0, strlen( $testcase));
|
---|
155 |
|
---|
156 | // read source data
|
---|
157 | $sourceuri = self::BASEURI."/$testcase.rdf";
|
---|
158 | $source = $this->_getSerializedData( $sourceuri);
|
---|
159 | $this->assertEquals( ($source !== false), true);
|
---|
160 |
|
---|
161 | // read target data
|
---|
162 | $resulturi = self::BASEURI."/$testcase.nt";
|
---|
163 | $result = $this->_getSerializedData( $resulturi);
|
---|
164 | $this->assertEquals( ($result !== false), true);
|
---|
165 |
|
---|
166 | // resolve problems with blnak node identifiers
|
---|
167 | // and different sorting of triples
|
---|
168 | $source = $this->_refineResult( $source);
|
---|
169 | $result = $this->_refineResult( $result);
|
---|
170 |
|
---|
171 | // check if results are equal
|
---|
172 | $success = ($source == $result);
|
---|
173 |
|
---|
174 | // in case of error, write serialized data to subdirectory
|
---|
175 | if (!$success)
|
---|
176 | $this->_writeErrorData( $testcase,
|
---|
177 | $source, $sourceuri,
|
---|
178 | $result, $resulturi);
|
---|
179 |
|
---|
180 | // compare source and target data
|
---|
181 | $this->assertEquals( $success, true);
|
---|
182 |
|
---|
183 |
|
---|
184 | } // public function test_parse_sparql()
|
---|
185 |
|
---|
186 |
|
---|
187 | // --------------------------------------------------------
|
---|
188 |
|
---|
189 | public function _dumpTestcaseInfo( $testcases) {
|
---|
190 | foreach ($testcases as $testcase) {
|
---|
191 | echo "=====================================================================\n";
|
---|
192 | echo 'URI: ' . $testcase->getSubject() . "\n";
|
---|
193 | echo 'Input: ' . $testcase->input . "\n";
|
---|
194 | echo 'Output: ' . $testcase->output . "\n";
|
---|
195 | echo 'Conclusion: ' . $testcase->conclusion . "\n";
|
---|
196 | }
|
---|
197 | }
|
---|
198 |
|
---|
199 |
|
---|
200 | } // class UnitTest
|
---|
201 |
|
---|
202 |
|
---|