blob: 16d31bb8eb337bf6ac0a8decbfe932461a98e211 [file] [log] [blame]
// Copyright (c) 2018, 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.naming.retrace;
import static com.android.tools.r8.naming.retrace.StackTrace.TAB_AT_PREFIX;
import static org.junit.Assert.assertEquals;
import com.android.tools.r8.TestBase;
import com.android.tools.r8.TestParameters;
import com.android.tools.r8.TestParametersCollection;
import com.android.tools.r8.naming.retrace.StackTrace.StackTraceLine;
import com.android.tools.r8.utils.StringUtils;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters;
@RunWith(Parameterized.class)
public class StackTraceTest extends TestBase {
private final TestParameters parameters;
@Parameters(name = "{0}")
public static TestParametersCollection data() {
return getTestParameters().withDexRuntimes().build();
}
public StackTraceTest(TestParameters parameters) {
this.parameters = parameters;
}
private static String lineOne =
TAB_AT_PREFIX + "Test.main(Test.java:10)" + System.lineSeparator();
private static String lineTwo = TAB_AT_PREFIX + "Test.a(Test.java:6)" + System.lineSeparator();
private static String randomArtLine =
"art W 26343 26343 art/runtime/base/mutex.cc:694] ConditionVariable::~ConditionVariable "
+ "for Thread resumption condition variable called with 1 waiters."
+ System.lineSeparator();
private static String oneLineStackTrace = lineOne;
private static String twoLineStackTrace = lineTwo + lineOne;
private void testEquals(String stderr) {
StackTrace stackTrace = StackTrace.extractFromJvm(stderr);
assertEquals(stackTrace, stackTrace);
assertEquals(stackTrace, StackTrace.extractFromJvm(stderr));
}
private void checkOneLine(StackTrace stackTrace) {
assertEquals(1, stackTrace.size());
StackTraceLine stackTraceLine = stackTrace.get(0);
assertEquals("Test", stackTraceLine.className);
assertEquals("main", stackTraceLine.methodName);
assertEquals("Test.java", stackTraceLine.fileName);
assertEquals(10, stackTraceLine.lineNumber);
assertEquals(StringUtils.splitLines(oneLineStackTrace).get(0), stackTraceLine.originalLine);
assertEquals(oneLineStackTrace, stackTrace.toStringWithPrefix(TAB_AT_PREFIX));
}
private void checkTwoLines(StackTrace stackTrace) {
StackTraceLine stackTraceLine = stackTrace.get(0);
assertEquals("Test", stackTraceLine.className);
assertEquals("a", stackTraceLine.methodName);
assertEquals("Test.java", stackTraceLine.fileName);
assertEquals(6, stackTraceLine.lineNumber);
assertEquals(StringUtils.splitLines(twoLineStackTrace).get(0), stackTraceLine.originalLine);
stackTraceLine = stackTrace.get(1);
assertEquals("Test", stackTraceLine.className);
assertEquals("main", stackTraceLine.methodName);
assertEquals("Test.java", stackTraceLine.fileName);
assertEquals(10, stackTraceLine.lineNumber);
assertEquals(StringUtils.splitLines(twoLineStackTrace).get(1), stackTraceLine.originalLine);
assertEquals(twoLineStackTrace, stackTrace.toStringWithPrefix(TAB_AT_PREFIX));
}
@Test
public void testOneLineJvm() {
checkOneLine(StackTrace.extractFromJvm(oneLineStackTrace));
}
@Test
public void testOneLineArt() {
checkOneLine(
StackTrace.extractFromArt(oneLineStackTrace, parameters.getRuntime().asDex().getVm()));
checkOneLine(
StackTrace.extractFromArt(
oneLineStackTrace + randomArtLine, parameters.getRuntime().asDex().getVm()));
checkOneLine(
StackTrace.extractFromArt(
randomArtLine + oneLineStackTrace, parameters.getRuntime().asDex().getVm()));
}
@Test
public void testTwoLinesJvm() {
checkTwoLines(StackTrace.extractFromJvm(twoLineStackTrace));
}
@Test
public void testTwoLinesArt() {
checkTwoLines(StackTrace.extractFromJvm(twoLineStackTrace));
checkTwoLines(StackTrace.extractFromJvm(twoLineStackTrace + randomArtLine));
checkTwoLines(StackTrace.extractFromJvm(randomArtLine + twoLineStackTrace));
checkTwoLines(StackTrace.extractFromJvm(lineTwo + randomArtLine + lineOne));
}
@Test
public void testEqualsOneLine() {
testEquals(lineOne);
}
@Test
public void testEqualsTwoLine() {
testEquals(twoLineStackTrace);
}
}