1
2/*
3Copyright é 2001-2004 World Wide Web Consortium,
4(Massachusetts Institute of Technology, European Research Consortium
5for Informatics and Mathematics, Keio University). All
6Rights Reserved. This work is distributed under the W3Cî Software License [1] in the
7hope that it will be useful, but WITHOUT ANY WARRANTY; without even
8the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
9
10[1] http://www.w3.org/Consortium/Legal/2002/copyright-software-20021231
11*/
12
13
14
15   /**
16    *  Gets URI that identifies the test.
17    *  @return uri identifier of test
18    */
19function getTargetURI() {
20      return "http://www.w3.org/2001/DOM-Test-Suite/level3/core/domconfigerrorhandler1";
21   }
22
23var docsLoaded = -1000000;
24var builder = null;
25
26//
27//   This function is called by the testing framework before
28//      running the test suite.
29//
30//   If there are no configuration exceptions, asynchronous
31//        document loading is started.  Otherwise, the status
32//        is set to complete and the exception is immediately
33//        raised when entering the body of the test.
34//
35function setUpPage() {
36   setUpPageStatus = 'running';
37   try {
38     //
39     //   creates test document builder, may throw exception
40     //
41     builder = createConfiguredBuilder();
42
43      docsLoaded = 0;
44
45       if (docsLoaded == 0) {
46          setUpPageStatus = 'complete';
47       }
48    } catch(ex) {
49    	catchInitializationError(builder, ex);
50        setUpPageStatus = 'complete';
51    }
52}
53
54
55
56//
57//   This method is called on the completion of
58//      each asychronous load started in setUpTests.
59//
60//   When every synchronous loaded document has completed,
61//      the page status is changed which allows the
62//      body of the test to be executed.
63function loadComplete() {
64    if (++docsLoaded == 0) {
65        setUpPageStatus = 'complete';
66    }
67}
68
69
70     /**
71      *    Inner class implementation for variable errorHandler
72      */
73var errorHandler;
74
75/**
76        * Constructor
77
78        */
79
80function DOMErrorHandlerN10049() {
81           }
82
83        /**
84         *
85This method is called on the error handler when an error occurs.
86If an exception is thrown from this method, it is considered to be equivalent of returningtrue.
87
88         * @param error
89The error object that describes the error. This object may be reused by the DOM implementation across multiple calls to thehandleErrormethod.
90
91         */
92DOMErrorHandlerN10049.prototype.handleError = function(error) {
93         //
94         //   bring class variables into function scope
95         //
96                return true;
97}
98
99/**
100* Checks behavior of "error-handler" configuration parameter.
101* @author Curt Arnold
102* @see http://www.w3.org/TR/2004/REC-DOM-Level-3-Core-20040407/core#parameter-error-handler
103* @see http://www.w3.org/TR/2004/REC-DOM-Level-3-Core-20040407/core#DOMConfiguration-getParameter
104* @see http://www.w3.org/TR/2004/REC-DOM-Level-3-Core-20040407/core#DOMConfiguration-setParameter
105* @see http://www.w3.org/Bugs/Public/show_bug.cgi?id=544
106*/
107function domconfigerrorhandler1() {
108   var success;
109    if(checkInitialization(builder, "domconfigerrorhandler1") != null) return;
110    var domImpl;
111      var doc;
112      var domConfig;
113      var nullDocType = null;
114
115      var canSet;
116      var origHandler;
117      var state;
118      var parameter = "eRrOr-handler";
119      errorHandler = new DOMErrorHandlerN10049();
120
121      domImpl = getImplementation();
122doc = domImpl.createDocument("http://www.w3.org/1999/xhtml","html",nullDocType);
123      domConfig = doc.domConfig;
124
125      origHandler = domConfig.getParameter(parameter);
126      canSet = domConfig.canSetParameter(parameter,errorHandler);
127      assertTrue("canSetNewHandler",canSet);
128canSet = domConfig.canSetParameter(parameter,origHandler);
129      assertTrue("canSetOrigHandler",canSet);
130domConfig.setParameter(parameter, errorHandler.handleError);
131	 state = domConfig.getParameter(parameter);
132      assertSame("setToNewHandlerEffective",errorHandler,state);
133domConfig.setParameter(parameter, origHandler.handleError);
134	 state = domConfig.getParameter(parameter);
135      assertSame("setToOrigHandlerEffective",origHandler,state);
136canSet = domConfig.canSetParameter(parameter,true);
137
138	if(
139	canSet
140	) {
141	domConfig.setParameter(parameter, true);
142
143	}
144
145}
146
147
148
149
150function runTest() {
151   domconfigerrorhandler1();
152}
153