mirror of
https://github.com/vanitasvitae/Smack.git
synced 2024-06-26 13:24:49 +02:00
6980c8e63d
this is the first stop towards fixing "SMACK-65: parsing should look for depth", by providing the initial parsing depth to the provider. Some methods (.e.g parseMessage) now use the depth as abort condition, instead of a unclean String equals check. parseIQ() and parseExtension() where both renamed to parse. This also restricts the Exceptions thrown by the parse method, to just XmlPullParserException, IOException and SmackException (not really a big victory, but nevertheless a slight improvement). StreamFeatureProvider is now gone, we simply use PacketExtensionProvider for stream features.
71 lines
2.2 KiB
Java
71 lines
2.2 KiB
Java
/**
|
|
*
|
|
* Copyright the original author or authors
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
package org.jivesoftware.smack.provider;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.Collection;
|
|
|
|
import org.junit.Assert;
|
|
|
|
import org.jivesoftware.smack.packet.IQ;
|
|
import org.jivesoftware.smack.util.FileUtils;
|
|
import org.junit.Test;
|
|
import org.xmlpull.v1.XmlPullParser;
|
|
|
|
public class ProviderConfigTest {
|
|
|
|
@Test
|
|
public void addGenericLoaderProvider() {
|
|
ProviderManager.addLoader(new ProviderLoader() {
|
|
|
|
@Override
|
|
public Collection<IQProviderInfo> getIQProviderInfo() {
|
|
ArrayList<IQProviderInfo> l = new ArrayList<IQProviderInfo>(1);
|
|
l.add(new IQProviderInfo("provider", "test:provider", new TestIQProvider()));
|
|
return l;
|
|
}
|
|
|
|
@Override
|
|
public Collection<ExtensionProviderInfo> getExtensionProviderInfo() {
|
|
return null;
|
|
}
|
|
|
|
@Override
|
|
public Collection<StreamFeatureProviderInfo> getStreamFeatureProviderInfo() {
|
|
return null;
|
|
}
|
|
});
|
|
|
|
Assert.assertNotNull(ProviderManager.getIQProvider("provider", "test:provider"));
|
|
}
|
|
|
|
@Test
|
|
public void addClasspathFileLoaderProvider() throws Exception{
|
|
ProviderManager.addLoader(new ProviderFileLoader(FileUtils.getStreamForUrl("classpath:test.providers", null)));
|
|
Assert.assertNotNull(ProviderManager.getIQProvider("provider", "test:file_provider"));
|
|
}
|
|
|
|
public static class TestIQProvider extends IQProvider<IQ> {
|
|
|
|
@Override
|
|
public IQ parse(XmlPullParser parser, int initialDepth) {
|
|
return null;
|
|
}
|
|
|
|
}
|
|
}
|