about summary refs log tree commit diff
diff options
context:
space:
mode:
authorShE3py <52315535+she3py@users.noreply.github.com>2023-08-20 21:50:45 +0200
committerShE3py <52315535+she3py@users.noreply.github.com>2023-08-20 21:50:45 +0200
commitf8a2f31ae48fbcf8b71684851b3652007a7094d7 (patch)
tree709d7c1039f829ebca6b6ffa2027c5a01fee8be7
parentdef52ba2b8d105601f7815fe768aa1cf9cdb3d93 (diff)
downloadrust-f8a2f31ae48fbcf8b71684851b3652007a7094d7.tar.gz
rust-f8a2f31ae48fbcf8b71684851b3652007a7094d7.zip
Add data race test to `std::env::{get, set}`
-rw-r--r--library/std/tests/env.rs20
1 files changed, 20 insertions, 0 deletions
diff --git a/library/std/tests/env.rs b/library/std/tests/env.rs
index 96b4f372b8b..a1ca85c2145 100644
--- a/library/std/tests/env.rs
+++ b/library/std/tests/env.rs
@@ -5,6 +5,7 @@ use rand::distributions::{Alphanumeric, DistString};
 
 mod common;
 use common::test_rng;
+use std::thread;
 
 #[track_caller]
 fn make_rand_name() -> OsString {
@@ -140,3 +141,22 @@ fn env_home_dir() {
         }
     }
 }
+
+#[test] // miri shouldn't detect any data race in this fn
+#[cfg_attr(any(not(miri), target_os = "emscripten"), ignore)]
+fn test_env_get_set_multithreaded() {
+    let getter = thread::spawn(|| {
+        for _ in 0..100 {
+            let _ = var_os("foo");
+        }
+    });
+
+    let setter = thread::spawn(|| {
+        for _ in 0..100 {
+            set_var("foo", "bar");
+        }
+    });
+
+    let _ = getter.join();
+    let _ = setter.join();
+}