langtools/test/tools/javac/api/taskListeners/TestSimpleAddRemove.java
author jjg
Wed, 29 Oct 2014 17:25:23 -0700
changeset 27319 030080f03e4f
parent 24898 88fa65d2ac87
child 30730 d3ce7619db2c
permissions -rw-r--r--
8062348: langtools tests should close file manager (group 1) Reviewed-by: darcy
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
12016
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
     1
/*
24898
88fa65d2ac87 8033414: javac Plugin to receive notification (before and) after the compilation.
jlahoda
parents: 12016
diff changeset
     2
 * Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved.
12016
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
     4
 *
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
     7
 * published by the Free Software Foundation.
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
     8
 *
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    13
 * accompanied this code).
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    14
 *
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    18
 *
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    21
 * questions.
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    22
 */
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    23
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    24
/*
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    25
 * @test
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    26
 * @bug     7093891
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    27
 * @summary support multiple task listeners
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    28
 */
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    29
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    30
import java.io.File;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    31
import java.io.IOException;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    32
import java.io.PrintWriter;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    33
import java.io.StringWriter;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    34
import java.net.URI;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    35
import java.util.ArrayList;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    36
import java.util.Arrays;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    37
import java.util.EnumMap;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    38
import java.util.List;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    39
import java.util.Set;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    40
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    41
import javax.annotation.processing.AbstractProcessor;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    42
import javax.annotation.processing.RoundEnvironment;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    43
import javax.annotation.processing.SupportedAnnotationTypes;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    44
import javax.lang.model.element.TypeElement;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    45
import javax.tools.JavaFileObject;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    46
import javax.tools.SimpleJavaFileObject;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    47
import javax.tools.StandardJavaFileManager;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    48
import javax.tools.StandardLocation;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    49
import javax.tools.ToolProvider;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    50
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    51
import com.sun.source.util.JavacTask;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    52
import com.sun.source.util.TaskEvent;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    53
import com.sun.source.util.TaskListener;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    54
import com.sun.tools.javac.api.JavacTool;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    55
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    56
public class TestSimpleAddRemove {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    57
    enum AddKind {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    58
        SET_IN_TASK,
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    59
        ADD_IN_TASK,
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    60
        ADD_IN_PROCESSOR,
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    61
        ADD_IN_LISTENER;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    62
    }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    63
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    64
    enum RemoveKind {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    65
        REMOVE_IN_TASK,
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    66
        REMOVE_IN_PROCESSOR,
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    67
        REMOVE_IN_LISTENER,
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    68
    }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    69
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    70
    enum CompileKind {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    71
        CALL {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    72
            void run(JavacTask t) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    73
                if (!t.call()) throw new Error("compilation failed");
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    74
            }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    75
        },
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    76
        GENERATE {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    77
            void run(JavacTask t) throws IOException {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    78
                t.generate();
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    79
            }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    80
        };
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    81
        abstract void run(JavacTask t) throws IOException;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    82
    }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    83
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    84
    static class EventKindCounter extends EnumMap<TaskEvent.Kind, EventKindCounter.Count> {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    85
        static class Count {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    86
            int started;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    87
            int finished;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    88
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    89
            @Override
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    90
            public String toString() {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    91
                return started + ":" + finished;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    92
            }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    93
        }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    94
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    95
        EventKindCounter() {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    96
            super(TaskEvent.Kind.class);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    97
        }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    98
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
    99
        void inc(TaskEvent.Kind k, boolean started) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   100
            Count c = get(k);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   101
            if (c == null)
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   102
                put(k, c = new Count());
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   103
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   104
            if (started)
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   105
                c.started++;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   106
            else
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   107
                c.finished++;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   108
        }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   109
    }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   110
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   111
    static class TestListener implements TaskListener {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   112
        EventKindCounter counter;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   113
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   114
        TestListener(EventKindCounter c) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   115
            counter = c;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   116
        }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   117
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   118
        public void started(TaskEvent e) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   119
            counter.inc(e.getKind(), true);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   120
        }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   121
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   122
        public void finished(TaskEvent e) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   123
            counter.inc(e.getKind(), false);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   124
        }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   125
    }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   126
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   127
    static void addInListener(final JavacTask task, final TaskEvent.Kind kind, final TaskListener listener) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   128
        task.addTaskListener(new TaskListener() {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   129
            public void started(TaskEvent e) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   130
                if (e.getKind() == kind) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   131
                    task.addTaskListener(listener);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   132
                    task.removeTaskListener(this);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   133
                }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   134
            }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   135
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   136
            public void finished(TaskEvent e) { }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   137
        });
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   138
    }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   139
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   140
    static void removeInListener(final JavacTask task, final TaskEvent.Kind kind, final TaskListener listener) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   141
        task.addTaskListener(new TaskListener() {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   142
            public void started(TaskEvent e) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   143
                if (e.getKind() == kind) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   144
                    task.removeTaskListener(listener);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   145
                    task.removeTaskListener(this);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   146
                }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   147
            }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   148
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   149
            public void finished(TaskEvent e) { }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   150
        });
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   151
    }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   152
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   153
    @SupportedAnnotationTypes("*")
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   154
    class TestProcessor extends AbstractProcessor {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   155
        AddKind ak;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   156
        RemoveKind rk;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   157
        TaskListener listener;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   158
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   159
        TestProcessor(AddKind ak, RemoveKind rk, TaskListener listener) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   160
            this.ak = ak;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   161
            this.rk = rk;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   162
            this.listener = listener;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   163
        }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   164
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   165
        int round = 0;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   166
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   167
        @Override
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   168
        public boolean process(Set<? extends TypeElement> annotations, RoundEnvironment roundEnv) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   169
