aboutsummaryrefslogtreecommitdiff
path: root/unittests/allplatformstests.py
diff options
context:
space:
mode:
authorJussi Pakkanen <jpakkane@gmail.com>2021-09-25 14:42:12 +0300
committerGitHub <noreply@github.com>2021-09-25 14:42:12 +0300
commitf6ae82169cd3780d2c9cd0cae7edfea8c427ef35 (patch)
treec5134832db2202f3c273ff6575a23b5464e0a3fe /unittests/allplatformstests.py
parentc0efa7ab22f8900f6fa1dadf0d306ec375569c8d (diff)
parent30202a24021587b7d7ddffd8312eb5b425b3e273 (diff)
downloadmeson-f6ae82169cd3780d2c9cd0cae7edfea8c427ef35.zip
meson-f6ae82169cd3780d2c9cd0cae7edfea8c427ef35.tar.gz
meson-f6ae82169cd3780d2c9cd0cae7edfea8c427ef35.tar.bz2
Merge pull request #8773 from dcbaker/submit/rustc-enhancements-clippy
More enhancements for Rust + clippy support
Diffstat (limited to 'unittests/allplatformstests.py')
-rw-r--r--unittests/allplatformstests.py13
1 files changed, 13 insertions, 0 deletions
diff --git a/unittests/allplatformstests.py b/unittests/allplatformstests.py
index 7afa989..93a2e49 100644
--- a/unittests/allplatformstests.py
+++ b/unittests/allplatformstests.py
@@ -4034,3 +4034,16 @@ class AllPlatformTests(BasePlatformTests):
for file, details in files.items():
with self.subTest(key='{}.{}'.format(data_type, file)):
self.assertEqual(res[data_type][file], details)
+
+ @skip_if_not_language('rust')
+ @unittest.skipIf(not shutil.which('clippy-driver'), 'Test requires clippy-driver')
+ def test_rust_clippy(self) -> None:
+ if self.backend is not Backend.ninja:
+ raise unittest.SkipTest('Rust is only supported with ninja currently')
+ # Wehn clippy is used, we should get an exception since a variable named
+ # "foo" is used, but is on our denylist
+ testdir = os.path.join(self.rust_test_dir, '1 basic')
+ self.init(testdir, extra_args=['--werror'], override_envvars={'RUSTC': 'clippy-driver'})
+ with self.assertRaises(subprocess.CalledProcessError) as cm:
+ self.build()
+ self.assertIn('error: use of a blacklisted/placeholder name `foo`', cm.exception.stdout)