2 * This file is part of the LibreOffice project.
4 * This Source Code Form is subject to the terms of the Mozilla Public
5 * License, v. 2.0. If a copy of the MPL was not distributed with this
6 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8 * This file incorporates work covered by the following license notice:
10 * Licensed to the Apache Software Foundation (ASF) under one or more
11 * contributor license agreements. See the NOTICE file distributed
12 * with this work for additional information regarding copyright
13 * ownership. The ASF licenses this file to you under the Apache
14 * License, Version 2.0 (the "License"); you may not use this file
15 * except in compliance with the License. You may obtain a copy of
16 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
21 import lib
.MultiMethodTest
;
23 import lib
.StatusException
;
25 import com
.sun
.star
.lang
.XMultiServiceFactory
;
26 import com
.sun
.star
.ucb
.ContentProviderInfo
;
27 import com
.sun
.star
.ucb
.DuplicateProviderException
;
28 import com
.sun
.star
.ucb
.XContentProvider
;
29 import com
.sun
.star
.ucb
.XContentProviderManager
;
30 import com
.sun
.star
.uno
.Exception
;
31 import com
.sun
.star
.uno
.UnoRuntime
;
34 * Tests XContentProviderManager. The test registers two ContentProviders, calls
35 * queryXXX methods to verify results, and deregisters them.
37 * Testing <code>com.sun.star.ucb.XContentProviderManager</code>
40 * <li><code> registerContentProvider()</code></li>
41 * <li><code> deregisterContentProvider()</code></li>
42 * <li><code> queryContentProviders()</code></li>
43 * <li><code> queryContentProvider()</code></li>
45 * The test registers two ContentProviders, calls
46 * queryXXX methods to verify results, and deregisters them. <p>
48 * Test is <b> NOT </b> multithread compliant. <p>
49 * @see com.sun.star.ucb.XContentProviderManager
51 public class _XContentProviderManager
extends MultiMethodTest
{
53 * Contains the tested object.
55 public XContentProviderManager oObj
;
58 * The test scheme name.
60 static final String myScheme
= "test-scheme";
63 * Any preexisting content provider. If it exists it will be hidden by
64 * <code>firstContentProvider</code>, registered with the same
65 * <code>myScheme</code>. Typically there is no preexisting content
66 * provider, unless the catch-all providers GnomeVFSContentProvider or
67 * GIOContentProvider is installed
69 XContentProvider preexistingContentProvider
;
72 * First content provider. It will be hidden by <code>contentProvider
73 * </code>, registered with the same <code>myScheme</code> to test
74 * the "hiding" behaviour.
76 XContentProvider firstContentProvider
;
79 * The main content provider.
81 XContentProvider contentProvider
;
84 * <code>ContentProvider</code>s information which are in the manager
85 * before registering the testing providers.
87 ContentProviderInfo
[] initialProvidersInfo
;
90 * Creates two testing providers.
92 * @see #firstContentProvider
93 * @see #contentProvider
96 public void before() {
97 XMultiServiceFactory xMSF
= tParam
.getMSF();
99 log
.println("creating testing content providers");
101 firstContentProvider
= UnoRuntime
.queryInterface(
102 XContentProvider
.class, xMSF
.createInstance(
103 "com.sun.star.ucb.FileContentProvider"));
105 contentProvider
= UnoRuntime
.queryInterface(
106 XContentProvider
.class, xMSF
.createInstance(
107 "com.sun.star.ucb.FileContentProvider"));
108 } catch (Exception e
) {
109 log
.println("Can't create content providers " + e
.getMessage());
110 e
.printStackTrace(log
);
111 throw new StatusException("Unexpected exception", e
);
116 * At the beginning call <code>queryContentProviders</code> method
118 * to have info about providers existing before new adding.
119 * It adds two testing contents providers, both for the same scheme.
120 * The second one is added two times: first, in non-replacing mode, to test
121 * <code>DuplicateProviderException</code>, and second, in replacing mode,
122 * to hide the first provider. <p>
124 * The evaluation of results are performed later, in
125 * <code>queryContentProvider()</code>.
127 * Has <b> OK </b> status if in the first provider is registered
128 * without exceptions, the second throws
129 * <code>DuplicateProviderException</code> in non-replacing mode,
130 * and no exceptions in replacing mode. <p>
132 * @see #_queryContentProvider
134 public void _registerContentProvider() {
135 // querying providfers info before inserting them, to verify results
136 initialProvidersInfo
= oObj
.queryContentProviders();
138 // GnomeVFSContentProvider or GIOContentProvider ?, typically null
139 preexistingContentProvider
= oObj
.queryContentProvider(myScheme
);
141 log
.println("registering the first provider");
143 oObj
.registerContentProvider(firstContentProvider
, myScheme
,false);
144 } catch (DuplicateProviderException e
) {
145 log
.println("Unexpected exception thrown " + e
.getMessage());
146 e
.printStackTrace(log
);
147 throw new StatusException("Unexpected exception ", e
);
150 log
.println("registering the second provider in non-replacing mode");
152 oObj
.registerContentProvider(contentProvider
, myScheme
, false);
153 Status
.failed("registerContentProvider(.., .., false)");
154 } catch (DuplicateProviderException e
) {
155 log
.println("DuplicateProviderException thrown - OK");
158 XContentProvider result
;
160 log
.println("registering the second provider in the replace mode");
162 result
= oObj
.registerContentProvider(contentProvider
, myScheme
, true);
163 } catch (DuplicateProviderException e
) {
164 log
.println("Unexpected exception thrown " + e
.getMessage());
165 e
.printStackTrace(log
);
166 throw new StatusException("Unexpected exception ", e
);
169 // check the result is the first provider
170 tRes
.tested("registerContentProvider()",
171 result
.equals(firstContentProvider
));
175 * It calls the method (after registering providers) and compares
176 * its result with the result before registering.
178 * Has <b> OK </b> status if the number of providers increases
179 * by one after registering custom provider.
181 * The following method tests are to be completed successfully before :
183 * <li> <code> registerContentProvider() </code> : to compare number
184 * of providers. </li>
186 * @see #_registerContentProvider
188 public void _queryContentProviders() {
189 executeMethod("registerContentProvider()");
191 ContentProviderInfo
[] providersInfo
= oObj
.queryContentProviders();
192 // verifying that the number of providers increased by 1
193 tRes
.tested("queryContentProviders()",
194 providersInfo
.length
== initialProvidersInfo
.length
+ 1);
198 * It queries for added custom provider using its scheme
199 * and verifies its result with
200 * <code>queryContentProviders()</code> result and with
201 * custom provider created in <code>registerContentProvider()</code>.
202 * Also verifies <code>registerContentProvider()</code>. <p>
204 * Has <b>OK</b> status if the provider returned is found within
205 * all providers and is equal to provider created before.
207 * The following method tests are to be completed successfully before :
209 * <li> <code> registerContentProvider() </code> </li>
212 public void _queryContentProvider() {
213 executeMethod("registerContentProvider()");
215 XContentProvider result
= oObj
.queryContentProvider
216 ("http://www.sun.com");
218 log
.println("finding queryContentProvider() result");
219 boolean found
= false;
221 ContentProviderInfo
[] providersInfo
= oObj
.queryContentProviders();
223 for (int i
= 0; i
< providersInfo
.length
; i
++) {
224 if (result
.equals(providersInfo
[i
].ContentProvider
)) {
230 tRes
.tested("queryContentProvider()", found
);
234 * At first one provider is deregistered, after that provider
235 * is queried, the second provider must be returned for the
236 * specified scheme. Then the second provider is deregistered.
237 * Now <code>null</code> value must be retruned by the method
238 * <code>queryContentProvider</code> on the specified scheme. <p>
240 * Has <b>OK</b> status if in the first case the second provider
241 * remains registered, and after its removing no providers remain
242 * registered for the scheme specified.
244 * The following method tests are to be completed successfully before :
246 * <li> <code> registerContentProvider() </code> : two providers
247 * must be registered. </li>
249 * The following method tests are to be executed before :
251 * <li> <code> queryContentProvider() </code> : to run this test
253 * <li> <code> queryContentProviders() </code> : to run this test
257 public void _deregisterContentProvider() {
258 executeMethod("queryContentProvider()");
259 executeMethod("queryContentProviders()");
260 requiredMethod("registerContentProvider()");
262 log
.println("deregistering the second provider");
263 oObj
.deregisterContentProvider(contentProvider
, myScheme
);
265 XContentProvider res
= oObj
.queryContentProvider(myScheme
);
267 log
.println("deregistering the first provider");
268 oObj
.deregisterContentProvider(firstContentProvider
, myScheme
);
270 res
= oObj
.queryContentProvider(myScheme
);
272 // verifying that the original provider (typically none) is returned.
273 tRes
.tested("deregisterContentProvider()", res
== preexistingContentProvider
);