Rework Spack's Mercurial support (#3834)
* Add tests to mercurial package * Add support for --insecure with mercurial fetching * Install man pages and tab-completion scripts * Add tests and latest version for all deps * Flake8 fix * Use certifi module to find CA certificate * Flake8 fix * Unset PYTHONPATH when running hg * svn_fetch should use to svn-test, not hg-test * Drop Python 3 support in Mercurial Python 3 support is a work in progress and isn't currently recommended: https://www.mercurial-scm.org/wiki/SupportedPythonVersions * Test both secure and insecure hg fetching * Test both secure and insecure git and svn fetching
This commit is contained in:

committed by
Todd Gamblin

parent
53763f7698
commit
f4858cb7a7
@@ -23,16 +23,23 @@
|
||||
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||
##############################################################################
|
||||
from spack import *
|
||||
import llnl.util.tty as tty
|
||||
import os
|
||||
from llnl.util import tty
|
||||
|
||||
|
||||
class Mercurial(Package):
|
||||
class Mercurial(PythonPackage):
|
||||
"""Mercurial is a free, distributed source control management tool."""
|
||||
|
||||
homepage = "https://www.mercurial-scm.org"
|
||||
url = "https://www.mercurial-scm.org/release/mercurial-3.9.tar.gz"
|
||||
url = "https://www.mercurial-scm.org/release/mercurial-4.1.2.tar.gz"
|
||||
|
||||
import_modules = [
|
||||
'hgext', 'hgext3rd', 'mercurial', 'hgext.convert', 'hgext.fsmonitor',
|
||||
'hgext.highlight', 'hgext.largefiles', 'hgext.zeroconf',
|
||||
'hgext.fsmonitor.pywatchman', 'mercurial.hgweb',
|
||||
'mercurial.httpclient', 'mercurial.pure'
|
||||
]
|
||||
|
||||
version('4.1.2', '934c99808bdc8385e074b902d59b0d93')
|
||||
version('3.9.1', '3759dd10edb8c1a6dfb8ff0ce82658ce')
|
||||
version('3.9', 'e2b355da744e94747daae3a5339d28a0')
|
||||
version('3.8.4', 'cec2c3db688cb87142809089c6ae13e9')
|
||||
@@ -40,30 +47,62 @@ class Mercurial(Package):
|
||||
version('3.8.2', 'c38daa0cbe264fc621dc3bb05933b0b3')
|
||||
version('3.8.1', '172a8c588adca12308c2aca16608d7f4')
|
||||
|
||||
extends('python')
|
||||
depends_on('python@2.6:2.8')
|
||||
depends_on('py-docutils', type='build')
|
||||
depends_on('py-pygments', type=('build', 'run'))
|
||||
depends_on('py-certifi', type=('build', 'run'))
|
||||
|
||||
def install(self, spec, prefix):
|
||||
make('install', 'PREFIX={0}'.format(prefix))
|
||||
@run_after('install')
|
||||
def post_install(self):
|
||||
prefix = self.prefix
|
||||
|
||||
# Configuration of HTTPS certificate authorities
|
||||
# https://www.mercurial-scm.org/wiki/CACertificates
|
||||
hgrc_filename = join_path(prefix.etc, 'mercurial', 'hgrc')
|
||||
mkdirp(os.path.dirname(hgrc_filename))
|
||||
# Install man pages
|
||||
mkdirp(prefix.man1)
|
||||
mkdirp(prefix.man5)
|
||||
mkdirp(prefix.man8)
|
||||
with working_dir('doc'):
|
||||
install('hg.1', prefix.man1)
|
||||
install('hgignore.5', prefix.man5)
|
||||
install('hgrc.5', prefix.man5)
|
||||
install('hg-ssh.8', prefix.man8)
|
||||
|
||||
# Install completion scripts
|
||||
contrib = join_path(prefix, 'contrib')
|
||||
mkdir(contrib)
|
||||
with working_dir('contrib'):
|
||||
install('bash_completion', join_path(contrib, 'bash_completion'))
|
||||
install('zsh_completion', join_path(contrib, 'zsh_completion'))
|
||||
|
||||
@run_after('install')
|
||||
def configure_certificates(self):
|
||||
"""Configuration of HTTPS certificate authorities
|
||||
https://www.mercurial-scm.org/wiki/CACertificates"""
|
||||
|
||||
etc_dir = join_path(self.prefix.etc, 'mercurial')
|
||||
mkdirp(etc_dir)
|
||||
|
||||
hgrc_filename = join_path(etc_dir, 'hgrc')
|
||||
|
||||
# Use certifi to find the location of the CA certificate
|
||||
certificate = python('-c', 'import certifi; print certifi.where()',
|
||||
output=str)
|
||||
|
||||
if not certificate:
|
||||
tty.warn('CA certificate not found. You may not be able to '
|
||||
'connect to an HTTPS server. If your CA certificate '
|
||||
'is in a non-standard location, you should add it to '
|
||||
'{0}.'.format(hgrc_filename))
|
||||
|
||||
# Write the global mercurial configuration file
|
||||
with open(hgrc_filename, 'w') as hgrc:
|
||||
if os.path.exists('/etc/ssl/certs/ca-certificates.crt'):
|
||||
# Debian/Ubuntu/Gentoo/Arch Linux
|
||||
hgrc.write('[web]\ncacerts = /etc/ssl/certs/ca-certificates.crt') # noqa
|
||||
elif os.path.exists('/etc/pki/tls/certs/ca-bundle.crt'):
|
||||
# Fedora/RHEL/CentOS
|
||||
hgrc.write('[web]\ncacerts = /etc/pki/tls/certs/ca-bundle.crt')
|
||||
elif os.path.exists('/etc/ssl/ca-bundle.pem'):
|
||||
# openSUSE/SLE
|
||||
hgrc.write('[web]\ncacerts = /etc/ssl/ca-bundle.pem')
|
||||
else:
|
||||
tty.warn('CA certificate not found. You may not be able to '
|
||||
'connect to an HTTPS server. If your CA certificate '
|
||||
'is in a non-standard location, you should add it to '
|
||||
'{0}'.format(hgrc_filename))
|
||||
hgrc.write('[web]\ncacerts = {0}'.format(certificate))
|
||||
|
||||
@run_after('install')
|
||||
@on_package_attributes(run_tests=True)
|
||||
def check_install(self):
|
||||
"""Sanity-check setup."""
|
||||
|
||||
hg = Executable(join_path(self.prefix.bin, 'hg'))
|
||||
|
||||
hg('debuginstall')
|
||||
hg('version')
|
||||
|
Reference in New Issue
Block a user