#1 HOLIX Android 배포, 그리고…
21년 7월 말, 심사를 통과하고 얼마 있지 않아 팀 내외부로부터 텍스트 수정 관련 이슈를 제보해주시는 분들이 생겼습니다.
제보해주신 고객님과 소통하여 문제를 재현해냈는데 삼성 키보드의 문제라는 것을 특정했습니다. 그리고 삼성 키보드의 다양한 옵션들을 활성화/비활성화 해보며 문제가 재현되는 조건을 찾을 수 있었습니다.
아래와 같은 조건에서 메시지 커서를 중간으로 옮겨 메시지를 수정하면 자음과 모음이 분리되었습니다.
- 삼성 키보드
- 문구 추천 on (기본값 on)
- 텍스트 입력 composable (BasicTextField, Material 2,3 TextField)
안드로이드 기기 중 삼성 기종의 비율은 절대적이며, 문구 추천 옵션은 기본값이 활성인지라 대다수의 사용자는 문제를 겪을 것이 예상 되었습니다. 일단 문구 추천을 끄는 임시 방편 해결책을 두고 빠르게 문제 해결을 시작했습니다.
#2 AndroidView + EditText를 통한 해결
저희 서비스의 코어 액션은 메시지를 남기는 것입니다. 카카오톡이나 업무 메신저등, 작성 중이던 메시지를 수정하는 일은 자주 발생하는 일이므로 빠른 수정이 필요했습니다. 다행히 저희는 ExoPlayer, WebView 등을 사용하기 위해 AndroidView를 활용하는 법에 대해 어느 정도 학습이 되어 있었고, EditText를 사용하여 문제를 해결할 수 있을 것이라 기대했습니다.
가장 시급한 부분이 메시지 작성 컴포넌트인데, TextField의 Focus, AnnotatedString, VisualTransformation, onTextLayout등 Compose의 특성을 활용한 것을 Composable 내 AndroidView의 EditText를 통해서 달성해야했습니다. 😇
어려움이 있었지만, 약 일주일 정도 소요하여 기존의 메시지 입력 컴포넌트를 대체할 수 있는 수준으로 완성되었고, 새 앱 배포를 통해 시급한 문제를 해결했습니다. 🎉
그 후, 여러 요구사항을 만족할 수 있는 HolixTextField
를 구현하여 회원가입/로그인/검색 등 앱 내에 있는 모든 TextField를 대체했습니다.
#3 이슈 해결을 위한 노력 — Issue Tracker
현재 시점에서는 어떨지 모르겠는데, 당시엔 Stack Overflow보다 Issue Tracker를 통해 유용한 정보를 더 많이 얻을 수 있었습니다.
문제를 인지한 21년 8월 초, 재현을 위한 간단한 코드와 함께 Issue를 작성했습니다. 제목에 Korean
이라는 좁은 scope의 단어가 포함되어서 그런지 높은 Priority는 받지 못하고 분류, hotlist 등 구글러가 아니면 볼 수 없는 업데이트만 종종 오고 있었습니다.
11월 쯤, 우연찮게 Compose 도입 사례에 대해 구글 분들과 세션을 가질 수 있었습니다. 이 이슈에 대해서는 발생한 기기 및 Android 버전 등 좀 더 세분화된 재현 조건이 필요할 수 있다 하셔서 정보를 추가 했지만 업데이트는 없었습니다.
그러던 중 해가 바뀌고 1월 말, 저의 소심한 Any updates?
에 반응을 한건지 드디어 담당자가 배정이 되었습니다. 곧바로 다른 이슈와 duplicated
마킹이 되어 함께 해결이 되었다는 업데이트가 떴습니다🙏 기쁜 마음에 해당 commit에 대한 Snapshot을 테스트 해봤지만, 여전히 문제는 발생하고 있었습니다.
이대로 해결이 되었다고 처리될 뻔 했지만, 저의 업데이트로 담당자가 duplicated
라벨을 제거하고 문제에 대한 재조사를 해줬습니다. 곧 타이밍이 문제 원인인 것 같다며 해결 방법까지 밝혔지만 확신할 수 없다는 답변과 함께 미완의 해결책만 남게 되었습니다.
#4 이슈 해결을 위한 노력 — 삼성 멤버스
저는 삼성 키보드에서만 문제가 발생했기 때문에, 당연히 삼성 쪽 귀책 사유가 있을 거라 생각했습니다. 문제 발생 후 삼성 키보드 앱 내 문의 기능을 통해 로그와 문제 상황 설명을 보냈는데 첫 답변이 너무 실망스러웠습니다.
일단 문의에 대한 답변을 받은 시점은 1.0이 정식 출시된 상황 이었고, 삼성 키보드에서만 문제가 발생하는 상황에서
해결 방안은 없습니다. 양해바랍니다.
라는 식의 답변은 아직도 최악이었던 것 같습니다. 다시 정중하게 문의를 넣은 결과 이전보다 상세한 설명을 들을 수 있었습니다.
하지만, 위에 언급된 getTextBeforeCursor
로직은 라이브러리 내부 구현이라 저희가 어떻게 해볼 여지가 없었고, IME (Input Method Editor)에 대한 이해 없이 잘 와닿는 답변은 아니었습니다. TextFieldValue값을 디버거로 찍어보고 최대한 라이브러리 수정없이 해결해보려 노력했으나 큰 성과는 없었습니다. 이런 힌트들은 Issue Tracker를 통해 구글에도 전달했습니다.
#5 드디어 해결 🎉 1+1 당해버린 한국어(?)
저는 2주에 한번 있는 배포 노트, 그리고 그것을 넘어 현재 개발 중인 사안들 까지 종종 모니터링 하는 편입니다. 안드로이드의 멋진 부분은 오픈 소스라는 것입니다. 코드의 변경사항들은 아래와 같이 다양한 곳에서 확인할 수 있습니다.
이 중 저는 사용자 경험이 좀 더 좋은 Github를 활용했고, BasicTextField
가 포함된 foundation
라이브러리의 commit들을 모니터링 했습니다. TextInputConnection
등등 관련된 class, function등의 이름이 적혀있을 때마다 두근 거리는 마음으로 변경사항을 확인했지만 관련이 없는 경우가 더 많았습니다.
그러던 중… 얼마 전인 22년 7월 28일, 이런 commit과 Issue Tracker의 내용을 확인합니다.
일본어에서 키보드 관련 이슈가 있다는 것인데, 삼성 측에서 준 힌트 getTextBeforeCursor
, 구글러가 확신하지 못했지만 원인으로 지목했던 timing 이슈 등 모든 부분에서 닮아 있었습니다.
바로 Snapshot Build를 테스트 하고자 CI에서 해당 변경사항에 대한 Build ID를 찾았습니다.
그 결과…
- BasicTextField (foundation-1.3.0-SNAPSHOT)
- TextField (material-1.3.0-SNAPSHOT)
- TextField(material3–1.0.0-SNAPSHOT)
모든 텍스트 입력 컴포넌트가 정상적으로 작동하는 것을 확인할 수 있었습니다. 🎉🎉🎉🎉🎉🎉🎉🎉
단, material이나 material3 내부는 foundation 1.2.0-rc02를 사용하게 되어있는데, 의존성 전이가 이루어진 것 같습니다. Snapshot 빌드의 특성에 따른 의존성 conflict인 것 같습니다.
마치며
Jetpack Compose, 어떤가요? 도입할만한가요?
라는 질문을 들었을 때 선뜻 권하기 어려웠던게 TextField와 같이 기본적으로 잘 동작할 것으로 예상되는 부분에 문제가 있다는 것이었습니다. 저는 한국 사용자를 대상으로 하는 서비스가 Jetpack Compose를 도입하고자 할 때 겪을 큰 문제 중 하나가 해결되었다고 생각합니다.
마음 놓고 Compose 사용을 이어나가세요!
많은 개발자 분들이 아래와 같은 이유로 여전히 이 이슈를 인지하지 못하셨을 수 있다고 생각합니다.
- 안드로이드 에뮬레이터를 테스트 기기로 사용하는 경우가 많습니다.
- 테스트 시에는 오타를 내지 않아 수정할 일이 잘 없습니다.
실제 사용자가 겪을만한 큰 문제가 해결되었으니 마음 편히 개발하시면 될 것 같습니다.👍
Issue Tracker를 잘 활용해보세요
특히 View에서 되던 것들이 Compose에서 안되는 경우가 꽤 많은데, 이런 경우 보통 Feature Request
로 올라와있으니 Issue Tracker를 통해 가장 빠르고 정확한 업데이트를 받아보세요. 최근 배포가 된 것 중 예시로는 includeFontPadding
, Downloadable Font
등이 있습니다.
언제부터 쓸 수 있을까요?
- 글 작성 시점(22년 8월 5일) 기준 1.3.0-alpha02 버전은 여전히 문제가 발생하고 있습니다. 이 변경사항이 1.2.1에 포함될 지, 1.3.0-alpha03에 포함되어 나올지는 다음 릴리즈 날짜인 22년 8월 11일 목요일 새벽에 알 수 있을 것 같습니다. HOLIX Jetpack Compose 커뮤니티에서는 이런 최신 정보에 대해 이야기 나누고 있습니다.
- 미리 프로젝트에 적용해보고 싶으신 분들은
Build ID 8878537
를 사용해 아래 가이드에 따라 적용해보세요! (아마 최신Build ID
를 이용해도 괜찮을 겁니다. )
- 간단히 문제를 체험해보고 싶으신 분들은 아래 Github repository를 통해 apk를 받으실 수 있습니다.
긴 글 읽어주셔서 감사합니다.
Happy Compose!