| // Copyright (c) 2020, the R8 project authors. Please see the AUTHORS file |
| // for details. All rights reserved. Use of this source code is governed by a |
| // BSD-style license that can be found in the LICENSE file. |
| |
| package com.android.tools.r8.missingclasses; |
| |
| import com.android.tools.r8.CompilationFailedException; |
| import com.android.tools.r8.R8FullTestBuilder; |
| import com.android.tools.r8.TestDiagnosticMessages; |
| import com.android.tools.r8.TestParameters; |
| import com.android.tools.r8.ThrowableConsumer; |
| import com.android.tools.r8.diagnostic.DefinitionContext; |
| import com.android.tools.r8.diagnostic.internal.DefinitionMethodContextImpl; |
| import com.android.tools.r8.references.Reference; |
| import com.android.tools.r8.utils.MethodReferenceUtils; |
| import com.google.common.collect.ImmutableList; |
| import org.junit.Test; |
| |
| public class MissingClassReferencedFromUsedLambdaParameterTest extends MissingClassesTestBase { |
| |
| private final DefinitionContext[] referencedFrom = |
| new DefinitionContext[] { |
| DefinitionMethodContextImpl.builder() |
| .setMethodContext( |
| MethodReferenceUtils.methodFromMethod(I.class, "m", MissingClass.class)) |
| .setOrigin(getOrigin(I.class)) |
| .build(), |
| DefinitionMethodContextImpl.builder() |
| .setMethodContext( |
| Reference.method( |
| Reference.classFromClass(Main.class), |
| "lambda$main$0", |
| ImmutableList.of(Reference.classFromClass(MissingClass.class)), |
| null)) |
| .setOrigin(getOrigin(Main.class)) |
| .build(), |
| DefinitionMethodContextImpl.builder() |
| .setMethodContext(MethodReferenceUtils.mainMethod(Main.class)) |
| .setOrigin(getOrigin(Main.class)) |
| .build() |
| }; |
| |
| public MissingClassReferencedFromUsedLambdaParameterTest(TestParameters parameters) { |
| super(parameters); |
| } |
| |
| @Test(expected = CompilationFailedException.class) |
| public void testNoRules() throws Exception { |
| compileWithExpectedDiagnostics( |
| Main.class, |
| diagnostics -> inspectDiagnosticsWithNoRules(diagnostics, referencedFrom), |
| addInterface()); |
| } |
| |
| @Test |
| public void testDontWarnMainClassAndInterface() throws Exception { |
| compileWithExpectedDiagnostics( |
| Main.class, |
| TestDiagnosticMessages::assertNoMessages, |
| addInterface().andThen(addDontWarn(Main.class, I.class))); |
| } |
| |
| @Test |
| public void testDontWarnMissingClass() throws Exception { |
| compileWithExpectedDiagnostics( |
| Main.class, |
| TestDiagnosticMessages::assertNoMessages, |
| addInterface().andThen(addDontWarn(MissingClass.class))); |
| } |
| |
| @Test |
| public void testIgnoreWarnings() throws Exception { |
| compileWithExpectedDiagnostics( |
| Main.class, |
| diagnostics -> inspectDiagnosticsWithIgnoreWarnings(diagnostics, referencedFrom), |
| addInterface().andThen(addIgnoreWarnings())); |
| } |
| |
| ThrowableConsumer<R8FullTestBuilder> addInterface() { |
| return builder -> builder.addProgramClasses(I.class); |
| } |
| |
| static class Main { |
| |
| public static void main(String[] args) { |
| I i = mc -> {}; |
| i.m(null); |
| } |
| |
| /* private static synthetic void lambda$main$0(MissingClass mc) {} */ |
| } |
| |
| interface I { |
| |
| void m(MissingClass mc); |
| } |
| } |