1 /*
   2  * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved.
   3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
   4  *
   5  * This code is free software; you can redistribute it and/or modify it
   6  * under the terms of the GNU General Public License version 2 only, as
   7  * published by the Free Software Foundation.
   8  *
   9  * This code is distributed in the hope that it will be useful, but WITHOUT
  10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  11  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
  12  * version 2 for more details (a copy is included in the LICENSE file that
  13  * accompanied this code).
  14  *
  15  * You should have received a copy of the GNU General Public License version
  16  * 2 along with this work; if not, write to the Free Software Foundation,
  17  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
  18  *
  19  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
  20  * or visit www.oracle.com if you need additional information or have any
  21  * questions.
  22  */
  23 
  24 package catalog;
  25 
  26 import static catalog.CatalogTestUtils.CATALOG_SYSTEM;
  27 import static catalog.CatalogTestUtils.CATALOG_URI;
  28 import static catalog.CatalogTestUtils.RESOLVE_CONTINUE;
  29 import static catalog.CatalogTestUtils.RESOLVE_IGNORE;
  30 import static catalog.CatalogTestUtils.RESOLVE_STRICT;
  31 import static catalog.CatalogTestUtils.catalogResolver;
  32 import static catalog.CatalogTestUtils.catalogUriResolver;
  33 import static catalog.ResolutionChecker.checkSysIdResolution;
  34 import static catalog.ResolutionChecker.checkUriResolution;
  35 import static javax.xml.catalog.CatalogFeatures.builder;
  36 
  37 import javax.xml.catalog.CatalogException;
  38 import javax.xml.catalog.CatalogFeatures;
  39 import javax.xml.catalog.CatalogFeatures.Feature;
  40 import javax.xml.catalog.CatalogResolver;
  41 import javax.xml.catalog.CatalogUriResolver;
  42 
  43 import org.testng.annotations.Listeners;
  44 import org.testng.annotations.Test;
  45 
  46 /*
  47  * @test
  48  * @bug 8077931
  49  * @library /javax/xml/jaxp/libs
  50  * @run testng/othervm -DrunSecMngr=true catalog.ResolveFeatureTest
  51  * @run testng/othervm catalog.ResolveFeatureTest
  52  * @summary This case tests how does resolve feature affect the catalog
  53  *          resolution.
  54  */
  55 @Listeners({jaxp.library.FilePolicy.class})
  56 public class ResolveFeatureTest {
  57 
  58     /*
  59      * For strict external identifier resolution, if no match is found,
  60      * it should throw CatalogException.
  61      */
  62     @Test(expectedExceptions = CatalogException.class)
  63     public void testStrictResolutionOnEntityResolver() {
  64         createEntityResolver(RESOLVE_STRICT).resolveEntity(null,
  65                 "http://remote/dtd/alice/docAliceDummy.dtd");
  66     }
  67 
  68     /*
  69      * For strict URI reference resolution, if no match is found,
  70      * it should throw CatalogException.
  71      */
  72     @Test(expectedExceptions = CatalogException.class)
  73     public void testStrictResolutionOnUriResolver() {
  74         createUriResolver(RESOLVE_STRICT).resolve(
  75                 "http://remote/dtd/alice/docAliceDummy.dtd", null);
  76     }
  77 
  78     /*
  79      * For continue external identifier resolution, if no match is found,
  80      * it should continue the process.
  81      */
  82     @Test
  83     public void testContinueResolutionOnEntityResolver() {
  84         CatalogResolver resolver = createEntityResolver(RESOLVE_CONTINUE);
  85         resolver.resolveEntity(null, "http://remote/dtd/bob/docBobDummy.dtd");
  86         checkSysIdResolution(resolver, "http://remote/dtd/bob/docBob.dtd",
  87                 "http://local/base/dtd/docBobSys.dtd");
  88     }
  89 
  90     /*
  91      * For continue URI reference resolution, if no match is found,
  92      * it should continue the process.
  93      */
  94     @Test
  95     public void testContinueResolutionOnUriResolver() {
  96         CatalogUriResolver resolver = createUriResolver(RESOLVE_CONTINUE);
  97         resolver.resolve("http://remote/dtd/bob/docBobDummy.dtd", null);
  98         checkUriResolution(resolver, "http://remote/dtd/bob/docBob.dtd",
  99                 "http://local/base/dtd/docBobURI.dtd");
 100     }
 101 
 102     /*
 103      * For ignore external identifier resolution, if no match is found,
 104      * it should break the process and return null.
 105      */
 106     @Test
 107     public void testIgnoreResolutionOnEntityResolver() {
 108         checkSysIdResolution(createEntityResolver(RESOLVE_IGNORE),
 109                 "http://remote/dtd/carl/docCarlDummy.dtd", null);
 110     }
 111 
 112     /*
 113      * For ignore URI reference resolution, if no match is found,
 114      * it should break the process and return null.
 115      */
 116     @Test
 117     public void testIgnoreResolutionOnUriResolver() {
 118         checkUriResolution(createUriResolver(RESOLVE_IGNORE),
 119                 "http://remote/dtd/carl/docCarlDummy.dtd", null);
 120     }
 121 
 122     private CatalogResolver createEntityResolver(String resolve) {
 123         return catalogResolver(createFeature(resolve), CATALOG_SYSTEM);
 124     }
 125 
 126     private CatalogUriResolver createUriResolver(String resolve) {
 127         return catalogUriResolver(createFeature(resolve), CATALOG_URI);
 128     }
 129 
 130     private CatalogFeatures createFeature(String resolve) {
 131         return builder().with(Feature.RESOLVE, resolve).build();
 132     }
 133 }
 134