//            System.err.println("TestProcessor.process " + roundEnv);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   170
            JavacTask task = JavacTask.instance(processingEnv);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   171
            if (++round == 1) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   172
                switch (ak) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   173
                    case ADD_IN_PROCESSOR:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   174
                        task.addTaskListener(listener);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   175
                        break;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   176
                    case ADD_IN_LISTENER:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   177
                        addInListener(task, TaskEvent.Kind.ANALYZE, listener);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   178
                        break;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   179
                }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   180
            } else if (roundEnv.processingOver()) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   181
                switch (rk) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   182
                    case REMOVE_IN_PROCESSOR:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   183
                        task.removeTaskListener(listener);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   184
                        break;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   185
                    case REMOVE_IN_LISTENER:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   186
                        removeInListener(task, TaskEvent.Kind.GENERATE, listener);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   187
                        break;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   188
                }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   189
            }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   190
            return true;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   191
        }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   192
    }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   193
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   194
    static class TestSource extends SimpleJavaFileObject {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   195
        public TestSource() {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   196
            super(URI.create("myfo:/Test.java"), JavaFileObject.Kind.SOURCE);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   197
        }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   198
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   199
        @Override
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   200
        public CharSequence getCharContent(boolean ignoreEncodingErrors) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   201
            return "class Test { }";
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   202
        }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   203
    }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   204
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   205
    public static void main(String... args) throws Exception {
27319
030080f03e4f 8062348: langtools tests should close file manager (group 1)
jjg
parents: 24898
diff changeset
   206
        TestSimpleAddRemove t = new TestSimpleAddRemove();
030080f03e4f 8062348: langtools tests should close file manager (group 1)
jjg
parents: 24898
diff changeset
   207
        try {
030080f03e4f 8062348: langtools tests should close file manager (group 1)
jjg
parents: 24898
diff changeset
   208
            t.run();
030080f03e4f 8062348: langtools tests should close file manager (group 1)
jjg
parents: 24898
diff changeset
   209
        } finally {
030080f03e4f 8062348: langtools tests should close file manager (group 1)
jjg
parents: 24898
diff changeset
   210
            t.fm.close();
030080f03e4f 8062348: langtools tests should close file manager (group 1)
jjg
parents: 24898
diff changeset
   211
        }
12016
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   212
    }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   213
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   214
    JavacTool tool = (JavacTool) ToolProvider.getSystemJavaCompiler();
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   215
    StandardJavaFileManager fm = tool.getStandardFileManager(null, null, null);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   216
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   217
    void run() throws Exception {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   218
        for (CompileKind ck: CompileKind.values()) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   219
            for (AddKind ak: AddKind.values()) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   220
                for (RemoveKind rk: RemoveKind.values()) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   221
                    test(ck, ak, rk);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   222
                }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   223
            }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   224
        }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   225
        if (errors > 0)
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   226
            throw new Exception(errors + " errors occurred");
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   227
    }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   228
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   229
    void test(CompileKind ck, AddKind ak, RemoveKind rk) throws IOException {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   230
        System.err.println("Test: " + ck + " " + ak + " " + rk);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   231
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   232
        File tmpDir = new File(ck + "-" + ak + "-" + rk);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   233
        tmpDir.mkdirs();
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   234
        fm.setLocation(StandardLocation.CLASS_OUTPUT, Arrays.asList(tmpDir));
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   235
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   236
        List<String> options = new ArrayList<String>();
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   237
        Iterable<? extends JavaFileObject> files = Arrays.asList(new TestSource());
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   238
        StringWriter sw = new StringWriter();
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   239
        PrintWriter pw = new PrintWriter(sw);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   240
        JavacTask task = tool.getTask(pw, fm, null, options, null, files);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   241
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   242
        EventKindCounter ec = new EventKindCounter();
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   243
        TaskListener listener = new TestListener(ec);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   244
        boolean needProcessor = false;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   245
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   246
        switch (ak) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   247
            case SET_IN_TASK:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   248
                task.setTaskListener(listener);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   249
                break;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   250
            case ADD_IN_TASK:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   251
                task.addTaskListener(listener);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   252
                break;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   253
            case ADD_IN_PROCESSOR:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   254
            case ADD_IN_LISTENER:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   255
                needProcessor = true;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   256
        }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   257
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   258
        switch (rk) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   259
            case REMOVE_IN_TASK:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   260
                task.removeTaskListener(listener);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   261
                break;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   262
            case REMOVE_IN_PROCESSOR:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   263
            case REMOVE_IN_LISTENER:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   264
                needProcessor = true;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   265
        }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   266
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   267
        if (needProcessor)
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   268
            task.setProcessors(Arrays.asList(new TestProcessor(ak, rk, listener)));
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   269
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   270
        ck.run(task);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   271
        System.err.println(ec);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   272
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   273
        check(ck, ak, rk, ec);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   274
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   275
        System.err.println();
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   276
    }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   277
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   278
    void check(CompileKind ck, AddKind ak, RemoveKind rk, EventKindCounter ec) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   279
        // All results should be independent of ck, so we can ignore that
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   280
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   281
        // Quick way to compare expected values of ec, by comparing ec.toString()
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   282
        String expect = ec.toString();
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   283
        String found;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   284
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   285
        switch (ak) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   286
            // Add/set in task should record all events until the listener is removed
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   287
            case SET_IN_TASK:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   288
            case ADD_IN_TASK:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   289
                switch (rk) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   290
                    case REMOVE_IN_TASK:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   291
                        // Remove will succeed, meaning no events will be recorded
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   292
                        found = "{}";
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   293
                        break;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   294
                    case REMOVE_IN_PROCESSOR:
