diff options
author | Loïc Hoguin <[email protected]> | 2015-01-10 21:22:50 +0100 |
---|---|---|
committer | Loïc Hoguin <[email protected]> | 2015-01-10 21:22:50 +0100 |
commit | 72a61573442c5a74818c9cdefb94f568250b534a (patch) | |
tree | 3321efa396494e4c90cab4eed88ea6ec7e18e419 | |
parent | b1ceed66810a962198585e3e8c49decec82d5cde (diff) | |
download | erlang.mk-72a61573442c5a74818c9cdefb94f568250b534a.tar.gz erlang.mk-72a61573442c5a74818c9cdefb94f568250b534a.tar.bz2 erlang.mk-72a61573442c5a74818c9cdefb94f568250b534a.zip |
Add triq plugin
-rw-r--r-- | README.md | 27 | ||||
-rw-r--r-- | build.config | 1 | ||||
-rw-r--r-- | erlang.mk | 30 | ||||
-rw-r--r-- | plugins/triq.mk | 29 |
4 files changed, 84 insertions, 3 deletions
@@ -450,9 +450,8 @@ EUnit plugin This plugin is available by default. It adds the following target: -`eunit` which runs all the EUnit tests found in `ebin` and -any of the additional EUnit directories specified in -`TEST_DIR`. +`eunit` which runs all the EUnit tests found in `ebin` or +the test directory specified in `TEST_DIR`. `EUNIT_OPTS` can be used to specify EUnit-specific options (e.g. `verbose`) that will be used when calling @@ -499,6 +498,28 @@ For more information please see `erl -man erl`. `SHELL_PATH` adds paths to the shell's library search path. By default this option sets the paths to `-pa ../$(PROJECT)/ebin $(DEPS_DIR)/*/ebin`. +Triq plugin +----------- + +This plugin is available by default. It adds the following +target: + +`triq` will check all the properties found in `ebin` or +the test directory specified in `TEST_DIR`. + +You can use the `t` variable to give a specific module +or function to run, for example: + +``` bash +$ make triq t=cow_http_hd +``` + +Or: + +``` bash +$ make triq t=cow_http_hd:prop_parse_accept +``` + Contributing ------------ diff --git a/build.config b/build.config index 48ac7e1..7e60d80 100644 --- a/build.config +++ b/build.config @@ -21,3 +21,4 @@ plugins/escript plugins/eunit plugins/relx plugins/shell +plugins/triq @@ -1185,3 +1185,33 @@ build-shell-deps: $(ALL_SHELL_DEPS_DIRS) shell: build-shell-deps $(gen_verbose) erl $(SHELL_PATH) $(SHELL_OPTS) + +# Copyright (c) 2015, Loïc Hoguin <[email protected]> +# This file is part of erlang.mk and subject to the terms of the ISC License. + +.PHONY: triq + +# Targets. + +tests:: triq + +define triq_run +$(ERL) -pa $(CURDIR)/ebin $(DEPS_DIR)/*/ebin \ + -eval "try $(1) of true -> halt(0); _ -> halt(1) catch error:undef -> io:format(\"Undefined property or module~n\"), halt() end." +endef + +ifdef t +ifeq (,$(findstring :,$(t))) +triq: test-build + @$(call triq_run,triq:check($(t))) +else +triq: test-build + @echo Testing $(t)/0 + @$(call triq_run,triq:check($(t)())) +endif +else +triq: test-build + $(eval MODULES := $(shell find ebin -type f -name \*.beam \ + | sed "s/ebin\//'/;s/\.beam/',/" | sed '$$s/.$$//')) + $(gen_verbose) $(call triq_run,[true] =:= lists:usort([triq:check(M) || M <- [$(MODULES)]])) +endif diff --git a/plugins/triq.mk b/plugins/triq.mk new file mode 100644 index 0000000..8a77c91 --- /dev/null +++ b/plugins/triq.mk @@ -0,0 +1,29 @@ +# Copyright (c) 2015, Loïc Hoguin <[email protected]> +# This file is part of erlang.mk and subject to the terms of the ISC License. + +.PHONY: triq + +# Targets. + +tests:: triq + +define triq_run +$(ERL) -pa $(CURDIR)/ebin $(DEPS_DIR)/*/ebin \ + -eval "try $(1) of true -> halt(0); _ -> halt(1) catch error:undef -> io:format(\"Undefined property or module~n\"), halt() end." +endef + +ifdef t +ifeq (,$(findstring :,$(t))) +triq: test-build + @$(call triq_run,triq:check($(t))) +else +triq: test-build + @echo Testing $(t)/0 + @$(call triq_run,triq:check($(t)())) +endif +else +triq: test-build + $(eval MODULES := $(shell find ebin -type f -name \*.beam \ + | sed "s/ebin\//'/;s/\.beam/',/" | sed '$$s/.$$//')) + $(gen_verbose) $(call triq_run,[true] =:= lists:usort([triq:check(M) || M <- [$(MODULES)]])) +endif |