From 666e567c8a75123e4738b828dff4c35e1df86a99 Mon Sep 17 00:00:00 2001 From: Ciaran McCreesh Date: Sun, 6 May 2012 22:32:55 +0100 Subject: EAPI 5 has econf --disable-silent-rules --- paludis/repositories/e/e_repository_TEST_5.cc | 51 ++++++++++++++++++++++ .../repositories/e/e_repository_TEST_5_setup.sh | 36 +++++++++++++++ paludis/repositories/e/eapis/5.conf | 2 + 3 files changed, 89 insertions(+) diff --git a/paludis/repositories/e/e_repository_TEST_5.cc b/paludis/repositories/e/e_repository_TEST_5.cc index 07532b7cf..d001f4fa9 100644 --- a/paludis/repositories/e/e_repository_TEST_5.cc +++ b/paludis/repositories/e/e_repository_TEST_5.cc @@ -89,6 +89,57 @@ namespace } } +TEST(ERepository, InstallEAPI5) +{ + TestEnvironment env; + std::shared_ptr > keys(std::make_shared>()); + keys->insert("format", "e"); + keys->insert("names_cache", "/var/empty"); + keys->insert("location", stringify(FSPath::cwd() / "e_repository_TEST_5_dir" / "repo")); + keys->insert("profiles", stringify(FSPath::cwd() / "e_repository_TEST_5_dir" / "repo/profiles/profile")); + keys->insert("layout", "traditional"); + keys->insert("eapi_when_unknown", "0"); + keys->insert("eapi_when_unspecified", "0"); + keys->insert("profile_eapi", "0"); + keys->insert("distdir", stringify(FSPath::cwd() / "e_repository_TEST_5_dir" / "distdir")); + keys->insert("builddir", stringify(FSPath::cwd() / "e_repository_TEST_5_dir" / "build")); + std::shared_ptr repo(ERepository::repository_factory_create(&env, + std::bind(from_keys, keys, std::placeholders::_1))); + env.add_repository(1, repo); + + std::shared_ptr installed_repo(std::make_shared( + make_named_values( + n::environment() = &env, + n::name() = RepositoryName("installed"), + n::suitable_destination() = true, + n::supports_uninstall() = true + ))); + env.add_repository(2, installed_repo); + + InstallAction action(make_named_values( + n::destination() = installed_repo, + n::make_output_manager() = &make_standard_output_manager, + n::perform_uninstall() = &cannot_uninstall, + n::replacing() = std::make_shared(), + n::want_phase() = &want_all_phases + )); + + PretendAction pretend_action(make_named_values( + n::destination() = installed_repo, + n::make_output_manager() = &make_standard_output_manager, + n::replacing() = std::make_shared() + )); + + { + const std::shared_ptr id(*env[selection::RequireExactlyOne(generator::Matches( + PackageDepSpec(parse_user_package_dep_spec("=cat/econf-disable-silent-rules-5", + &env, { })), make_null_shared_ptr(), { }))]->last()); + ASSERT_TRUE(bool(id)); + EXPECT_EQ("5", visitor_cast >(**id->find_metadata("EAPI"))->parse_value()); + id->perform_action(action); + } +} + TEST(ERepository, RequiredUse) { FSPath root(FSPath::cwd() / "e_repository_TEST_5_dir" / "root"); diff --git a/paludis/repositories/e/e_repository_TEST_5_setup.sh b/paludis/repositories/e/e_repository_TEST_5_setup.sh index 021540e6d..791442898 100755 --- a/paludis/repositories/e/e_repository_TEST_5_setup.sh +++ b/paludis/repositories/e/e_repository_TEST_5_setup.sh @@ -75,5 +75,41 @@ REQUIRED_USE="?? ( disabled1 enabled2 enabled3 )" S="${WORKDIR}" END +mkdir -p "cat/econf-disable-silent-rules" || exit 1 +cat << 'END' > cat/econf-disable-silent-rules/econf-disable-silent-rules-5.ebuild || exit 1 +EAPI="${PV}" +DESCRIPTION="The Description" +HOMEPAGE="http://example.com/" +SRC_URI="" +SLOT="0" +IUSE="spork" +LICENSE="GPL-2" +KEYWORDS="test" + +S="${WORKDIR}" + +src_unpack() { + mkdir -p ${WORKDIR} + cd "${WORKDIR}" + + cat <<'EOF' > configure +#!/bin/sh + +if echo "$@" | grep -q 'help' ; then + echo disable-silent-rules + exit 0 +fi + +if ! echo "$@" | grep -q 'disable-silent-rules' ; then + exit 1 +fi + +exit 0 +EOF + + chmod +x configure +} +END + cd .. cd .. diff --git a/paludis/repositories/e/eapis/5.conf b/paludis/repositories/e/eapis/5.conf index 3947268b9..225a3ad58 100644 --- a/paludis/repositories/e/eapis/5.conf +++ b/paludis/repositories/e/eapis/5.conf @@ -10,3 +10,5 @@ ebuild_module_suffixes = 5 4 3 2 1 0 utility_path_suffixes = 5 4 3 2 1 0 dependency_spec_tree_parse_options = ${dependency_spec_tree_parse_options} allow_at_most_one + +econf_extra_options_help_dependent = ${econf_extra_options_help_dependent} disable-silent-rules::--disable-silent-rules -- cgit v1.2.3