main-tester

Capture stdout/stderr/exit code, and replace stdin of your main function. https://gitlab.com/igrep/main-tester#readme

Version on this page:0.1.0.0
LTS Haskell 12.24:0.1.0.0
Stackage Nightly 2018-12-19:0.2.0.0
Latest on Hackage:0.2.0.0

See all snapshots main-tester appears in

Apache-2.0 licensed by Yuji Yamamoto
Maintained by whosekiteneverfly@gmail.com

Module documentation for 0.1.0.0

main-tester

Capture stdout/stderr/exit code, and replace stdin of your main function.

Why?

Against the best practice, I often prefer large, end-to-end (E2E) tests.
Because:

  • E2E tests can directly test your users’ requirement.
  • E2E tests can detect bugs caused by misassumption of external components
    • Which happenes relatively more often than the others, according to my experience.
  • I often write small programs where E2E tests are sufficient.

This library main-tester provides utility functions for E2E testing of your CLI applications.
With main-tester, You can test your apps with arbitrary stdin data, check their output and exit code.

Comparison with silently and System.IO.Fake

  • Can test exit code of your main.
  • All input and outputs are strict bytestrings except the command line arguments, which is very important when testing with non-UTF8 input and output.
  • Currently doesn’t support suppressing stdout and stderr (Pull request welcome!).

Usage

See the document of Test.Main module.

Changes

0.2.0.0

  • Breaking change:
    • Add prException field to ProcessResult.
    • Now captureProcessResult catches any exception (including ExitCode) thrown by the given action (usually your main function).
      • The caught exception is available by prException function (except ExitCode).
  • :new: Add withEnv function.

0.1.0.0

  • Initial release.
Depends on 3 packages:
Used by 1 package:
comments powered byDisqus