Eksen : regression test selection for VHDL

Date

2018-01-26

Authors

Loyola, Jose Luis

Journal Title

Journal ISSN

Volume Title

Publisher

Abstract

Regression testing - running tests after a change - has become a critical component of software development, but as projects grow bigger it becomes a time consuming task. For this reason Regression Test Selection (RTS) techniques have become very important. RTS consists of analyzing the changes to a code base and selecting a subset of tests to be run based on these changes. In the context of regression testing, VHDL development is not so different from any other programming language. Modules have unit tests and integration tests. Similarly, the larger the project, the longer it takes to run the test suite. We propose Eksen, a tool for VHDL test selection inspired by the Ekstazi tool for Java. Eksen keeps track of which files have changed including its dependencies and uses this information to select which tests must be run. Eksen statically analyzes the VHDL file dependency tree, it determines which files are affected by the change and only run the tests from that dependency branch. By targeting only the tests on the dependency branch, Eksen can significantly reduce the test suite execution time. For evaluation purposes, we implemented two versions of Eksen: one using VUnit (an open-source VHDL testing framework). The second using a proprietary enterprise VHDL compiler. This allowed us to verify the time savings on a real industrial projects. Eksen was able to cut test time in half on some of these projects. The results of this experiment are presented in the evaluation section.

Description

LCSH Subject Headings

Citation