summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorTodd Gamblin <tgamblin@llnl.gov>2016-06-20 09:28:24 -0700
committerTodd Gamblin <tgamblin@llnl.gov>2016-06-20 09:28:39 -0700
commit84e21703bde307c920e83e6cd4452feaacbaf5f2 (patch)
treece717243c43d2eb6114b7ce28be9bf5d8c1c65e3 /lib
parent64c83638fff9716477ecbc3d87989b6b8437b05f (diff)
downloadspack-84e21703bde307c920e83e6cd4452feaacbaf5f2.tar.gz
spack-84e21703bde307c920e83e6cd4452feaacbaf5f2.tar.bz2
spack-84e21703bde307c920e83e6cd4452feaacbaf5f2.tar.xz
spack-84e21703bde307c920e83e6cd4452feaacbaf5f2.zip
Test no longer assumes compilers exist in /usr.
- makes a fake gcc instead, and tests that.
Diffstat (limited to 'lib')
-rw-r--r--lib/spack/spack/test/cmd/test_compiler_cmd.py67
1 files changed, 57 insertions, 10 deletions
diff --git a/lib/spack/spack/test/cmd/test_compiler_cmd.py b/lib/spack/spack/test/cmd/test_compiler_cmd.py
index 81bc7aacf2..d89814154b 100644
--- a/lib/spack/spack/test/cmd/test_compiler_cmd.py
+++ b/lib/spack/spack/test/cmd/test_compiler_cmd.py
@@ -1,8 +1,16 @@
+import os
+import shutil
+from tempfile import mkdtemp
+
+from llnl.util.filesystem import set_executable, mkdirp
+
import spack.spec
import spack.cmd.compiler
import spack.compilers
+from spack.version import Version
from spack.test.mock_packages_test import *
+test_version = '4.5-spacktest'
class MockArgs(object):
def __init__(self, add_paths=[], scope=None, compiler_spec=None, all=None):
@@ -12,23 +20,62 @@ class MockArgs(object):
self.all = all
+def make_mock_compiler():
+ """Make a directory containing a fake, but detectable compiler."""
+ mock_compiler_dir = mkdtemp()
+ bin_dir = os.path.join(mock_compiler_dir, 'bin')
+ mkdirp(bin_dir)
+
+ gcc_path = os.path.join(bin_dir, 'gcc')
+ gxx_path = os.path.join(bin_dir, 'g++')
+ gfortran_path = os.path.join(bin_dir, 'gfortran')
+
+ with open(gcc_path, 'w') as f:
+ f.write("""\
+#!/bin/sh
+
+for arg in "$@"; do
+ if [ "$arg" = -dumpversion ]; then
+ echo '%s'
+ fi
+done
+""" % test_version)
+
+ # Create some mock compilers in the temporary directory
+ set_executable(gcc_path)
+ shutil.copy(gcc_path, gxx_path)
+ shutil.copy(gcc_path, gfortran_path)
+
+ return mock_compiler_dir
+
+
class CompilerCmdTest(MockPackagesTest):
""" Test compiler commands for add and remove """
+
def test_compiler_remove(self):
args = MockArgs(all=True, compiler_spec='gcc@4.5.0')
spack.cmd.compiler.compiler_remove(args)
compilers = spack.compilers.all_compilers()
self.assertTrue(spack.spec.CompilerSpec("gcc@4.5.0") not in compilers)
+
def test_compiler_add(self):
- # Probably not a good a assumption but might try finding local
- # compilers
- # installed in /usr
- compilers = spack.compilers.all_compilers()
- s = set(compilers)
- args = MockArgs(add_paths=["/usr"])
- spack.cmd.compiler.compiler_find(args)
- new_compilers = spack.compilers.all_compilers()
- new_compiler = [x for x in new_compilers if x not in s]
- self.assertTrue(new_compiler)
+ # compilers available by default.
+ old_compilers = set(spack.compilers.all_compilers())
+
+ # add our new compiler and find again.
+ compiler_dir = make_mock_compiler()
+
+ try:
+ args = MockArgs(add_paths=[compiler_dir])
+ spack.cmd.compiler.compiler_find(args)
+
+ # ensure new compiler is in there
+ new_compilers = set(spack.compilers.all_compilers())
+ new_compiler = new_compilers - old_compilers
+ self.assertTrue(new_compiler)
+ self.assertTrue(new_compiler.pop().version == Version(test_version))
+
+ finally:
+ shutil.rmtree(compiler_dir, ignore_errors=True)