mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-01 23:12:02 +00:00
Auto merge of #112390 - MoskalykA:move-two-tests-from-library-to-tests, r=workingjubilee
Move two tests from `tests/ui/std` to `library/std/tests` Hi, there, This pull request comes from this issue (#99417), sorry I made some mistakes creating the pull request, it's my first one.
This commit is contained in:
commit
e40e22be55
@ -1,38 +1,17 @@
|
||||
// run-pass
|
||||
|
||||
#![allow(unused_variables)]
|
||||
// no-prefer-dynamic
|
||||
// ignore-cross-compile
|
||||
|
||||
use std::env;
|
||||
use std::ffi::OsStr;
|
||||
use std::fs;
|
||||
use std::path::PathBuf;
|
||||
use std::process;
|
||||
use std::str;
|
||||
|
||||
fn main() {
|
||||
// If we're the child, make sure we were invoked correctly
|
||||
let args: Vec<String> = env::args().collect();
|
||||
if args.len() > 1 && args[1] == "child" {
|
||||
// FIXME: This should check the whole `args[0]` instead of just
|
||||
// checking that it ends_with the executable name. This
|
||||
// is needed because of Windows, which has a different behavior.
|
||||
// See #15149 for more info.
|
||||
let my_path = env::current_exe().unwrap();
|
||||
return assert_eq!(my_path.file_stem(), Some(OsStr::new("mytest")));
|
||||
}
|
||||
mod common;
|
||||
|
||||
test();
|
||||
}
|
||||
|
||||
fn test() {
|
||||
#[test]
|
||||
fn issue_15149() {
|
||||
// If we're the parent, copy our own binary to a new directory.
|
||||
let my_path = env::current_exe().unwrap();
|
||||
let my_dir = my_path.parent().unwrap();
|
||||
|
||||
let child_dir = PathBuf::from(env::var_os("RUST_TEST_TMPDIR").unwrap());
|
||||
let child_dir = child_dir.join("issue-15140-child");
|
||||
let temp = common::tmpdir();
|
||||
let child_dir = temp.join("issue-15140-child");
|
||||
fs::create_dir_all(&child_dir).unwrap();
|
||||
|
||||
let child_path = child_dir.join(&format!("mytest{}", env::consts::EXE_SUFFIX));
|
@ -1,10 +1,9 @@
|
||||
// run-pass
|
||||
// ignore-wasm (needs file descriptors and env variables)
|
||||
#[cfg(any(target_family = "unix", target_family = "windows"))]
|
||||
|
||||
use std::env;
|
||||
use std::fs::File;
|
||||
use std::io::{Read, Write};
|
||||
use std::path::PathBuf;
|
||||
|
||||
mod common;
|
||||
|
||||
#[cfg(unix)]
|
||||
fn switch_stdout_to(file: File) {
|
||||
@ -35,16 +34,18 @@ fn switch_stdout_to(file: File) {
|
||||
}
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let path = PathBuf::from(env::var_os("RUST_TEST_TMPDIR").unwrap());
|
||||
let path = path.join("switch-stdout-output");
|
||||
#[test]
|
||||
fn switch_stdout() {
|
||||
let temp = common::tmpdir();
|
||||
let path = temp.join("switch-stdout-output");
|
||||
let f = File::create(&path).unwrap();
|
||||
|
||||
println!("foo");
|
||||
std::io::stdout().flush().unwrap();
|
||||
let mut stdout = std::io::stdout();
|
||||
stdout.write(b"foo\n").unwrap();
|
||||
stdout.flush().unwrap();
|
||||
switch_stdout_to(f);
|
||||
println!("bar");
|
||||
std::io::stdout().flush().unwrap();
|
||||
stdout.write(b"bar\n").unwrap();
|
||||
stdout.flush().unwrap();
|
||||
|
||||
let mut contents = String::new();
|
||||
File::open(&path).unwrap().read_to_string(&mut contents).unwrap();
|
Loading…
Reference in New Issue
Block a user