Code Monkey home page Code Monkey logo

ci-hpc's Introduction

CI & HPC · Travis (.org) branch Read the Docs download the PDF Docs PyPI GitHub Coveralls github branch

A simple framework which can monitor the performance and scalability of software packages. The framework presented here combines Continuous Integation & High Performance Computing together with a minimalistic set of Python scripts. The results can be visualised in form of static Jupyter notebook or in an interactive web page.

Features

  • automatically run benchmarks of your project
  • inspect performance and scalability of your project
  • create complex configurations with travis-like syntax build matrix capabilities (YAML format)

How to use ci-hpc?

  1. First install the framework by executing:

    pip3 install --user ci-hpc
  2. Create a configuration (file config.yaml) for your repository. In this cofiguration, you should specify several options.

    • ci-hpc needs to know, which repositories are part of your project. You can specify one or more repositories. Each repository will be cloned and checked out when installing.

    • You also need to tell the ci-hpc how to install your project.
      It can be as simple as

      ./configure; make; make install
      or pip install ./foo/

      But it can be also quite complex, you can even simplify entire process with usage of install file:
      with something like this!sh install.sh (install.sh in this case is a shell script, which contains your installation process)

    • Next thing is testing section. Here, ci-hpc needs to know, what benchmarks you want to run under what configuration. You can create complex build matrices so your configuration can be kept simple and transparent.

  3. When you are done with the configuration. You should probably verify, it is working. Assuming the following structure:

    .
    └── hello-world
       └── config.yaml
    

    Execute ci-hpc with

    cihpc --project hello-world
    
  4. If everything works, setup a mongoDB server and add collection section (once again file config.yaml):

    • ci-hpc needs to know, what results you want to store. Is it a some json profiler or yaml results? or are the timings save in a xml format? In the ci-hpc there is some general support for the json and yaml formats, but you can write your own artifact module and simply put it in the correct folder.

    • The most of the heavy lifting is already done in a parent class so adding a new collection module should be relatively easy.

  5. Now to display the results, setup a visualization server.

What's new?

  • now supporting multiple repositories within single project
  • speed up testing process by using multiple cores on a computing node
  • easily run ci-hpc on a previous commits by using commit-browser module
  • automatically determine which tests to run based on the previous results
  • webhook support, automatically start ci-chp upon new commit

What's to come?

  • run extra tests when suspecting significant performance change
  • create web visualisation configuration from analyzing records in database

CI-HPC showcase

Interactive website

  • Demo site 1
  • Demo site 2
  • Demo site 2
  • Demo site gif

Documentation & Installation

Read the docs at ci-hpc.readthedocs.io to know more about installation.

ci-hpc's People

Contributors

janhybs 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.