Learning Deep Semantics for Test Completion
Pengyu Nie, Rahul Banerjee, Junyi Jessy Li, Raymond J. Mooney, Milos Gligoric
TL;DR
The paper introduces test completion and TeCo, a transformer model that uses six static code-semantics signals plus execution-based reranking to automatically predict the next statement in a Java test method. It builds a large corpus of 130,934 test methods from 1,270 open-source projects and fine-tunes CodeT5 for the task, using beam search and a reranking stage that prefers compilable and runnable outputs. Across intrinsic lexical metrics and a functional correctness measure (compile/run), TeCo consistently outperforms syntax-only baselines and state-of-the-art test-oracle models, and shows clear benefits from execution-aware reranking and diverse code-semantics signals. The work demonstrates that incorporating execution semantics into ML models significantly improves automated test writing and provides a public corpus to advance research in ML for software testing.
Abstract
Writing tests is a time-consuming yet essential task during software development. We propose to leverage recent advances in deep learning for text and code generation to assist developers in writing tests. We formalize the novel task of test completion to automatically complete the next statement in a test method based on the context of prior statements and the code under test. We develop TeCo -- a deep learning model using code semantics for test completion. The key insight underlying TeCo is that predicting the next statement in a test method requires reasoning about code execution, which is hard to do with only syntax-level data that existing code completion models use. TeCo extracts and uses six kinds of code semantics data, including the execution result of prior statements and the execution context of the test method. To provide a testbed for this new task, as well as to evaluate TeCo, we collect a corpus of 130,934 test methods from 1,270 open-source Java projects. Our results show that TeCo achieves an exact-match accuracy of 18, which is 29% higher than the best baseline using syntax-level data only. When measuring functional correctness of generated next statement, TeCo can generate runnable code in 29% of the cases compared to 18% obtained by the best baseline. Moreover, TeCo is significantly better than prior work on test oracle generation.
