|
1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN""http://www.w3.org/TR/html4/strict.dtd"> |
|
2 <html> |
|
3 <head> |
|
4 <META http-equiv="Content-Type" content="text/html; charset=UTF-8"> |
|
5 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> |
|
6 <title>http://www.w3.org/2001/DOM-Test-Suite/level2/core/domimplementationhasfeature01</title> |
|
7 <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"> |
|
8 <script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script> |
|
9 <script type="text/javascript" src="DOMTestCase.js"></script> |
|
10 <script type="text/javascript" src="exclusions.js"></script> |
|
11 <script type="text/javascript"> |
|
12 // expose test function names |
|
13 function exposeTestFunctionNames() |
|
14 { |
|
15 return ['domimplementationhasfeature01']; |
|
16 } |
|
17 |
|
18 var docsLoaded = -1000000; |
|
19 var builder = null; |
|
20 |
|
21 // |
|
22 // This function is called by the testing framework before |
|
23 // running the test suite. |
|
24 // |
|
25 // If there are no configuration exceptions, asynchronous |
|
26 // document loading is started. Otherwise, the status |
|
27 // is set to complete and the exception is immediately |
|
28 // raised when entering the body of the test. |
|
29 // |
|
30 function setUpPage() { |
|
31 setUpPageStatus = 'running'; |
|
32 try { |
|
33 // |
|
34 // creates test document builder, may throw exception |
|
35 // |
|
36 builder = createConfiguredBuilder(); |
|
37 |
|
38 docsLoaded = 0; |
|
39 |
|
40 var docRef = null; |
|
41 if (typeof(this.doc) != 'undefined') { |
|
42 docRef = this.doc; |
|
43 } |
|
44 docsLoaded += preload(docRef, "doc", "staffNS"); |
|
45 |
|
46 if (docsLoaded == 1) { |
|
47 setUpPage = 'complete'; |
|
48 } |
|
49 } catch(ex) { |
|
50 catchInitializationError(builder, ex); |
|
51 setUpPage = 'complete'; |
|
52 } |
|
53 } |
|
54 |
|
55 // |
|
56 // This method is called on the completion of |
|
57 // each asychronous load started in setUpTests. |
|
58 // |
|
59 // When every synchronous loaded document has completed, |
|
60 // the page status is changed which allows the |
|
61 // body of the test to be executed. |
|
62 function loadComplete() { |
|
63 if (++docsLoaded == 1) { |
|
64 setUpPageStatus = 'complete'; |
|
65 runJSUnitTests(); |
|
66 markTodos(); |
|
67 SimpleTest.finish(); |
|
68 } |
|
69 } |
|
70 |
|
71 var docName = 'domimplementationhasfeature01'; |
|
72 |
|
73 |
|
74 /** |
|
75 * |
|
76 The method "hasFeature(feature,version)" tests if the DOMImplementation implements |
|
77 a specific feature and if so returns true. |
|
78 |
|
79 Call the hasFeature method on this DOMImplementation with a combination of features |
|
80 versions as below. Valid feature names are case insensitive and versions "2.0", |
|
81 "1.0" and if the version is not specified, supporting any version of the feature |
|
82 should return true. Check if the value returned value was true. |
|
83 |
|
84 * @author IBM |
|
85 * @author Neil Delima |
|
86 * @see http://www.w3.org/TR/DOM-Level-2-Core/core#ID-5CED94D7 |
|
87 */ |
|
88 function domimplementationhasfeature01() { |
|
89 var success; |
|
90 if(checkInitialization(builder, "domimplementationhasfeature01") != null) return; |
|
91 var doc; |
|
92 var domImpl; |
|
93 var version = ""; |
|
94 var version1 = "1.0"; |
|
95 var version2 = "2.0"; |
|
96 var featureCore; |
|
97 var featureXML; |
|
98 var success; |
|
99 featuresXML = new Array(); |
|
100 featuresXML[0] = "XML"; |
|
101 featuresXML[1] = "xmL"; |
|
102 |
|
103 featuresCore = new Array(); |
|
104 featuresCore[0] = "Core"; |
|
105 featuresCore[1] = "CORE"; |
|
106 |
|
107 |
|
108 var docRef = null; |
|
109 if (typeof(this.doc) != 'undefined') { |
|
110 docRef = this.doc; |
|
111 } |
|
112 doc = load(docRef, "doc", "staffNS"); |
|
113 domImpl = doc.implementation; |
|
114 for(var indexN65635 = 0;indexN65635 < featuresXML.length; indexN65635++) { |
|
115 featureXML = featuresXML[indexN65635]; |
|
116 success = domImpl.hasFeature(featureXML,version); |
|
117 assertTrue("domimplementationhasfeature01_XML_1",success); |
|
118 success = domImpl.hasFeature(featureXML,version1); |
|
119 assertTrue("domimplementationhasfeature01_XML_2",success); |
|
120 |
|
121 } |
|
122 for(var indexN65660 = 0;indexN65660 < featuresCore.length; indexN65660++) { |
|
123 featureCore = featuresCore[indexN65660]; |
|
124 success = domImpl.hasFeature(featureCore,version); |
|
125 assertTrue("domimplementationhasfeature01_Core_1",success); |
|
126 success = domImpl.hasFeature(featureCore,version1); |
|
127 success = domImpl.hasFeature(featureCore,version2); |
|
128 assertTrue("domimplementationhasfeature01_Core_3",success); |
|
129 |
|
130 } |
|
131 |
|
132 } |
|
133 |
|
134 </script> |
|
135 </head> |
|
136 <body> |
|
137 <h2>Test http://www.w3.org/2001/DOM-Test-Suite/level2/core/domimplementationhasfeature01</h2> |
|
138 <p></p> |
|
139 <p> |
|
140 Copyright (c) 2001-2004 World Wide Web Consortium, |
|
141 (Massachusetts Institute of Technology, European Research Consortium |
|
142 for Informatics and Mathematics, Keio University). All |
|
143 Rights Reserved. This work is distributed under the <a href="http://www.w3.org/Consortium/Legal/2002/copyright-software-20021231">W3C(r) Software License</a> in the |
|
144 hope that it will be useful, but WITHOUT ANY WARRANTY; without even |
|
145 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
|
146 </p> |
|
147 </body> |
|
148 </html> |