< prev index next >

test/hotspot/jtreg/runtime/SharedArchiveFile/ArchiveDoesNotExist.java

Print this page




  21  * questions.
  22  */
  23 
  24 /**
  25  * @test ArchiveDoesNotExist
  26  * @summary Test how VM handles "file does not exist" situation while
  27  *          attempting to use CDS archive. JVM should exit gracefully
  28  *          when sharing mode is ON, and continue w/o sharing if sharing
  29  *          mode is AUTO.
  30  * @requires vm.cds
  31  * @library /test/lib
  32  * @modules java.base/jdk.internal.misc
  33  *          java.management
  34  * @run main ArchiveDoesNotExist
  35  */
  36 
  37 import jdk.test.lib.cds.CDSOptions;
  38 import jdk.test.lib.cds.CDSTestUtils;
  39 import jdk.test.lib.process.OutputAnalyzer;
  40 import java.io.File;


  41 
  42 public class ArchiveDoesNotExist {
  43     public static void main(String[] args) throws Exception {
  44         String fileName = "ArchiveDoesNotExist.jsa";
  45 
  46         File cdsFile = new File(fileName);
  47         if (cdsFile.exists())
  48             throw new RuntimeException("Test error: cds file already exists");
  49 
  50         CDSOptions opts = (new CDSOptions()).setArchiveName(fileName);
  51 
  52         // -Xshare=on
  53         OutputAnalyzer out = CDSTestUtils.runWithArchive(opts);
  54         if (!CDSTestUtils.isUnableToMap(out)) {


  55             out.shouldContain("Specified shared archive not found")
  56                .shouldHaveExitValue(1);
  57         }
  58 
  59         // -Xshare=auto
  60         opts.setXShareMode("auto");
  61         out = CDSTestUtils.runWithArchive(opts);
  62         if (!CDSTestUtils.isUnableToMap(out)) {
  63             out.shouldMatch("(java|openjdk) version")
  64                .shouldNotContain("sharing")
  65                .shouldHaveExitValue(0);
  66         }
  67     }
  68 }


  21  * questions.
  22  */
  23 
  24 /**
  25  * @test ArchiveDoesNotExist
  26  * @summary Test how VM handles "file does not exist" situation while
  27  *          attempting to use CDS archive. JVM should exit gracefully
  28  *          when sharing mode is ON, and continue w/o sharing if sharing
  29  *          mode is AUTO.
  30  * @requires vm.cds
  31  * @library /test/lib
  32  * @modules java.base/jdk.internal.misc
  33  *          java.management
  34  * @run main ArchiveDoesNotExist
  35  */
  36 
  37 import jdk.test.lib.cds.CDSOptions;
  38 import jdk.test.lib.cds.CDSTestUtils;
  39 import jdk.test.lib.process.OutputAnalyzer;
  40 import java.io.File;
  41 import jtreg.SkippedException;
  42 
  43 
  44 public class ArchiveDoesNotExist {
  45     public static void main(String[] args) throws Exception {
  46         String fileName = "ArchiveDoesNotExist.jsa";
  47 
  48         File cdsFile = new File(fileName);
  49         if (cdsFile.exists())
  50             throw new RuntimeException("Test error: cds file already exists");
  51 
  52         CDSOptions opts = (new CDSOptions()).setArchiveName(fileName);
  53 
  54         // -Xshare=on
  55         OutputAnalyzer out = CDSTestUtils.runWithArchive(opts);
  56         if (CDSTestUtils.isUnableToMap(out)) {
  57             throw new SkippedException(CDSTestUtils.UnableToMapMsg);
  58         } else {
  59             out.shouldContain("Specified shared archive not found")
  60                .shouldHaveExitValue(1);
  61         }
  62 
  63         // -Xshare=auto
  64         opts.setXShareMode("auto");
  65         out = CDSTestUtils.runWithArchive(opts);
  66         if (!CDSTestUtils.isUnableToMap(out)) {
  67             out.shouldMatch("(java|openjdk) version")
  68                .shouldNotContain("sharing")
  69                .shouldHaveExitValue(0);
  70         }
  71     }
  72 }
< prev index next >