| /* |
| * Copyright 2008 Google Inc. |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); you may not |
| * use this file except in compliance with the License. You may obtain a copy of |
| * the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| * License for the specific language governing permissions and limitations under |
| * the License. |
| */ |
| |
| package com.google.gwt.dev.jjs.impl; |
| |
| import com.google.gwt.core.ext.TreeLogger; |
| import com.google.gwt.core.ext.UnableToCompleteException; |
| import com.google.gwt.dev.javac.testing.impl.MockJavaResource; |
| import com.google.gwt.dev.jjs.ast.JProgram; |
| import com.google.gwt.dev.util.UnitTestTreeLogger; |
| |
| /** |
| * Tests the error messages generated by {@link ReplaceRunAsyncs}. |
| */ |
| public class ReplaceRunAsyncsErrorMessagesTest extends JJSTestBase { |
| private UnitTestTreeLogger.Builder testLoggerBuilder; |
| |
| @Override |
| public void setUp() { |
| addCommonTestCode(); |
| initializeTestLoggerBuilder(); |
| } |
| |
| public void testAmbiguousClassLiteral() { |
| sourceOracle.addOrReplace(new MockJavaResource("test.SplitPoint3") { |
| @Override |
| public CharSequence getContent() { |
| StringBuffer code = new StringBuffer(); |
| code.append("package test;\n"); |
| code.append("import com.google.gwt.core.client.GWT;\n"); |
| code.append("public class SplitPoint3 {\n"); |
| code.append(" void doStuff() {\n"); |
| // Intentionally reuse SplitPoint1.class |
| code.append(" GWT.runAsync(SplitPoint1.class, null);\n"); |
| code.append(" }\n"); |
| code.append("}\n"); |
| return code; |
| } |
| }); |
| |
| addSnippetImport("test.SplitPoint3"); |
| expectError("Line 8: Multiple runAsync calls are named test.SplitPoint1"); |
| expectError("One call is at '/mock/test/SplitPoint1.java:5'"); |
| expectError("One call is at '/mock/test/SplitPoint3.java:5'"); |
| testSnippet("RunAsyncCode.runAsyncCode(SplitPoint1.class);"); |
| } |
| |
| public void testNonClassLiteral() { |
| expectError("Line 7: Only a class literal may be passed to runAsyncCode"); |
| testSnippet("RunAsyncCode.runAsyncCode(new SplitPoint1().getClass());"); |
| } |
| |
| public void testNonExistentSplitPoint() { |
| expectError("Line 7: No runAsync call is named java.lang.String"); |
| testSnippet("RunAsyncCode.runAsyncCode(String.class);"); |
| } |
| |
| private void addCommonTestCode() { |
| addSnippetImport("com.google.gwt.core.client.prefetch.RunAsyncCode"); |
| |
| sourceOracle.addOrReplace(new MockJavaResource("test.SplitPoint1") { |
| @Override |
| public CharSequence getContent() { |
| StringBuffer code = new StringBuffer(); |
| code.append("package test;\n"); |
| code.append("import com.google.gwt.core.client.GWT;\n"); |
| code.append("public class SplitPoint1 {\n"); |
| code.append(" void doStuff() {\n"); |
| code.append(" GWT.runAsync(SplitPoint1.class, null);\n"); |
| code.append(" }\n"); |
| code.append("}\n"); |
| return code; |
| } |
| }); |
| addSnippetImport("test.SplitPoint1"); |
| |
| sourceOracle.addOrReplace(new MockJavaResource("test.SplitPoint2") { |
| @Override |
| public CharSequence getContent() { |
| StringBuffer code = new StringBuffer(); |
| code.append("package test;\n"); |
| code.append("import com.google.gwt.core.client.GWT;\n"); |
| code.append("public class SplitPoint2 {\n"); |
| code.append(" void doStuff() {\n"); |
| code.append(" GWT.runAsync(SplitPoint2.class, null);\n"); |
| code.append(" }\n"); |
| code.append("}\n"); |
| return code; |
| } |
| }); |
| addSnippetImport("test.SplitPoint2"); |
| } |
| |
| private void expectError(String msg) { |
| testLoggerBuilder.expectError(msg, null); |
| } |
| |
| private void initializeTestLoggerBuilder() { |
| testLoggerBuilder = new UnitTestTreeLogger.Builder(); |
| testLoggerBuilder.setLowestLogLevel(TreeLogger.ERROR); |
| expectError("Errors in '/mock/test/EntryPoint.java'"); |
| } |
| |
| private void testSnippet(String codeSnippet) { |
| UnitTestTreeLogger testLogger = testLoggerBuilder.createLogger(); |
| logger = testLogger; |
| |
| try { |
| JProgram program = compileSnippet("void", codeSnippet); |
| ReplaceRunAsyncs.exec(logger, program); |
| fail("Expected a compile error"); |
| } catch (UnableToCompleteException e) { |
| // expected |
| } |
| |
| testLogger.assertCorrectLogEntries(); |
| } |
| } |