비정상 종료로 구현 테스트하기
테스트 비정상 종료를 강제로 적용하는 데 사용할 수 있는 코드를 앱에 추가합니다.
앱의
MainActivity
에서 다음 코드를 사용하여, 누르면 비정상 종료를 일으키는 버튼을 앱에 추가할 수 있습니다. 버튼에 'Test Crash'라는 라벨이 지정되어 있습니다.Kotlin+KTX
val crashButton = Button(this) crashButton.text = "Test Crash" crashButton.setOnClickListener { throw RuntimeException("Test Crash") // Force a crash } addContentView(crashButton, ViewGroup.LayoutParams( ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT))
Java
Button crashButton = new Button(this); crashButton.setText("Test Crash"); crashButton.setOnClickListener(new View.OnClickListener() { public void onClick(View view) { throw new RuntimeException("Test Crash"); // Force a crash } }); addContentView(crashButton, new ViewGroup.LayoutParams( ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT));
앱을 빌드하고 실행합니다.
앱의 첫 번째 비정상 종료 보고서를 전송하려면 테스트 비정상 종료를 강제로 적용합니다.
테스트 기기 또는 에뮬레이터에서 앱을 엽니다.
앱에서 위 코드를 사용하여 추가한 'Test Crash' 버튼을 누릅니다.
앱이 비정상 종료된 후에는 앱을 다시 시작하여 비정상 종료 보고서를 Firebase에 전송할 수 있도록 합니다.
Crashlytics 대시보드로 이동하여 Firebase 콘솔에서 테스트 비정상 종료를 확인하세요.
Console을 새로고침하고 5분 후에도 테스트 비정상 종료가 표시되지 않으면 디버그 로깅을 사용 설정해 보세요(다음 섹션).
Crashlytics 디버그 로깅 사용 설정
Crashlytics 대시보드에 테스트 비정상 종료가 표시되지 않는 경우 Crashlytics의 디버그 로깅을 사용하면 문제를 추적하는 데 도움이 됩니다.
Crashlytics의 디버그 로깅을 사용 설정하고 확인합니다.
앱을 실행하기 전에 다음
adb
셸 플래그를DEBUG
로 설정합니다.adb shell setprop log.tag.FirebaseCrashlytics DEBUG
다음 명령어를 실행하여 기기 로그의 로그를 확인합니다.
adb logcat -s FirebaseCrashlytics
테스트 비정상 종료를 강제로 적용합니다. 이 페이지의 첫 번째 섹션에서 이를 수행하는 방법을 설명합니다.
logcat 출력에 다음 메시지나 코드
204
가 있는지 확인합니다. 메시지나 코드를 통해 앱이 Firebase로 비정상 종료를 전송하는지 확인 가능합니다. 드림Crashlytics report upload complete
Crashlytics 대시보드에 이 로그가 표시되지 않거나 테스트 비정상 종료가 표시되지 않는 경우 5분 후에 Firebase 콘솔의 Firebase 지원 및 문제를 해결하는 데 도움을 드릴 수 있습니다.
다음 단계
- 보고 선택 옵션, 로그, 키를 추가하고 심각하지 않은 오류를 추적하여 비정상 종료 보고서 설정을 맞춤설정하세요.