test/langtools/jdk/javadoc/tool/OptionSyntaxTest.java
author bobv
Tue, 07 Nov 2017 10:30:53 -0500
changeset 47801 c7b50c23ea71
parent 47216 71c04702a3d5
permissions -rw-r--r--
8190283: Default heap sizing options select a MaxHeapSize larger than available physical memory in some cases Reviewed-by: tschatzl, sjohanss

/*
 * Copyright (c) 2002, 2016, Oracle and/or its affiliates. All rights reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.
 *
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 * or visit www.oracle.com if you need additional information or have any
 * questions.
 */

/*
 * @test
 * @bug 8166144
 * @summary support new-style options
 * @modules jdk.compiler/com.sun.tools.javac.api
 * @modules jdk.compiler/com.sun.tools.javac.main
 * @modules jdk.javadoc/jdk.javadoc.internal.api
 * @modules jdk.javadoc/jdk.javadoc.internal.tool
 * @library /tools/lib
 * @build toolbox.JavacTask toolbox.JavadocTask toolbox.ModuleBuilder toolbox.TestRunner toolbox.ToolBox
 * @run main OptionSyntaxTest
 */
import java.io.IOException;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashSet;
import java.util.List;
import java.util.Locale;
import java.util.Set;

import javax.lang.model.SourceVersion;

import jdk.javadoc.doclet.Doclet;
import jdk.javadoc.doclet.DocletEnvironment;
import jdk.javadoc.doclet.Reporter;

import toolbox.JavadocTask;
import toolbox.ModuleBuilder;
import toolbox.Task;
import toolbox.TestRunner;
import toolbox.ToolBox;


public class OptionSyntaxTest extends TestRunner {
    public static class TestDoclet implements Doclet {
        @Override
        public boolean run(DocletEnvironment root) {
            System.out.println("TestDoclet.run");
            return true;
        }

        @Override
        public String getName() {
            return "Test";
        }

        @Override
        public Set<Option> getSupportedOptions() {
            return options;
        }

        @Override
        public SourceVersion getSupportedSourceVersion() {
            return SourceVersion.latest();
        }

        @Override
        public void init(Locale locale, Reporter reporter) {
        }

        private final Set<Doclet.Option> options = new HashSet<>(Arrays.asList(
                new DOption("-old", 0),
                new DOption("-oldWithArg", 1),
                new DOption("-oldWithArgs", 2),
                new DOption("--new", 0),
                new DOption("--newWithArg", 1),
                new DOption("--newWithArgs", 2)
        ));

    }

    static class DOption implements Doclet.Option {
        private final List<String> names = new ArrayList<>();
        private final int argCount;

        DOption(String name, int argCount) {
            this.names.add(name);
            this.argCount = argCount;
        }

        @Override
        public int getArgumentCount() {
            return argCount;
        }

        @Override
        public String getDescription() {
            return "description[" + names.get(0) + "]";
        }

        @Override
        public Kind getKind() {
            return Doclet.Option.Kind.STANDARD;
        }

        @Override
        public List<String> getNames() {
            return names;
        }

        @Override
        public String getParameters() {
            return argCount > 0 ? "parameters[" + names.get(0) + "," + argCount + "]" : null;
        }

        @Override
        public boolean process(String option, List<String> arguments) {
            List<String> args = new ArrayList<>();
            for (int i = 0; i < argCount && i < arguments.size(); i++) {
                args.add(arguments.get(i));
            }
            System.out.println("process " + option + " " + args);
            return args.stream().filter(s -> s.startsWith("arg")).count() == argCount;
        }
    }

    public static void main(String... args) throws Exception {
        OptionSyntaxTest t = new OptionSyntaxTest();
        t.runTests();
    }

    private final ToolBox tb = new ToolBox();
    private final Path src = Paths.get("src");
    private final Path modules = Paths.get("modules");

    OptionSyntaxTest() throws IOException {
        super(System.err);
        initModules();
    }

    void initModules() throws IOException {
        new ModuleBuilder(tb, "m1")
                .exports("p1")
                .classes("package p1; public class C1 { }")
                .write(src);

        new ModuleBuilder(tb, "m2")
                .exports("p2")
                .classes("package p2; public class C2 { }")
                .build(modules);

    }

