QApilot - AI-Powered Mobile App Testing
    Back to Blogs

    Security Reports That Ship With Your Release: The QA Checklist Teams Ignore

    Most QA teams test whether a mobile app works. Almost none check whether it's safe before shipping. Here's what that gap looks like and what changes when security issues live next to your functional test results.

    Mobile Testingmobile-testingqaandroidsecuritydevops

    Harini Mukesh

    Product Marketing Analyst

    There's a ritual that happens before almost every mobile app release. The QA team runs through their checklist. Test cases pass. Regression looks clean. The PM gives the thumbs up. The build ships.

    And somewhere in that process, nobody checked if the app was running with a debug certificate. Nobody looked at whether microphone access was being requested for a feature that doesn't need it. Nobody noticed that three broadcast receivers were left open to any other app on the device.

    Not because the team was careless. Because that's just not what the QA checklist looked like.

    I've been thinking about this gap a lot lately, and I want to walk through what a security-aware QA process actually looks like for mobile apps, why most teams skip it, and what changes when security issues land right next to your functional test results.


    Why Security Stays Off the QA Radar

    The honest answer is that security testing has always lived in a different lane. You finish QA, hand off to a security team (if you have one), they run a scan separately, findings come back in a spreadsheet, and by that point the release is already being pressured. Anything non-critical gets deferred to "next sprint."

    The problem isn't intent. It's tooling and process. When security issues live in a separate tool, with a separate workflow, most QA engineers never see them. And if you don't see them, you can't include them in your release sign-off.


    What Static Analysis Actually Checks (And Why QA Should Care)

    When you run a static analysis scan on a mobile APK, you're not running the app. You're reading the package itself. Think of it like auditing a building's blueprints before anyone moves in. You're looking at what permissions were declared, how components are wired together, what's baked into the binary.

    Here's what the main categories of issues actually mean in plain terms:

    Permissions

    The app declares what device features it wants access to. Some of these are fine, internet access, vibration. Some are dangerous, fine GPS location, record audio, read contacts. The question isn't just "does the app need these" but "does it need all of these, and are they justified?" An app requesting microphone, fine location, and boot-on-start permissions together is worth looking at twice. OWASP's Mobile Top 10 lists over-privileged apps as one of the most common and exploitable issues in mobile security.

    Manifest misconfigurations

    The manifest is a config file every Android app ships with. It declares what the app is allowed to do, what components it has, how it talks to the OS. Issues here include cleartext traffic being allowed, the app supporting dangerously old Android versions, and components being accidentally left open to other apps. None of this is code, it's all configuration, but it can cause real damage.

    Certificate issues

    Every app has to be digitally signed before it can be distributed. During development you use a debug certificate, which is loose and meant for testing. Before production you're supposed to swap it for a proper production certificate. A debug certificate in a production build is a high severity issue, and it's exactly the kind of thing that slips through when nobody is looking.

    Hardcoded secrets

    API keys, tokens, and credentials sometimes end up baked directly into the app binary during development. Static analysis surfaces these. They shouldn't ship.

    Tracker detection

    Third-party SDKs bundled into the app, analytics, advertising, crash reporting, are catalogued. This matters for privacy compliance and gives you a clear picture of what data is being collected and where it's going.


    A Real Example Worth Paying Attention To

    This one happened earlier this year, and it's a good illustration of why the hardcoded secrets check isn't just housekeeping.

    In April 2026, security researchers at CloudSEK scanned the top 10,000 Android apps and found 32 Google API keys hardcoded across 22 popular applications with a combined install base of over 500 million users. Apps like OYO, Google Pay for Business, and ELSA Speak were in that list.

    Here's where it gets interesting. These API keys were not embedded by mistake. Developers followed Google's own documentation, which had long classified that key format as safe for client-side use. But when Google enabled Gemini on these projects, every existing API key on the project silently inherited access to the AI endpoints. Keys that were harmless became live credentials to one of the most powerful AI systems in the world, overnight, without any code change on the developer's side.

    Researchers confirmed actual data exposure in at least one case, accessing user-uploaded audio files through an exposed key. And the billing damage from similar exposures? One solo developer lost $15,400 in a single night. A team in Japan was hit for roughly $128,000.

    The thing that stays with me about this is that a static analysis scan would have flagged these keys. Not because the scan knew Gemini was going to become a problem, but because hardcoded keys are a known issue regardless of what they currently access. The checklist item existed. The check just wasn't happening consistently.


    Here's How QApilot Handles This

    This is where I want to show rather than tell. QApilot generates a security report alongside every test run automatically. No separate tool, no handoff, no extra setup beyond flipping one toggle when you upload your app.

    This video walks through what that actually looks like in practice, from enabling the toggle to reading the issues across Manifest Analysis, Certificate Analysis, and Code Analysis.

    What I find useful about this is the Recommendation column. It doesn't just tell you something is wrong. It tells you exactly what to change and where. That's a different experience from receiving a spreadsheet of issues after code freeze, when nobody wants to reopen anything.

    And when the report lives next to your functional test results, it stops being something you defer. A HIGH severity issue sitting next to two failed test cases gets treated the same way a failed test case does. It becomes part of the release conversation, not an afterthought.


    The Bigger Point

    I'm not saying every QA engineer needs to become a security expert. That's not realistic and it's not the point.

    The point is that there's a category of issues that are consistently skipped before release, not because they're hard to find but because nobody set up the workflow to look for them. A debug certificate, an over-privileged permission, a misconfigured manifest component, these are not subtle vulnerabilities. They show up immediately in any static scan. They just don't show up in the QA checklist.

    The CloudSEK example is a good reminder that the cost of skipping this check doesn't always look like a traditional breach. Sometimes it's a billing spike that hits overnight. Sometimes it's user data sitting in an accessible cache that nobody knew was exposed. The common thread is that the risk was well understood, and the check still wasn't part of the release process.

    Adding security to your release process doesn't have to mean a major overhaul. It can start with one toggle and one more report in your test run. That alone catches the obvious stuff before it ships.

    Written by

    Harini Mukesh

    Harini Mukesh

    LinkedIn

    Product Marketing Analyst

    Harini is a Product Marketing Analyst at QApilot with a background in Psychology and Data Analytics. She is interested in understanding user behavior and translating insights into structured, meaningful solutions. She enjoys working at the intersection of data, content, and product thinking, and is particularly curious about how technology and human behavior come together to shape better user experiences.

    Read More...

    Get started

    Start Your Journey to Smarter Mobile App QE

    Rethink how your team approaches mobile testing.