diff options
| m--------- | libraries/hpc | 0 | ||||
| -rw-r--r-- | testsuite/config/ghc | 4 | ||||
| -rw-r--r-- | testsuite/driver/testlib.py | 92 | ||||
| -rw-r--r-- | testsuite/mk/test.mk | 16 | 
4 files changed, 56 insertions, 56 deletions
| diff --git a/libraries/hpc b/libraries/hpc -Subproject a071321d33188fb958f42e36778464617c56cfb +Subproject 08afa91988b68315a035df4702b84b69ba8e125 diff --git a/testsuite/config/ghc b/testsuite/config/ghc index 10565dd914..c208838268 100644 --- a/testsuite/config/ghc +++ b/testsuite/config/ghc @@ -165,12 +165,12 @@ llvm_ways     = [x[0] for x in config.way_flags('dummy_name').items()  def get_compiler_info():  # This should really not go through the shell -    h = os.popen('"' + config.compiler + '" --info', 'r') +    h = os.popen(config.compiler + ' --info', 'r')      s = h.read()      s = re.sub('[\r\n]', '', s)      h.close()      compilerInfoDict = dict(eval(s)) -    h = os.popen('"' + config.compiler + '" +RTS --info', 'r') +    h = os.popen(config.compiler + ' +RTS --info', 'r')      s = h.read()      s = re.sub('[\r\n]', '', s)      h.close() diff --git a/testsuite/driver/testlib.py b/testsuite/driver/testlib.py index 38107af026..a3c473a486 100644 --- a/testsuite/driver/testlib.py +++ b/testsuite/driver/testlib.py @@ -106,7 +106,8 @@ def _reqlib( name, opts, lib ):          if have_subprocess:              # By preference we use subprocess, as the alternative uses              # /dev/null which mingw doesn't have. -            p = subprocess.Popen([config.ghc_pkg, '--no-user-package-db', 'describe', lib], +            cmd = strip_quotes(config.ghc_pkg) +            p = subprocess.Popen([cmd, '--no-user-package-db', 'describe', lib],                                   stdout=subprocess.PIPE,                                   stderr=subprocess.PIPE)              # read from stdout and stderr to avoid blocking due to @@ -950,26 +951,16 @@ def ghci_script_override_default_flags(overrides):      return apply  def ghci_script( name, way, script, override_flags = None ): -    # Use overriden default flags when given -    if override_flags is not None: -        default_flags = override_flags -    else: -        default_flags = getTestOpts().compiler_always_flags -      # filter out -fforce-recomp from compiler_always_flags, because we're      # actually testing the recompilation behaviour in the GHCi tests. -    flags = [f for f in default_flags if f != '-fforce-recomp'] -    flags.append(getTestOpts().extra_hc_opts) -    if getTestOpts().outputdir != None: -        flags.extend(["-outputdir", getTestOpts().outputdir]) +    flags = ' '.join(get_compiler_flags(override_flags, noforce=True)) + +    way_flags = '--interactive -v0 -ignore-dot-ghci'      # We pass HC and HC_OPTS as environment variables, so that the      # script can invoke the correct compiler by using ':! $HC $HC_OPTS' -    cmd = "HC='" + config.compiler + "' " + \ -          "HC_OPTS='" + ' '.join(flags) + "' " + \ -          "'" + config.compiler + "'" + \ -          ' --interactive -v0 -ignore-dot-ghci ' + \ -          ' '.join(flags) +    cmd = ('HC={{compiler}} HC_OPTS="{flags}" {{compiler}} {flags} {way_flags}' +          ).format(flags=flags, way_flags=way_flags)      getTestOpts().stdin = script      return simple_run( name, way, cmd, getTestOpts().extra_run_opts ) @@ -1243,24 +1234,13 @@ def simple_build( name, way, extra_hc_opts, should_fail, top_mod, link, addsuf,      else:          cmd_prefix = getTestOpts().compile_cmd_prefix + ' ' -    if override_flags is not None: -        comp_flags = copy.copy(override_flags) -    else: -        comp_flags = copy.copy(getTestOpts().compiler_always_flags) +    flags = ' '.join(get_compiler_flags(override_flags, noforce) + +                     config.way_flags(name)[way]) -    if noforce: -        comp_flags = [f for f in comp_flags if f != '-fforce-recomp'] -    if getTestOpts().outputdir != None: -        comp_flags.extend(["-outputdir", getTestOpts().outputdir]) - -    cmd = 'cd ' + getTestOpts().testdir + " && " + cmd_prefix + "'" \ -          + config.compiler + "' " \ -          + ' '.join(comp_flags) + ' ' \ -          + to_do + ' ' + srcname + ' ' \ -          + ' '.join(config.way_flags(name)[way]) + ' ' \ -          + extra_hc_opts + ' ' \ -          + opts.extra_hc_opts + ' ' \ -          + '>' + errname + ' 2>&1' +    cmd = ('cd {opts.testdir} && {cmd_prefix} ' +           '{{compiler}} {to_do} {srcname} {flags} {extra_hc_opts} ' +           '> {errname} 2>&1' +          ).format(**locals())      result = runCmdFor(name, cmd) @@ -1434,9 +1414,8 @@ def interpreter_run( name, way, extra_hc_opts, compile_only, top_mod ):      script.close() -    flags = copy.copy(getTestOpts().compiler_always_flags) -    if getTestOpts().outputdir != None: -        flags.extend(["-outputdir", getTestOpts().outputdir]) +    flags = ' '.join(get_compiler_flags(override_flags=None, noforce=False) + +                     config.way_flags(name)[way])      if getTestOpts().combined_output:          redirection        = ' > {} 2>&1'.format(outname) @@ -1445,13 +1424,9 @@ def interpreter_run( name, way, extra_hc_opts, compile_only, top_mod ):          redirection        = ' > {} 2> {}'.format(outname, errname)          redirection_append = ' >> {} 2>> {}'.format(outname, errname) -    cmd = "'" + config.compiler + "' " \ -          + ' '.join(flags) + ' ' \ -          + srcname + ' ' \ -          + ' '.join(config.way_flags(name)[way]) + ' ' \ -          + extra_hc_opts + ' ' \ -          + getTestOpts().extra_hc_opts + ' ' \ -          + '<' + scriptname + redirection +    cmd = ('{{compiler}} {srcname} {flags} {extra_hc_opts} ' +           '< {scriptname} {redirection}' +          ).format(**locals())      if getTestOpts().cmd_wrapper != None:          cmd = getTestOpts().cmd_wrapper(cmd) + redirection_append; @@ -1508,6 +1483,23 @@ def split_file(in_fn, delimiter, out1_fn, out2_fn):  # -----------------------------------------------------------------------------  # Utils +def get_compiler_flags(override_flags, noforce): +    opts = getTestOpts() + +    if override_flags is not None: +        flags = copy.copy(override_flags) +    else: +        flags = copy.copy(opts.compiler_always_flags) + +    if noforce: +        flags = [f for f in flags if f != '-fforce-recomp'] + +    flags.append(opts.extra_hc_opts) + +    if opts.outputdir != None: +        flags.extend(["-outputdir", opts.outputdir]) + +    return flags  def check_stdout_ok( name ):     if getTestOpts().with_namebase == None: @@ -1581,7 +1573,7 @@ def write_file(file, str):  def check_hp_ok(name):      # do not qualify for hp2ps because we should be in the right directory -    hp2psCmd = "cd " + getTestOpts().testdir + " && '" + config.hp2ps + "' " + name +    hp2psCmd = "cd " + getTestOpts().testdir + " && {hp2ps} " + name      hp2psResult = runCmdExitCode(hp2psCmd) @@ -1793,11 +1785,11 @@ def rawSystem(cmd_and_args):      # However, subprocess is new in python 2.4, so fall back to      # using spawnv if we don't have it - +    cmd = cmd_and_args[0]      if have_subprocess: -        return subprocess.call(cmd_and_args) +        return subprocess.call([strip_quotes(cmd)] + cmd_and_args[1:])      else: -        return os.spawnv(os.P_WAIT, cmd_and_args[0], cmd_and_args) +        return os.spawnv(os.P_WAIT, cmd, cmd_and_args)  # When running under native msys Python, any invocations of non-msys binaries,  # including timeout.exe, will have their arguments munged according to some @@ -2279,7 +2271,7 @@ def printFailingTestInfosSummary(file, testInfos):  def getStdout(cmd):      if have_subprocess: -        p = subprocess.Popen(cmd, +        p = subprocess.Popen(strip_quotes(cmd),                               stdout=subprocess.PIPE,                               stderr=subprocess.PIPE)          (stdout, stderr) = p.communicate() @@ -2291,3 +2283,7 @@ def getStdout(cmd):          return stdout      else:          raise Exception("Need subprocess to get stdout, but don't have it") + +def strip_quotes(s): +    # Don't wrap commands to subprocess.call/Popen in quotes. +    return s.strip('\'"') diff --git a/testsuite/mk/test.mk b/testsuite/mk/test.mk index 42022cd958..d1d66c781a 100644 --- a/testsuite/mk/test.mk +++ b/testsuite/mk/test.mk @@ -196,21 +196,25 @@ RUNTEST_OPTS +=  \  	--rootdir=. \  	--config=$(CONFIG) \  	-e 'config.confdir="$(CONFIGDIR)"' \ -	-e 'config.compiler="$(TEST_HC)"' \ -	-e 'config.ghc_pkg="$(GHC_PKG)"' \ -	-e 'config.hp2ps="$(HP2PS_ABS)"' \ -	-e 'config.hpc="$(HPC)"' \ -	-e 'config.gs="$(GS)"' \  	-e 'config.platform="$(TARGETPLATFORM)"' \  	-e 'config.os="$(TargetOS_CPP)"' \  	-e 'config.arch="$(TargetARCH_CPP)"' \  	-e 'config.wordsize="$(WORDSIZE)"' \  	-e 'default_testopts.cleanup="$(CLEANUP)"' \  	-e 'config.timeout=int($(TIMEOUT)) or config.timeout' \ -	-e 'config.timeout_prog="$(TIMEOUT_PROGRAM)"' \  	-e 'config.exeext="$(exeext)"' \  	-e 'config.top="$(TOP_ABS)"' +# Put an extra pair of quotes around program paths, +# so we don't have to in .T scripts or driver/testlib.py. +RUNTEST_OPTS +=  \ +	-e 'config.compiler="\"$(TEST_HC)\""' \ +	-e 'config.ghc_pkg="\"$(GHC_PKG)\""' \ +	-e 'config.hp2ps="\"$(HP2PS_ABS)\""' \ +	-e 'config.hpc="\"$(HPC)\""' \ +	-e 'config.gs="\"$(GS)\""' \ +	-e 'config.timeout_prog="\"$(TIMEOUT_PROGRAM)\""' +  ifneq "$(OUTPUT_SUMMARY)" ""  RUNTEST_OPTS +=  \  	--output-summary "$(OUTPUT_SUMMARY)" | 