24898
88fa65d2ac87 8033414: javac Plugin to receive notification (before and) after the compilation.
jlahoda
parents: 12016
diff changeset
   295
                        if (ck == CompileKind.CALL)
88fa65d2ac87 8033414: javac Plugin to receive notification (before and) after the compilation.
jlahoda
parents: 12016
diff changeset
   296
                            found = "{PARSE=1:1, ENTER=2:2, ANNOTATION_PROCESSING=1:0, ANNOTATION_PROCESSING_ROUND=2:1, COMPILATION=1:0}";
88fa65d2ac87 8033414: javac Plugin to receive notification (before and) after the compilation.
jlahoda
parents: 12016
diff changeset
   297
                        else
88fa65d2ac87 8033414: javac Plugin to receive notification (before and) after the compilation.
jlahoda
parents: 12016
diff changeset
   298
                            found = "{PARSE=1:1, ENTER=2:2, ANNOTATION_PROCESSING=1:0, ANNOTATION_PROCESSING_ROUND=2:1}";
12016
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   299
                        break;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   300
                    case REMOVE_IN_LISTENER:
24898
88fa65d2ac87 8033414: javac Plugin to receive notification (before and) after the compilation.
jlahoda
parents: 12016
diff changeset
   301
                        if (ck == CompileKind.CALL)
88fa65d2ac87 8033414: javac Plugin to receive notification (before and) after the compilation.
jlahoda
parents: 12016
diff changeset
   302
                            found = "{PARSE=1:1, ENTER=3:3, ANALYZE=1:1, GENERATE=1:0, ANNOTATION_PROCESSING=1:1, ANNOTATION_PROCESSING_ROUND=2:2, COMPILATION=1:0}";
88fa65d2ac87 8033414: javac Plugin to receive notification (before and) after the compilation.
jlahoda
parents: 12016
diff changeset
   303
                        else