    @Test
    public void testBasic() {
        new JavadocTask(tb, Task.Mode.CMDLINE)
                .options("-docletpath", System.getProperty("test.classes"),
                       "-doclet", TestDoclet.class.getName(),
                       "-sourcepath", "src/m1",
                       "p1")
                .run()
                .writeAll();
    }

    @Test
    public void testNewSourcePath() {
        new JavadocTask(tb, Task.Mode.CMDLINE)
                .options("-docletpath", System.getProperty("test.classes"),
                       "-doclet", TestDoclet.class.getName(),
                       "--source-path", "src/m1",
                       "p1")
                .run()
                .writeAll();
    }

    @Test
    public void testNewSourcePathEquals() {
        new JavadocTask(tb, Task.Mode.CMDLINE)
                .options("-docletpath", System.getProperty("test.classes"),
                       "-doclet", TestDoclet.class.getName(),
                       "--source-path=src/m1",
                       "p1")
                .run()
                .writeAll();
    }

    @Test
    public void testOldDocletArgs() {
        new JavadocTask(tb, Task.Mode.CMDLINE)
                .options("-docletpath", System.getProperty("test.classes"),
                       "-doclet", TestDoclet.class.getName(),
                       "-sourcepath", "src/m1",
                       "-old",
                       "-oldWithArg", "arg",
                       "-oldWithArgs", "arg1", "arg2",
                       "p1")
                .run()
                .writeAll();
    }

    @Test
    public void testNewDocletArgs() {
        new JavadocTask(tb, Task.Mode.CMDLINE)
                .options("-docletpath", System.getProperty("test.classes"),
                       "-doclet", TestDoclet.class.getName(),
                       "-sourcepath", "src/m1",
                       "--new",
                       "--newWithArg", "arg",
                       "--newWithArgs", "arg1", "arg2",
                       "p1")
                .run()
                .writeAll();
    }

    @Test
    public void testNewDocletArgsEquals() {
        new JavadocTask(tb, Task.Mode.CMDLINE)
                .options("-docletpath", System.getProperty("test.classes"),
                       "-doclet", TestDoclet.class.getName(),
                       "-sourcepath", "src/m1",
                       "--new", "--newWithArg=arg",
                       "p1")
                .run()
                .writeAll();
    }

    @Test
    public void testNewDocletArgsMissingArgs() throws Exception {
        String log = new JavadocTask(tb, Task.Mode.CMDLINE)
                .options("-docletpath", System.getProperty("test.classes"),
                       "-doclet", TestDoclet.class.getName(),
                       "-sourcepath", "src/m1",
                       "--newWithArg")
                .run(Task.Expect.FAIL)
                .writeAll()
                .getOutput(Task.OutputKind.DIRECT);
        if (!log.contains("option --newWithArg requires an argument"))
            throw new Exception("expected output not found");
    }

    @Test
    public void testNewDocletArgsExtraArgs() throws Exception {
        String log = new JavadocTask(tb, Task.Mode.CMDLINE)
                .options("-docletpath", System.getProperty("test.classes"),
                       "-doclet", TestDoclet.class.getName(),
                       "-sourcepath", "src/m1",
                       "--new=arg",
                       "p1")
                .run(Task.Expect.FAIL)
                .writeAll()
                .getOutput(Task.OutputKind.DIRECT);
        if (!log.contains("option --new does not require an argument"))
            throw new Exception("expected output not found");
    }

    @Test
    public void testNewDocletArgsExtraArgs2() throws Exception {
        String log = new JavadocTask(tb, Task.Mode.CMDLINE)
                .options("-docletpath", System.getProperty("test.classes"),
                       "-doclet", TestDoclet.class.getName(),
                       "-sourcepath", "src/m1",
                       "--newWithArgs=arg1 arg2",
                       "p1")
                .run(Task.Expect.FAIL)
                .writeAll()
                .getOutput(Task.OutputKind.DIRECT);
        if (!log.contains("cannot use '=' syntax for options that require multiple arguments"))
            throw new Exception("expected output not found");
    }

}