Large Language Models and Simple, Stupid Bugs
Kevin Jesse, Toufique Ahmed, Premkumar T. Devanbu, Emily Morgan
TL;DR
The study investigates how large language models used for code completion, notably Codex, generate single-statement bugs (SStuBs) and how prompting strategies influence outcomes. Using the ManySStuBs4J Java dataset across Codex, PolyCoder, and CodeGen, it shows that LLMs produce about twice as many SStuBs as patches, but can avoid a meaningful fraction of bugs when prompted wisely. The most effective mitigation comes from automatically generated natural language comments inserted into prompts, which improve bug/patch ratios and patch rates, even when comments themselves contain minor inaccuracies. The findings highlight both the risk and potential of AI-assisted coding and point to practical practices, like automated commenting, to steer LLMs toward safer, more maintainable code.
Abstract
With the advent of powerful neural language models, AI-based systems to assist developers in coding tasks are becoming widely available; Copilot is one such system. Copilot uses Codex, a large language model (LLM), to complete code conditioned on a preceding "prompt". Codex, however, is trained on public GitHub repositories, viz., on code that may include bugs and vulnerabilities. Previous studies [1], [2] show Codex reproduces vulnerabilities seen in training. In this study, we examine how prone Codex is to generate an interesting bug category, single statement bugs, commonly referred to as simple, stupid bugs or SStuBs in the MSR community. We find that Codex and similar LLMs do help avoid some SStuBs, but do produce known, verbatim SStuBs as much as 2x as likely than known, verbatim correct code. We explore the consequences of the Codex generated SStuBs and propose avoidance strategies that suggest the possibility of reducing the production of known, verbatim SStubs, and increase the possibility of producing known, verbatim fixes.
