Giter VIP home page Giter VIP logo

bandit's Introduction

bandit

MIT License Contributors Watchers Stars Forks Commits per year Last commit Travis CI Status AppVeyor Status Codecov Badge Codacy Badge Coverity Scan Build Status Issues Pull Requests freenode Conan Center

Human-friendly unit testing for C++11

Bandit is a framework for C++11 that wants to make working with unit tests a pleasant experience.

An example

This is a complete test application written in bandit:

#include <bandit/bandit.h>

using namespace snowhouse;
using namespace bandit;

// Tell bandit there are tests here.
go_bandit([]() {
  // We're describing how a fuzzbox works.
  describe("fuzzbox", []() {
    guitar_ptr guitar;
    fuzzbox_ptr fuzzbox;

    // Make sure each test has a fresh setup with
    // a guitar with a fuzzbox connected to it.
    before_each([&]() {
      guitar = guitar_ptr(new struct guitar());
      fuzzbox = fuzzbox_ptr(new struct fuzzbox());
      guitar->add_effect(fuzzbox.get());
    });

    it("starts in clean mode", [&]() {
      AssertThat(guitar->sound(), Equals(sounds::clean));
    });

    // Describe what happens when we turn on the fuzzbox.
    describe("in distorted mode", [&]() {
      // Turn on the fuzzbox.
      before_each([&]() {
        fuzzbox->flip();
      });

      it("sounds distorted", [&]() {
        AssertThat(guitar->sound(), Equals(sounds::distorted));
      });
    });
  });
});

int main(int argc, char* argv[]) {
  // Run the tests.
  return bandit::run(argc, argv);
}

Download

Clone the Git repository:

git clone --recursive https://github.com/banditcpp/bandit.git

or if you have already cloned the repository without --recursive, do

cd bandit
git submodule update --init --recursive

The Git repository contains several directories besides bandit itself, that is, the specifications (or tests) for bandit (in specs), the bandit website and documentation (in docs), and auxiliary tools for CMake (in cmake) and continuous integration (in util).

Installation

Bandit is header-only, so there is no need for additional compilation before you can start using it. (CMake is only necessary to compile the specs for bandit itself.)

If you want to use bandit inside your projects, add the parent directory of the bandit directory to your project's include directories and you are ready to go.

Note that you can remove all directories except the bandit directory. Also keep license and copyright information intact. You can also simply use the headers-only branch as a submodule:

git submodule add -b headers-only https://github.com/banditcpp/bandit bandit
git submodule update --init --recursive

Compilers

Bandit has been tested with the following compilers:

  • GCC ≥ 4.5
  • Clang ≥ 3.2
  • MSVC ≥ 2012

If you want to see if bandit works for your compiler, bandit is shipped with a cmake project for generating bandit's self tests. Let us know how it goes.

If your compiler does not support the C++11 features required by Bandit, we suggest that you take a look at Igloo, which is built on the same philosophy but works without C++11.

Online resources

bandit's People

Contributors

andystanton avatar aria42 avatar bcachet avatar bfoz avatar dcousens avatar e-kwsm avatar garyfurnish avatar hedtke avatar joakimkarlsson avatar keeruline avatar kimgr avatar kirkpatrickc avatar ktns avatar marc--olivier avatar martindelille avatar nabijaczleweli avatar oragonefreet avatar rhuelga avatar sbeyer avatar terala 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.