그림 그리는 개발자
  • 안드로이드 디바이스가 절전모드일 때 발생한 이슈
    2022년 10월 01일 18시 05분 42초에 업로드 된 글입니다.
    작성자: 루루개발자

    안녕하세요. 루루개발자 입니다.

    최근 안드로이드 디바이스의 절전모드로 인해 겪었던 이슈에 대해 공유드리고자 합니다.

     

    이슈가 생긴 서비스의 플로우는 어떻게 되나?

    어떤 서비스의 로그인 페이지가 있습니다. A 앱에서는 이 로그인 페이지를 웹뷰로 표시하고, 로그인 페이지에서 "로그인" 버튼을 클릭하면 B 앱이 위에 표시되며 로그인이 진행 된 후 B 앱이 종료되며 다시 A 앱의 웹뷰 화면으로 돌아가게 됩니다.

     

    발생한 이슈는 무엇인가?

    문제는, B앱이 호출된 직후 A앱 Webview 페이지의 javascript 에서 이후 로직이 진행되어야 하는데 해당 로직이 진행되지 않아 팝업창이 표시되지 않는 현상이 발생하였습니다. 다양한 케이스로 테스트를 해본 결과 원인은 절전모드에 있었습니다. 안드로이드 디바이스의 절전모드가 활성화 되어 있으면 브라우저가 백그라운드로 넘어가게 되면 javascript 가 동작을 하지 않게 됩니다. 그래서 이후 팝업을 띄우거나 API 호출 등을 하는 javascript 코드가 동작하지 않았던 것입니다.

     

    다른 앱은 절전모드에 대해 어떻게 대처하고 있는가?

    대표적인 예로 카카오맵을 들어볼 수 있을 것 같습니다. 카카오맵은 절전모드가 활성화 되면 다음과 같은 토스트메시지가 표시됩니다.

    절전모드 기능을 막을 수는 없으니, 사용자가 절전모드를 활성화하면 일부 기능이 정상 작동하지 않을 수 있다고 알림을 주는 방식으로 대처를 하고 있는 모습을 볼 수 있습니다.

     

    그래서 이번 이슈는 어떻게 해결을 하였나?

    네, 저희도 이번 이슈가 절전모드로인해 백그라운드에서 javascript 동작 멈춤으로 생긴 이슈라는 것을 인지하였고 다음과 같이 대처하였습니다.


    <수정 전>

    앱을 호출한 이후에 팝업창을 표시

     

    <수정 후>

    앱을 호출하기 전에 먼저 팝업창을 표시


    요점은, 백그라운드로 넘어가서 Javascript 가 비활성되기 전에 먼저 팝업창을 표시해주는 것입니다.

     

    마치며

    이번 이슈로 느낀점은 정말 다양한 케이스를 염두에 두고 테스트를 하는 것이 중요하다고 느꼈습니다.

     

     

    댓글