View Javadoc
1   /*
2    * Licensed to the Apache Software Foundation (ASF) under one or more
3    * contributor license agreements.  See the NOTICE file distributed with
4    * this work for additional information regarding copyright ownership.
5    * The ASF licenses this file to You under the Apache License, Version 2.0
6    * (the "License"); you may not use this file except in compliance with
7    * the License.  You may obtain a copy of the License at
8    *
9    *      http://www.apache.org/licenses/LICENSE-2.0
10   *
11   * Unless required by applicable law or agreed to in writing, software
12   * distributed under the License is distributed on an "AS IS" BASIS,
13   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14   * See the License for the specific language governing permissions and
15   * limitations under the License.
16   */
17  package org.apache.commons.vfs2.provider.tar;
18  
19  import org.apache.commons.vfs2.AbstractProviderTestConfig;
20  import org.apache.commons.vfs2.AbstractVfsTestCase;
21  import org.apache.commons.vfs2.FileObject;
22  import org.apache.commons.vfs2.FileSystemManager;
23  import org.apache.commons.vfs2.FileSystemOptions;
24  import org.apache.commons.vfs2.ProviderTestSuite;
25  import org.apache.commons.vfs2.auth.StaticUserAuthenticator;
26  import org.apache.commons.vfs2.impl.DefaultFileSystemConfigBuilder;
27  import org.apache.commons.vfs2.impl.DefaultFileSystemManager;
28  
29  import junit.framework.Test;
30  
31  /**
32   * Tests for the Tar file system, using a tar file nested inside another tar file.
33   */
34  public class NestedTarTestCase extends AbstractProviderTestConfig {
35      /**
36       * Creates the test suite for nested tar files.
37       */
38      public static Test suite() throws Exception {
39          return new ProviderTestSuite(new NestedTarTestCase(), true);
40      }
41  
42      /**
43       * Returns the base folder for tests.
44       */
45      @Override
46      public FileObject getBaseTestFolder(final FileSystemManager manager) throws Exception {
47          // We test with non-empty FS options to make sure they are propagated
48          final FileSystemOptions opts = new FileSystemOptions();
49          DefaultFileSystemConfigBuilder.getInstance().setUserAuthenticator(opts,
50                  new StaticUserAuthenticator("domain", null, null));
51  
52          // Locate the base Tar file
53          final String tarFilePath = AbstractVfsTestCase.getTestResource("nested.tar").getAbsolutePath();
54  
55          // Now build the nested file system
56          final String uri = "tar:file:" + tarFilePath + "!/test.tar";
57          final FileObject tarFile = manager.resolveFile(uri, opts);
58          final FileObject nestedFS = manager.createFileSystem(tarFile);
59          return nestedFS.resolveFile("/");
60      }
61  
62      /**
63       * Prepares the file system manager.
64       */
65      @Override
66      public void prepare(final DefaultFileSystemManager manager) throws Exception {
67          manager.addProvider("tar", new TarFileProvider());
68          manager.addExtensionMap("tar", "tar");
69          manager.addMimeTypeMap("application/x-tar", "tar");
70      }
71  }