[ 
https://issues.apache.org/jira/browse/CONFIGURATION-609?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=14715391#comment-14715391
 ] 

Oliver Heger commented on CONFIGURATION-609:
--------------------------------------------

This looks indeed like a bug. I will have a look (in the next few days). Thanks 
for the report.

> When using a VFSFileSystem on a PropertiesConfiguration, processing an 
> include token defaults back to DefaultFileSystem
> -----------------------------------------------------------------------------------------------------------------------
>
>                 Key: CONFIGURATION-609
>                 URL: https://issues.apache.org/jira/browse/CONFIGURATION-609
>             Project: Commons Configuration
>          Issue Type: Bug
>          Components: File reloading
>    Affects Versions: 2.0
>         Environment: OSX using Eclipse/Maven
>            Reporter: Patrick Ethier
>
> I have uploaded two files to HDFS.
> -----
> bob.properties:
> ==
> include=fred.properties
> ==
> ----
> fred.properties
> ==
> key=value
> ==
> ---
> If I load fred.properties and evaluated the "key", value is returned as 
> expected. If I load bob.properties, I get a ConfigurationException.
> Here is the code snippet, please change setFileName() to reflect both cases:
>               FileSystem fsTest = new VFSFileSystem();
>               fsTest.setFileOptionsProvider(new HDFSOptionsProvider());
>               
>               Parameters params = new Parameters();
>               FileBasedConfigurationBuilder<FileBasedConfiguration> builder =
>                   new 
> FileBasedConfigurationBuilder<FileBasedConfiguration>(PropertiesConfiguration.class)
>                   .configure(params.fileBased()
>                       .setLocationStrategy(new FileSystemLocationStrategy())
>                       .setBasePath("hdfs://localhost:8020/user/myusername")
>                       .setFileName("bob.properties")
>                       .setFileSystem(fsTest));
>               
>               Configuration config;
>               try {
>                       config = builder.getConfiguration();
>                       System.out.println(config.getString("key"));
>               } catch (ConfigurationException e) {
>                       e.printStackTrace();
>               }
> --------------------
> HDFSOptionsProvider.java:
> ==
> public class HDFSOptionsProvider implements FileOptionsProvider {
>       @Override
>       public Map<String, Object> getOptions() {
>               Map<String, Object> opts = new HashMap<String, Object>();
>               opts.put("DefaultProvider", HdfsFileProvider.class);
>               return  opts;
>       }
> }
> ==
> -------------
> Here is the Exception trace:
> 15/08/25 14:14:46 INFO impl.StandardFileSystemManager: Using "/tmp/vfs_cache" 
> as temporary files store.
> 15/08/25 14:14:47 WARN util.NativeCodeLoader: Unable to load native-hadoop 
> library for your platform... using builtin-java classes where applicable
> org.apache.commons.configuration2.ex.ConfigurationException: Unable to load 
> the configuration from the URL 
> hdfs://localhost:8020/user/myusername/fred.properties
>       at 
> org.apache.commons.configuration2.io.DefaultFileSystem.getInputStream(DefaultFileSystem.java:56)
>       at 
> org.apache.commons.configuration2.io.FileHandler.load(FileHandler.java:979)
>       at 
> org.apache.commons.configuration2.io.FileHandler.load(FileHandler.java:740)
>       at 
> org.apache.commons.configuration2.PropertiesConfiguration.loadIncludeFile(PropertiesConfiguration.java:1419)
>       at 
> org.apache.commons.configuration2.PropertiesConfiguration.propertyLoaded(PropertiesConfiguration.java:571)
>       at 
> org.apache.commons.configuration2.PropertiesConfigurationLayout.load(PropertiesConfigurationLayout.java:494)
>       at 
> org.apache.commons.configuration2.PropertiesConfiguration.read(PropertiesConfiguration.java:509)
>       at 
> org.apache.commons.configuration2.io.FileHandler.loadFromReader(FileHandler.java:1124)
>       at 
> org.apache.commons.configuration2.io.FileHandler.loadFromTransformedStream(FileHandler.java:1110)
>       at 
> org.apache.commons.configuration2.io.FileHandler.loadFromStream(FileHandler.java:1049)
>       at 
> org.apache.commons.configuration2.io.FileHandler.load(FileHandler.java:980)
>       at 
> org.apache.commons.configuration2.io.FileHandler.load(FileHandler.java:963)
>       at 
> org.apache.commons.configuration2.io.FileHandler.load(FileHandler.java:692)
>       at 
> org.apache.commons.configuration2.builder.FileBasedConfigurationBuilder.initFileHandler(FileBasedConfigurationBuilder.java:312)
>       at 
> org.apache.commons.configuration2.builder.FileBasedConfigurationBuilder.initResultInstance(FileBasedConfigurationBuilder.java:291)
>       at 
> org.apache.commons.configuration2.builder.FileBasedConfigurationBuilder.initResultInstance(FileBasedConfigurationBuilder.java:60)
>       at 
> org.apache.commons.configuration2.builder.BasicConfigurationBuilder.createResult(BasicConfigurationBuilder.java:421)
>       at 
> org.apache.commons.configuration2.builder.BasicConfigurationBuilder.getConfiguration(BasicConfigurationBuilder.java:285)
>       at com.secureops.config.TestLoadConf.main(TestLoadConf.java:33)
> Caused by: java.io.IOException: VFS URLs can only be used with VFS APIs
>       at 
> org.apache.commons.configuration2.io.VFSFileSystem$VFSURLStreamHandler.openConnection(VFSFileSystem.java:368)
>       at java.net.URL.openConnection(URL.java:975)
>       at java.net.URL.openStream(URL.java:1041)
>       at 
> org.apache.commons.configuration2.io.DefaultFileSystem.getInputStream(DefaultFileSystem.java:52)
>       ... 18 more



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to