88fa65d2ac87 8033414: javac Plugin to receive notification (before and) after the compilation.
jlahoda
parents: 12016
diff changeset
   304
                            found = "{PARSE=1:1, ENTER=3:3, ANALYZE=1:1, GENERATE=1:0, ANNOTATION_PROCESSING=1:1, ANNOTATION_PROCESSING_ROUND=2:2}";
12016
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   305
                        break;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   306
                    default:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   307
                        throw new IllegalStateException();
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   308
                }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   309
                break;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   310
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   311
            // "Add in processor" should skip initial PARSE/ENTER events
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   312
            case ADD_IN_PROCESSOR:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   313
                switch (rk) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   314
                    // Remove will fail (too early), so events to end will be recorded
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   315
                    case REMOVE_IN_TASK:
24898
88fa65d2ac87 8033414: javac Plugin to receive notification (before and) after the compilation.
jlahoda
parents: 12016
diff changeset
   316
                        if (ck == CompileKind.CALL)
88fa65d2ac87 8033414: javac Plugin to receive notification (before and) after the compilation.
jlahoda
parents: 12016
diff changeset
   317
                            found = "{ENTER=2:2, ANALYZE=1:1, GENERATE=1:1, ANNOTATION_PROCESSING=0:1, ANNOTATION_PROCESSING_ROUND=1:2, COMPILATION=0:1}";
88fa65d2ac87 8033414: javac Plugin to receive notification (before and) after the compilation.
jlahoda
parents: 12016
diff changeset
   318
                        else
88fa65d2ac87 8033414: javac Plugin to receive notification (before and) after the compilation.
jlahoda
parents: 12016
diff changeset
   319
                            found = "{ENTER=2:2, ANALYZE=1:1, GENERATE=1:1, ANNOTATION_PROCESSING=0:1, ANNOTATION_PROCESSING_ROUND=1:2}";
12016
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   320
                        break;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   321
                    case REMOVE_IN_PROCESSOR:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   322
                        found = "{ENTER=1:1, ANNOTATION_PROCESSING_ROUND=1:1}";
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   323
                        break;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   324
                    case REMOVE_IN_LISTENER:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   325
                        found = "{ENTER=2:2, ANALYZE=1:1, GENERATE=1:0, ANNOTATION_PROCESSING=0:1, ANNOTATION_PROCESSING_ROUND=1:2}";
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   326
                        break;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   327
                    default:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   328
                        throw new IllegalStateException();
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   329
                }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   330
                break;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   331
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   332
            // "Add in listener" will occur during "ANALYSE.started" event
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   333
            case ADD_IN_LISTENER:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   334
                switch (rk) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   335
                    // Remove will fail (too early, so events to end will be recorded
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   336
                    case REMOVE_IN_TASK:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   337
                    case REMOVE_IN_PROCESSOR:
24898
88fa65d2ac87 8033414: javac Plugin to receive notification (before and) after the compilation.
jlahoda
parents: 12016
diff changeset
   338
                        if (ck == CompileKind.CALL)
88fa65d2ac87 8033414: javac Plugin to receive notification (before and) after the compilation.
jlahoda
parents: 12016
diff changeset
   339
                            found = "{ANALYZE=0:1, GENERATE=1:1, COMPILATION=0:1}";
88fa65d2ac87 8033414: javac Plugin to receive notification (before and) after the compilation.
jlahoda
parents: 12016
diff changeset
   340
                        else
88fa65d2ac87 8033414: javac Plugin to receive notification (before and) after the compilation.
jlahoda
parents: 12016
diff changeset
   341
                            found = "{ANALYZE=0:1, GENERATE=1:1}";
12016
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   342
                        break;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   343
                    // Remove will succeed during "GENERATE.finished" event
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   344
                    case REMOVE_IN_LISTENER:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   345
                        found = "{ANALYZE=0:1, GENERATE=1:0}";
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   346
                        break;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   347
                    default:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   348
                        throw new IllegalStateException();
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   349
                }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   350
                break;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   351
            default:
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   352
                throw new IllegalStateException();
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   353
        }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   354
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   355
        if (!found.equals(expect)) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   356
            System.err.println("Expected: " + expect);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   357
            System.err.println("   Found: " + found);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   358
            error("unexpected value found");
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   359
        }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   360
    }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   361
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   362
    int errors;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   363
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   364
    void error(String message) {
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   365
        System.err.println("Error: " + message);
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   366
        errors++;
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   367
    }
1990493b64db 7093891: support multiple task listeners
jjg
parents:
diff changeset
   368
}