Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/antp/kovacs
https://github.com/antp/kovacs
Last synced: 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/antp/kovacs
- Owner: antp
- License: other
- Created: 2014-07-13T10:18:07.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2020-03-03T22:36:02.000Z (almost 5 years ago)
- Last Synced: 2024-10-08T09:41:23.236Z (3 months ago)
- Language: Elixir
- Homepage:
- Size: 7.13 MB
- Stars: 5
- Watchers: 4
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- freaking_awesome_elixir - Elixir - A simple ExUnit test runner. (Testing)
- fucking-awesome-elixir - kovacs - A simple ExUnit test runner. (Testing)
- awesome-elixir - kovacs - A simple ExUnit test runner. (Testing)
README
# Kovacs - A simple ExUnit test runner
## Installation
Download the latest release (or clone) the repository and build Kovacs with:
MIX_ENV=prod mix escript.build
Install the application into a directory on your path
/usr/local/bin
The easiest way to do this is to create a symbolic link to kovacs in
the directory where you have downloaded the project too.ln -s ~/{project path}/kovacs /usr/local/bin/kovacs
## Dependencies
You will also need fswatch installed as Kovacs uses this to monitor the file system.
Please download fswatch for your OS from its [github repository](https://github.com/emcrisostomo/fswatch).## Quick start
kovacs can then be run in any directory by typing the following:
kovacs
By default it will monitor the __lib__ and __test__ directories.
Due to problems closing down external applications when exiting Elixir command line applications,
please enter `q` to quit Kovacs.__Important:__ Failure to do this will leave instances of fswatch running on your system and you will need to manually tidy them up.
When you save a file, Kovacs will run the corresponding test file.
The runner will look for a test file in the same directory structure as the tested file.If you have a file in:
lib/parser/filter.ex
then it will expect the test file:
test/parser/filter_test.exs
When running Kovacs, the colour output from ExUnit will not be shown. If you want to have colour output then update the projects test_helper.ex file to the following:
ExUnit.start([colors: [enabled: true]])
Kovacs will exclude any tests that are tagged with `@pending` or `@ignore`.
@tag :pending
test "It will add" do
assert 2 == 1 + 1
end## Integration tests
If a all tests pass for the last run file, Kovacs will attempt to run a file named after the directory the test file is in. This allows for targeted integration tests for all files that collaborate within a directory.
If it is the root directory then Kovacs will look for a file named `app_test.exs`.
You can toggle the running of the integration test file at any time by entering `i`.
## Configuration
if you want to watch any custom directories then you will need to supply a configuration file.
Create a Elixir configuration file e.g. kovacs.ex
with the following contents.defmodule Kovacs.Cfg do
def configure do
Kovacs.watch(["./lib/dir1", "./lib/dir2", "./test"])
end
endThis will watch the __lib/dir1__, __lib/dir2__ and __test__ directories from your project root,
for file changes.__Note:__ Do not watch sub directories of an already watched directory.
Duplicate file changes may be detected if you do.### Running
Run kovacs with the following
kovacs {optional configuration file}
__Important:__ When exiting the application press the `q` key followed by carriage return.
Do not exit kovacs with `ctrl-c`. This will leave fswatch instances running,
which you will need to manually clean up -- you have been warned.## Author
Copyright © 2014 Component X Software, Antony Pinchbeck
Released under Apache 2 License