Using Thesaurus-Based Tag Clouds to Improve Test-Driven Code Search

  • Otavio Augusto Lazzarini Lemos UNIFESP
  • Adriano Carvalho de Paula
  • Gustavo Konishi UNIFESP
  • Joel Ossher University of California at Irvine
  • Sushil Bajracharya Black Duck Software, Inc.
  • Cristina Lopes University of California at Irvine

Resumo


Test-driven code search (TDCS) is an approach to code search and reuse that uses test cases as inputs to form the search query. Together with the test cases that provide more semantics to the search task, keywords taken from class and method names are still required. Therefore, the effectiveness of the approach also relies on how good these keywords are, i.e., how frequently they are chosen by developers to name the desired functions. To help users choose adequate words in their query test cases, visual aids can be used. In this paper we propose thesaurus-based tag clouds to show developers terms that are more frequently used in the code repository to improve their search. Terms are generated by looking up words similar to the initial keywords on a thesaurus. Tag clouds are then formed based on the frequency in which these terms appear in the code base. Our approach was implemented with an English thesaurus as an extension to CodeGenie, a Java- and Eclipse-based TDCS tool. Our evaluation shows that the approach can help improve the number of returned results. We also noticed the visual aid can be especially useful for non-native speakers of the language in which the code repository is written. These users are frequently unaware of the most common terms used to name specific functionality in the code, in the given language.
Palavras-chave: Tag clouds, Thesauri, Cloud computing, Visualization, Search problems, Color, code search, test-driven code search, software reuse
Publicado
29/09/2013
LEMOS, Otavio Augusto Lazzarini; PAULA, Adriano Carvalho de; KONISHI, Gustavo; OSSHER, Joel; BAJRACHARYA, Sushil; LOPES, Cristina. Using Thesaurus-Based Tag Clouds to Improve Test-Driven Code Search. In: SIMPÓSIO BRASILEIRO DE COMPONENTES, ARQUITETURAS E REUTILIZAÇÃO DE SOFTWARE (SBCARS), 7. , 2013, Brasília/DF. Anais [...]. Porto Alegre: Sociedade Brasileira de Computação, 2013 . p. 99-108.