Automated End-to-End Dynamic Taint Analysis for WhatsApp. Cela, S., Ciancone, A., Gustafsson, P., Hajdu, Á., Jia, Y., Kapus, T., Koshtenko, M., Lewis, W., Mao, K., & Martac, D. In Companion Proceedings of the 32nd ACM International Conference on the Foundations of Software Engineering, pages 21–26, 2024. ACM.
Automated End-to-End Dynamic Taint Analysis for WhatsApp [pdf]Pdf  Automated End-to-End Dynamic Taint Analysis for WhatsApp [pdf]Slides  Automated End-to-End Dynamic Taint Analysis for WhatsApp [link]Link  doi  abstract   bibtex   9 downloads  
Taint analysis aims to track data flows in systems, with potential use cases for security, privacy and performance. This paper describes an end-to-end dynamic taint analysis solution for WhatsApp. We use exploratory UI testing to generate realistic interactions and inputs, serving as data sources on the clients and then we track data propagation towards sinks on both client and server sides. Finally, a reporting pipeline localizes tainted flows in the source code, applies deduplication, filters false positives based on production call sites, and files tasks to code owners. Applied to WhatsApp, our approach found 89 flows that were fixed by engineers, and caught 50% of all privacy-related flows that required escalation, including instances that would have been difficult to uncover by conventional testing.

Downloads: 9