The Scientific World Journal (Jan 2013)

Compositional Mining of Multiple Object API Protocols through State Abstraction

  • Ziying Dai,
  • Xiaoguang Mao,
  • Yan Lei,
  • Yuhua Qi,
  • Rui Wang,
  • Bin Gu

DOI
https://doi.org/10.1155/2013/171647
Journal volume & issue
Vol. 2013

Abstract

Read online

API protocols specify correct sequences of method invocations. Despite their usefulness, API protocols are often unavailable in practice because writing them is cumbersome and error prone. Multiple object API protocols are more expressive than single object API protocols. However, the huge number of objects of typical object-oriented programs poses a major challenge to the automatic mining of multiple object API protocols: besides maintaining scalability, it is important to capture various object interactions. Current approaches utilize various heuristics to focus on small sets of methods. In this paper, we present a general, scalable, multiple object API protocols mining approach that can capture all object interactions. Our approach uses abstract field values to label object states during the mining process. We first mine single object typestates as finite state automata whose transitions are annotated with states of interacting objects before and after the execution of the corresponding method and then construct multiple object API protocols by composing these annotated single object typestates. We implement our approach for Java and evaluate it through a series of experiments.