source: php/trunk/unittest/rdftestcases/unittest.php@ 75

Last change on this file since 75 was 65, checked in by cla, 14 years ago

rdfint

  • added execution of positive parser tests
  • added exception list
  • Property svn:eol-style set to native
File size: 6.2 KB
Line 
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
21define( 'RDFINT', getenv( 'PHP_LIBROOT_RDFINT'));
22define( 'FDEBUG_SESSION_NAME', 'RDF Test Cases Unittest');
23require_once( RDFINT.'/rdfa.php');
24require_once( 'rdftestcases.php');
25
26class 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
Note: See TracBrowser for help on using the repository browser.