Я пытался сделать что-то похожее на Как сделать два разных исходных каталога в выводе Makefile в один каталог bin? , чтобы у меня были эти файлы (относительно корня моего проекта):
Emakefile:
% EMakefile
% -*- mode: erlang -*-
{["src/*", "src/*/*", "src/*/*/*"],
[{i, "include"}, {outdir, "ebin"}, debug_info]}.
test/Emakefile:
% EMakefile
% -*- mode: erlang -*-
{["../src/*", "../src/*/*", "../src/*/*/*"],
[{i, "../include"}, {outdir, "../ebin"}, debug_info, {d, 'TEST'}]}.
Makefile:
EPATH=-pa ebin
all: before_compile
erl -make
all_test: before_compile
cd test
erl -make
cd ..
before_compile: mk_ebin copy_sqlite create_db copy_config copy_dot_app
test: all_test
erl -noshell $(EPATH) \
-s tests run \
-s init stop
rm -f ct.db
clean:
rm -fv ebin/*
... dependencies of before_compile
Проблема в том, что запуск make test
не перекомпилирует никакие модули, которые уже скомпилированы с помощью make
. Кажется, erl -make
не заботится о том, что они были скомпилированы без определения TEST
, он просто проверяет, что сами модули старше, чем файлы-лучи. Как мне заставить его перекомпилировать (и избежать перекомпиляции, когда она не нужна)?
ОБНОВЛЕНИЕ : странно, при запуске make all_test
сразу после make clean
, оказывается, что . / Emakefile
используется вместо test / Emakefile
: я получаю
Recompile: src/tests
Recompile: src/server_protocol_client
и т. Д. и никаких тестов вместо
Recompile: ../src/tests
Recompile: ../src/server_protocol_client
, которые я получаю, делая cd test; erl -make
вручную. Есть идеи, почему? В любом случае, я решил эту проблему, удалив test / Emakefile
и заменив all_test
в Makefile
:
all_test: before_compile
erl -noshell -eval "make:all([{d, 'TEST'}])." -s init stop