[PATCH 7 of 9 debian-packaging] hghave: add a check for docker support

Augie Fackler raf at durin42.com
Wed Aug 26 14:08:48 CDT 2015


# HG changeset patch
# User Augie Fackler <augie at google.com>
# Date 1440475601 14400
#      Tue Aug 25 00:06:41 2015 -0400
# Node ID 65d972362afc1edba83ce4e785f7d54ba83a36f3
# Parent  e3d781ff1bcbcb2f4ad452bc0563d62673545f4c
hghave: add a check for docker support

This currently refuses to operate if on a non-Linux host. I suspect
that Docker running on FreeBSD 11 or on an Illumos derivative would
work fine, but I don't have ready access to such a system.

On OS X using boot2docker (I used a hacky xhyve-based one for
testing), it won't work because $TESTTEMP doesn't end up inside the
set of directories that get forwarded to the boot2docker VM, so you
can't actually drop debs in the $TESTTEMP at all. It would be possible
(probably even trivial) to hack around this by using a randomly-named
temporary directory inside the working directory, but that seems
unlikely to be useful enough to justify the ugliness.

diff --git a/tests/hghave.py b/tests/hghave.py
--- a/tests/hghave.py
+++ b/tests/hghave.py
@@ -414,6 +414,23 @@ def has_aix():
 def has_osx():
     return sys.platform == 'darwin'
 
+ at check("docker", "docker support")
+def has_docker():
+    pat = r'A self-sufficient runtime for linux containers\.'
+    if matchoutput('docker --help', pat):
+        if 'linux' not in sys.platform:
+            # TODO: in theory we should be able to test docker-based
+            # package creation on non-linux using boot2docker, but in
+            # practice that requires extra coordination to make sure
+            # $TESTTEMP is going to be visible at the same path to the
+            # boot2docker VM. If we figure out how to verify that, we
+            # can use the following instead of just saying False:
+            # return 'DOCKER_HOST' in os.environ
+            return False
+
+        return True
+    return False
+
 @check("dpkg", "debian packaging")
 def has_dpkg():
     return matchoutput('dpkg --version',


More information about the Mercurial-devel mailing list