Skip to content

Latest commit

 

History

History
80 lines (69 loc) · 4 KB

README.md

File metadata and controls

80 lines (69 loc) · 4 KB

TESTING

general statements about testing

  • Confidence: Write the code once and use it confidently everywhere else
  • Confidence: Correctness is main requirement for scientific code

the agile development workflow

  • add a test for the new functionality
  • implement the new functionality (!) ⟶ yes, after implementing the test ;)
  • run test suite ⟶ debug until all tests are green again
  • optimize and/or refactor

test automation

  • pytest
    • how does it work? the test_ functions
    • the assert statement
    • our first test suite
  • side effect: trust
  • side effect: faster development cycles
  • side effect: better code

testing scientific code

random bits

  • tests should be short and quick to execute
  • tests should be easy to read
  • tests should exercise one thing
  • test simple but general cases
  • test corner cases and boundary conditions
  • numerical fuzzing and the importance of the random seed (np.random.RandomState and np.random.seed)
  • for learning algorithms, for example to verify that they don't get stuck in local optima:
    • test stability of one optimal solution:
      • start from optimal solution
      • start from little perturbation of optimal solution
    • generate data from the model with known parameters and recover the parameters

the problem with random numbers in the tests

  • how do we make sure tests failures are reproducible if we use random data?
  • different approaches, with different level of complexity:

Continuous integration

We will use Travis CI (but there are many others). Note that it's for free only for public repositories:

  • login to https://travis-ci.com/ with your GitHub account
  • authorize Travis CI to have access to the repos
  • put a .travis.yml file in the repo
  • now your PR will automatically trigger a travis CI build
  • if the author of a PR does not have an account on Travis, the PR may not trigger a travis CI build (they are flagged as "abuse" on Travis).
  • you can manually trigger a build if you go to the travis repo page: https://travis-ci.com/USERNAME/REPONAME/ under More options...