Giter Site home page Giter Site logo

vara-tool-suite's Introduction

VaRA Tool Suite

Project Status codecov Documentation Status

branch build status
vara Python CI
vara-dev Python CI

Using VaRA with VaRA-TS

VaRA is a variability-aware framework to analyze interactions between code regions that convey a semantic meaning for the researcher, e.g., CommitRegions represent blocks of code that belongs to the same commit. Our tool suite allows the researcher to automatically run analyses provided by VaRA on different software projects. For this, we provides different preconfigured experiments and projects. Experiments abstract the actions that should be taken when analyzing a project, e.g., build, analyze, generate result graph. Projects describe how a software project should be configured and build, e.g., gzip provides all necessary information to checkout, configure, and compile the project.

Setup Tool Suite

Install dependencies

To use the VaRA Tool Suite, make sure you have the necessary packages installed. For ubuntu, you can use the following command to install them (your system has to have at least python3.6):

sudo apt install python3-dev python3-tk python3-psutil psutils ninja-build python3-pip autoconf cmake ruby curl time libyaml-dev git
sudo apt install python3-venv # If you want to install VaRA-TS in a python virtualenv

Installation from PyPI

pip3 install varats

Installation from source

Additional packages are required to build VaRA from source.

sudo apt install libsqlite3-dev libcurl4-openssl-dev libboost-all-dev libpapi-dev googletest libxml2-dev

The easiest way to install VaRA is to use the vara-buildsetup tool. You can find more information about this tool in its documentation.

Running experiments and analyzing projects

VaRA-TS provides different preconfigured experiments and projects. In order to execute an experiment on a project we use BenchBuild, an empirical-research toolkit.

Setup: Configuring BenchBuild

First, we need to generate a folder with a configuration file for BenchBuild in the vara root directory, this is done with:

vara-gen-bbconfig

Running BenchBuild experiments

Second, we change into the benchbuild folder and run an experiment that generates CommitReports for provided projects, in this case we use gzip.

cd $VARA_ROOT/benchbuild
benchbuild -vv run -E GenerateCommitReport gzip

The generated result files are place in the vara/results/$PROJECT_NAME folder and can be further visualized with VaRA-TS graph generators.

Using CaseStudy and paper configs

Reproducing results for different projects and experiments is important. To help with reproducing results, VaRA-TS proposes the concept of a CaseStudy and paper configs. Each case study specifies which revision of a project needs to be analyzed. Paper configs then group together a set of case studies that belong to the same paper, allowing the user to precisly specify which revisions of what project need to be analyzed to regenerate the results for a specific paper. For more information visit our documentation.

VaRA developer tools

VaRA-TS provides different tools to ease VaRA development.

vara-develop

vara-develop, short vd, is a helper to interact with the different VaRA project repositories when working on VaRA. The tool provides commands for showing git status, creating new-branch or checkout existing branches. Furthermore, commands to pull/push the current branches and to show currently developed feature branches f-branches. It can be used on a set of projects simultaneously. A command like:

> vd new-branch f-FooBar vara clang llvm

will create the branch f-FooBar on all three repositories.

Showing the current status of the listed projects can be done with:

> vd status clang vara
################################################################################
# Project: clang                                                               #
################################################################################
On branch vara-80-dev
Your branch is up to date with 'origin/vara-80-dev'.

nothing to commit, working tree clean

################################################################################
# Project: VaRA                                                                #
################################################################################
On branch f-InstrumentationVerifier
Your branch is up to date with 'origin/f-InstrumentationVerifier'.

nothing to commit, working tree clean

The checkout tool helps you to checkout the same branch on different projects, if one exists. Furthermore, it can easily switch all projects to vara-dev or vara by just typing:

vd checkout vara-dev

To get a full overview of the tool use vd -h and vd {sub_command} -h.

Extending the tool suite

VaRA-TS allows the user to extend it with different projects, experiments, and data representations.

BenchBuild Projects

VaRA-TS defines a set of projects that can be analyzed with benchbuild.

    benchbuild
    └── projects

BenchBuild Experiments

VaRA-TS defines a set of projects that can be analyzed with benchbuild.

    benchbuild
    └── experiments

Running tests

Running all python tests:

    python setup.py test

Running all test with coverage:

    python setup.py test --addopts "--cov=varats --cov-report term-missing"

vara-tool-suite's People

Contributors

bnico99 avatar boehmseb avatar carlschwan avatar cormensratio avatar danjujan avatar hechtlc avatar j03d03 avatar jonas-kaufmann avatar julianbreiteneicher avatar keller-1998 avatar labrenz avatar luabelt avatar marcjose avatar nflow avatar pdschubert avatar simonfedick avatar sinerum avatar tobih94 avatar vulder avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.