summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFred Hebert <mononcqc@ferd.ca>2017-12-15 11:59:35 -0500
committerGitHub <noreply@github.com>2017-12-15 11:59:35 -0500
commit9101a84f49aa58057d6ab9edccaf5409a8b849e8 (patch)
treeca70dd2a607da5d8c1ac4f1db1064046a62ec7c8
parentb7c021b3f216bdd03d286b467889d03b142f4bf3 (diff)
parentd0f958d59d1f87bda8d1d6c724a1af18af288324 (diff)
Merge pull request #1694 from ferd/escript-with-ebin-subdir
Fix escriptize failure when ebin/ has subdirs
-rw-r--r--src/rebar_prv_escriptize.erl3
-rw-r--r--test/rebar_escriptize_SUITE.erl27
2 files changed, 27 insertions, 3 deletions
diff --git a/src/rebar_prv_escriptize.erl b/src/rebar_prv_escriptize.erl
index 1da70f8..3d6e708 100644
--- a/src/rebar_prv_escriptize.erl
+++ b/src/rebar_prv_escriptize.erl
@@ -194,7 +194,8 @@ load_files(Wildcard, Dir) ->
load_files(Prefix, Wildcard, Dir) ->
[read_file(Prefix, Filename, Dir)
- || Filename <- filelib:wildcard(Wildcard, Dir)].
+ || Filename <- filelib:wildcard(Wildcard, Dir),
+ not filelib:is_dir(filename:join(Dir, Filename))].
read_file(Prefix, Filename, Dir) ->
Filename1 = case Prefix of
diff --git a/test/rebar_escriptize_SUITE.erl b/test/rebar_escriptize_SUITE.erl
index 139d5cd..a6901f9 100644
--- a/test/rebar_escriptize_SUITE.erl
+++ b/test/rebar_escriptize_SUITE.erl
@@ -7,7 +7,8 @@
all/0,
escriptize_with_name/1,
escriptize_with_bad_name/1,
- build_and_clean_app/1]).
+ build_and_clean_app/1,
+ escriptize_with_ebin_subdir/1]).
-include_lib("common_test/include/ct.hrl").
-include_lib("eunit/include/eunit.hrl").
@@ -29,7 +30,8 @@ all() ->
[
build_and_clean_app,
escriptize_with_name,
- escriptize_with_bad_name
+ escriptize_with_bad_name,
+ escriptize_with_ebin_subdir
].
%% Test escriptize builds and runs the app's escript
@@ -59,3 +61,24 @@ escriptize_with_bad_name(Config) ->
rebar_test_utils:create_app(AppDir, Name, Vsn, [kernel, stdlib]),
rebar_test_utils:run_and_check(Config, [{escript_main_app, boogers}], ["escriptize"],
{error,{rebar_prv_escriptize, {bad_name, boogers}}}).
+
+escriptize_with_ebin_subdir(Config) ->
+ AppDir = ?config(apps, Config),
+ Name = rebar_test_utils:create_random_name("app1_"),
+ Vsn = rebar_test_utils:create_random_vsn(),
+
+ rebar_test_utils:create_app(AppDir, Name, Vsn, [kernel, stdlib]),
+
+ filelib:ensure_dir(filename:join([AppDir, "ebin", "subdir", "subdirfile"])),
+
+ %% To work, this test must run from the AppDir itself. To avoid breaking
+ %% other tests, be careful with cwd
+ Cwd = file:get_cwd(),
+ try
+ file:set_cwd(AppDir),
+ {ok, _} = rebar3:run(rebar_state:new(?config(state,Config), [], AppDir),
+ ["escriptize"])
+ after
+ file:set_cwd(Cwd) % reset always
+ end,
+ ok.