From 98ba2191992c67244e50da4e95d38fd426b817ee Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Amadeusz=20=C5=BBo=C5=82nowski?= Date: Thu, 26 May 2016 20:59:11 +0100 Subject: [PATCH] rebar.eclass: Optionally provide alternate rebar config to alter Some packages have separate configs for build and tests. Build config is always named 'rebar.config' and there seem to be no standard name for tests config. --- eclass/rebar.eclass | 14 +++++++++++--- eclass/tests/rebar_fix_include_path.sh | 23 +++++++++++++++++++++++ eclass/tests/rebar_remove_deps.sh | 23 +++++++++++++++++++++++ 3 files changed, 57 insertions(+), 3 deletions(-) diff --git a/eclass/rebar.eclass b/eclass/rebar.eclass index 9f3d9e22109ec..c8a2cf47c29a1 100644 --- a/eclass/rebar.eclass +++ b/eclass/rebar.eclass @@ -93,17 +93,20 @@ erebar() { } # @FUNCTION: rebar_fix_include_path -# @USAGE: +# @USAGE: [] # @DESCRIPTION: # Fix path in rebar.config to 'include' directory of dependant project/package, # so it points to installation in system Erlang lib rather than relative 'deps' # directory. # +# is optional. Default is 'rebar.config'. +# # The function dies on failure. rebar_fix_include_path() { debug-print-function ${FUNCNAME} "${@}" local pn="$1" + local rebar_config="${2:-rebar.config}" local erl_libs="${EPREFIX}$(get_erl_libs)" local p @@ -121,19 +124,24 @@ rebar_fix_include_path() { next; } 1 -' rebar.config || die "failed to fix include paths in rebar.config for '${pn}'" +' "${rebar_config}" || die "failed to fix include paths in ${rebar_config} for '${pn}'" } # @FUNCTION: rebar_remove_deps +# @USAGE: [] # @DESCRIPTION: # Remove dependencies list from rebar.config and deceive build rules that any # dependencies are already fetched and built. Otherwise rebar tries to fetch # dependencies and compile them. # +# is optional. Default is 'rebar.config'. +# # The function dies on failure. rebar_remove_deps() { debug-print-function ${FUNCNAME} "${@}" + local rebar_config="${1:-rebar.config}" + mkdir -p "${S}/deps" && :>"${S}/deps/.got" && :>"${S}/deps/.built" || die gawk -i inplace ' /^{[[:space:]]*deps[[:space:]]*,/, /}[[:space:]]*\.$/ { @@ -143,7 +151,7 @@ rebar_remove_deps() { next; } 1 -' rebar.config || die "failed to remove deps from rebar.config" +' "${rebar_config}" || die "failed to remove deps from ${rebar_config}" } # @FUNCTION: rebar_set_vsn diff --git a/eclass/tests/rebar_fix_include_path.sh b/eclass/tests/rebar_fix_include_path.sh index 9047f8dcd225e..c8ab178a70544 100755 --- a/eclass/tests/rebar_fix_include_path.sh +++ b/eclass/tests/rebar_fix_include_path.sh @@ -77,6 +77,25 @@ test_typical_config() { [[ ${unit_rc}${diff_rc} = 00 ]] } +test_typical_config_with_different_name() { + local diff_rc + local unit_rc + + # Prepare + cd "${S}" || die + cp typical.config other.config || die + + # Run unit + (rebar_fix_include_path foo other.config) + unit_rc=$? + + # Test result + diff other.config typical.config.expected + diff_rc=$? + + [[ ${unit_rc}${diff_rc} = 00 ]] +} + test_multiple_versions() { local diff_rc local unit_rc @@ -144,6 +163,10 @@ tbegin "rebar_fix_include_path deals with typical config" test_typical_config tend $? +tbegin "rebar_fix_include_path deals with typical config with different name" +test_typical_config_with_different_name +tend $? + tbegin "rebar_fix_include_path fails on multiple versions of dependency" test_multiple_versions tend $? diff --git a/eclass/tests/rebar_remove_deps.sh b/eclass/tests/rebar_remove_deps.sh index 05207a783cb4f..32351bff03cbd 100755 --- a/eclass/tests/rebar_remove_deps.sh +++ b/eclass/tests/rebar_remove_deps.sh @@ -67,6 +67,25 @@ test_typical_config() { [[ ${unit_rc}${diff_rc} = 00 ]] } +test_typical_config_with_different_name() { + local diff_rc + local unit_rc + + # Prepare + cd "${S}" || die + cp typical.config other.config || die + + # Run unit + (rebar_remove_deps other.config) + unit_rc=$? + + # Test result + diff other.config rebar.config.expected + diff_rc=$? + + [[ ${unit_rc}${diff_rc} = 00 ]] +} + test_deps_in_one_line() { local diff_rc local unit_rc @@ -92,6 +111,10 @@ tbegin "rebar_remove_deps deals with typical config" test_typical_config tend $? +tbegin "rebar_remove_deps deals with typical config with different name" +test_typical_config_with_different_name +tend $? + tbegin "rebar_remove_deps deals with all deps in one line" test_deps_in_one_line tend $?