From 3682b6de55ee88109147516be0a2634aeeb951ab Mon Sep 17 00:00:00 2001 From: Ian Wienand Date: Wed, 8 Oct 2014 15:37:23 +1100 Subject: [PATCH] Install latest EPEL release Use a little trick cribbed from [1] to install the latest EPEL release, rather than hard-coding versions [1] http://stackoverflow.com/questions/14016286/how-to-programmatically-install-the-latest-epel-release-rpm-without-knowing-its Closes-bug: #1376321 Change-Id: Ib89d73d669efe2e2d61fc0b12b46395fce113386 --- stack.sh | 32 ++++++++++++++++++++++++++------ 1 file changed, 26 insertions(+), 6 deletions(-) diff --git a/stack.sh b/stack.sh index 0cec623a54..3b5fb7459b 100755 --- a/stack.sh +++ b/stack.sh @@ -234,15 +234,35 @@ fi if [[ is_fedora && ( $DISTRO == "rhel6" || $DISTRO == "rhel7" ) ]]; then # RHEL requires EPEL for many Open Stack dependencies - if [[ $DISTRO == "rhel7" ]]; then - EPEL_RPM=${RHEL7_EPEL_RPM:-"http://dl.fedoraproject.org/pub/epel/beta/7/x86_64/epel-release-7-1.noarch.rpm"} - elif [[ $DISTRO == "rhel6" ]]; then - EPEL_RPM=${RHEL6_EPEL_RPM:-"http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm"} - fi if ! sudo yum repolist enabled epel | grep -q 'epel'; then echo "EPEL not detected; installing" - yum_install ${EPEL_RPM} || \ + # This trick installs the latest epel-release from a bootstrap + # repo, then removes itself (as epel-release installed the + # "real" repo). + # + # you would think that rather than this, you could use + # $releasever directly in .repo file we create below. However + # RHEL gives a $releasever of "6Server" which breaks the path; + # see https://bugzilla.redhat.com/show_bug.cgi?id=1150759 + if [[ $DISTRO == "rhel7" ]]; then + epel_ver="7" + elif [[ $DISTRO == "rhel6" ]]; then + epel_ver="6" + fi + + cat <