blob: d1556fba36c22dec751b8fe992070d371c3d374a [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.retraceproguard;
import static com.android.tools.r8.naming.retraceproguard.StackTrace.TAB_AT_PREFIX;
import static org.junit.Assert.assertEquals;
import com.android.tools.r8.naming.retraceproguard.StackTrace.StackTraceLine;
import com.android.tools.r8.utils.StringUtils;
import org.junit.Test;
public class StackTraceTest {
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));
checkOneLine(StackTrace.extractFromArt(oneLineStackTrace + randomArtLine));
checkOneLine(StackTrace.extractFromArt(randomArtLine + oneLineStackTrace));
}
@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);
}
}