tests: add tests for warnings in build output
- add tests for build warnings and error messages - simplify some code in build environment with plural() function
This commit is contained in:
		| @@ -71,6 +71,7 @@ | |||||||
| import spack.main | import spack.main | ||||||
| import spack.paths | import spack.paths | ||||||
| import spack.store | import spack.store | ||||||
|  | from spack.util.string import plural | ||||||
| from spack.environment import EnvironmentModifications, validate | from spack.environment import EnvironmentModifications, validate | ||||||
| from spack.environment import preserve_environment | from spack.environment import preserve_environment | ||||||
| from spack.util.environment import env_flag, filter_system_paths, get_path | from spack.util.environment import env_flag, filter_system_paths, get_path | ||||||
| @@ -914,17 +915,13 @@ def long_message(self): | |||||||
|                 nwar = len(warnings) |                 nwar = len(warnings) | ||||||
|                 if nerr > 0: |                 if nerr > 0: | ||||||
|                     # If errors are found, only display errors |                     # If errors are found, only display errors | ||||||
|                     if nerr == 1: |                     out.write( | ||||||
|                         out.write("\n1 error found in build log:\n") |                         "\n%s found in build log:\n" % plural(nerr, 'error')) | ||||||
|                     else: |  | ||||||
|                         out.write("\n%d errors found in build log:\n" % nerr) |  | ||||||
|                     out.write(make_log_context(errors)) |                     out.write(make_log_context(errors)) | ||||||
|                 elif nwar > 0: |                 elif nwar > 0: | ||||||
|                     # If no errors are found but warnings are, display warnings |                     # If no errors are found but warnings are, display warnings | ||||||
|                     if nwar == 1: |                     out.write( | ||||||
|                         out.write("\n1 warning found in build log:\n") |                         "\n%s found in build log:\n" % plural(nwar, 'warning')) | ||||||
|                     else: |  | ||||||
|                         out.write("\n%d warnings found in build log:\n" % nwar) |  | ||||||
|                     out.write(make_log_context(warnings)) |                     out.write(make_log_context(warnings)) | ||||||
|  |  | ||||||
|         else: |         else: | ||||||
|   | |||||||
| @@ -429,3 +429,30 @@ def test_cdash_upload_build_error(tmpdir, mock_fetch, install_mockery, | |||||||
|             assert report_file in report_dir.listdir() |             assert report_file in report_dir.listdir() | ||||||
|             content = report_file.open().read() |             content = report_file.open().read() | ||||||
|             assert '<Text>configure: error: in /path/to/some/file:</Text>' in content |             assert '<Text>configure: error: in /path/to/some/file:</Text>' in content | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @pytest.mark.disable_clean_stage_check | ||||||
|  | def test_build_error_output(tmpdir, mock_fetch, install_mockery, capfd): | ||||||
|  |     with capfd.disabled(): | ||||||
|  |         msg = '' | ||||||
|  |         try: | ||||||
|  |             install('build-error') | ||||||
|  |             assert False, "no exception was raised!" | ||||||
|  |         except spack.build_environment.ChildError as e: | ||||||
|  |             msg = e.long_message | ||||||
|  |  | ||||||
|  |         assert 'configure: error: in /path/to/some/file:' in msg | ||||||
|  |         assert 'configure: error: cannot run C compiled programs.' in msg | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @pytest.mark.disable_clean_stage_check | ||||||
|  | def test_build_warning_output(tmpdir, mock_fetch, install_mockery, capfd): | ||||||
|  |     with capfd.disabled(): | ||||||
|  |         msg = '' | ||||||
|  |         try: | ||||||
|  |             install('build-warnings') | ||||||
|  |         except spack.build_environment.ChildError as e: | ||||||
|  |             msg = e.long_message | ||||||
|  |  | ||||||
|  |         assert 'WARNING: ALL CAPITAL WARNING!' in msg | ||||||
|  |         assert 'foo.c:89: warning: some weird warning!' in msg | ||||||
|   | |||||||
							
								
								
									
										33
									
								
								lib/spack/spack/test/util/util_string.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								lib/spack/spack/test/util/util_string.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | |||||||
|  | ############################################################################## | ||||||
|  | # Copyright (c) 2013-2018, Lawrence Livermore National Security, LLC. | ||||||
|  | # Produced at the Lawrence Livermore National Laboratory. | ||||||
|  | # | ||||||
|  | # This file is part of Spack. | ||||||
|  | # Created by Todd Gamblin, tgamblin@llnl.gov, All rights reserved. | ||||||
|  | # LLNL-CODE-647188 | ||||||
|  | # | ||||||
|  | # For details, see https://github.com/spack/spack | ||||||
|  | # Please also see the NOTICE and LICENSE files for our notice and the LGPL. | ||||||
|  | # | ||||||
|  | # This program is free software; you can redistribute it and/or modify | ||||||
|  | # it under the terms of the GNU Lesser General Public License (as | ||||||
|  | # published by the Free Software Foundation) version 2.1, February 1999. | ||||||
|  | # | ||||||
|  | # This program is distributed in the hope that it will be useful, but | ||||||
|  | # WITHOUT ANY WARRANTY; without even the IMPLIED WARRANTY OF | ||||||
|  | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the terms and | ||||||
|  | # conditions of the GNU Lesser General Public License for more details. | ||||||
|  | # | ||||||
|  | # You should have received a copy of the GNU Lesser General Public | ||||||
|  | # License along with this program; if not, write to the Free Software | ||||||
|  | # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||||||
|  | ############################################################################## | ||||||
|  | from spack.util.string import plural | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def test_plural(): | ||||||
|  |     assert plural(0, 'thing') == '0 things' | ||||||
|  |     assert plural(1, 'thing') == '1 thing' | ||||||
|  |     assert plural(2, 'thing') == '2 things' | ||||||
|  |     assert plural(1, 'thing', 'wombats') == '1 thing' | ||||||
|  |     assert plural(2, 'thing', 'wombats') == '2 wombats' | ||||||
| @@ -53,3 +53,23 @@ def comma_and(sequence): | |||||||
|  |  | ||||||
| def quote(sequence, q="'"): | def quote(sequence, q="'"): | ||||||
|     return ['%s%s%s' % (q, e, q) for e in sequence] |     return ['%s%s%s' % (q, e, q) for e in sequence] | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def plural(n, singular, plural=None): | ||||||
|  |     """Pluralize <singular> word by adding an s if n != 1. | ||||||
|  |  | ||||||
|  |     Arguments: | ||||||
|  |         n (int): number of things there are | ||||||
|  |         singular (str): singular form of word | ||||||
|  |         plural (str, optional): optional plural form, for when it's not just | ||||||
|  |             singular + 's' | ||||||
|  |  | ||||||
|  |     Returns: | ||||||
|  |         (str): "1 thing" if n == 1 or "n things" if n != 1 | ||||||
|  |     """ | ||||||
|  |     if n == 1: | ||||||
|  |         return "%d %s" % (n, singular) | ||||||
|  |     elif plural is not None: | ||||||
|  |         return "%d %s" % (n, plural) | ||||||
|  |     else: | ||||||
|  |         return "%d %ss" % (n, singular) | ||||||
|   | |||||||
| @@ -0,0 +1,47 @@ | |||||||
|  | ############################################################################## | ||||||
|  | # Copyright (c) 2013-2018, Lawrence Livermore National Security, LLC. | ||||||
|  | # Produced at the Lawrence Livermore National Laboratory. | ||||||
|  | # | ||||||
|  | # This file is part of Spack. | ||||||
|  | # Created by Todd Gamblin, tgamblin@llnl.gov, All rights reserved. | ||||||
|  | # LLNL-CODE-647188 | ||||||
|  | # | ||||||
|  | # For details, see https://github.com/spack/spack | ||||||
|  | # Please also see the NOTICE and LICENSE files for our notice and the LGPL. | ||||||
|  | # | ||||||
|  | # This program is free software; you can redistribute it and/or modify | ||||||
|  | # it under the terms of the GNU Lesser General Public License (as | ||||||
|  | # published by the Free Software Foundation) version 2.1, February 1999. | ||||||
|  | # | ||||||
|  | # This program is distributed in the hope that it will be useful, but | ||||||
|  | # WITHOUT ANY WARRANTY; without even the IMPLIED WARRANTY OF | ||||||
|  | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the terms and | ||||||
|  | # conditions of the GNU Lesser General Public License for more details. | ||||||
|  | # | ||||||
|  | # You should have received a copy of the GNU Lesser General Public | ||||||
|  | # License along with this program; if not, write to the Free Software | ||||||
|  | # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||||||
|  | ############################################################################## | ||||||
|  | from spack import * | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class BuildWarnings(Package): | ||||||
|  |     """This package's install fails but only emits warnings.""" | ||||||
|  |  | ||||||
|  |     homepage = "http://www.example.com/trivial_install" | ||||||
|  |     url      = "http://www.unit-test-should-replace-this-url/trivial_install-1.0.tar.gz" | ||||||
|  |  | ||||||
|  |     version('1.0', 'foobarbaz') | ||||||
|  |  | ||||||
|  |     def install(self, spec, prefix): | ||||||
|  |         with open('configure', 'w') as f: | ||||||
|  |             f.write("""#!/bin/sh\n | ||||||
|  | echo 'checking for gcc... /Users/gamblin2/src/spack/lib/spack/env/clang/clang' | ||||||
|  | echo 'checking whether the C compiler works... yes' | ||||||
|  | echo 'checking for C compiler default output file name... a.out' | ||||||
|  | echo 'WARNING: ALL CAPITAL WARNING!' | ||||||
|  | echo 'checking for suffix of executables...' | ||||||
|  | echo 'foo.c:89: warning: some weird warning!' | ||||||
|  | exit 1 | ||||||
|  | """) | ||||||
|  |         configure() | ||||||
		Reference in New Issue
	
	Block a user
	 Todd Gamblin
					Todd Gamblin