Auto merge of #124497 - rytheo:move-std-tests-to-library, r=workingjubilee
Move some stdlib tests from `tests/ui` to `library/std/tests` Related to #99417
This commit is contained in:
commit
8cef37dbb6
11 changed files with 97 additions and 89 deletions
|
@ -1,4 +1,3 @@
|
||||||
//@ run-pass
|
|
||||||
// Test that `Clone` is correctly implemented for builtin types.
|
// Test that `Clone` is correctly implemented for builtin types.
|
||||||
// Also test that cloning an array or a tuple is done right, i.e.
|
// Also test that cloning an array or a tuple is done right, i.e.
|
||||||
// each component is cloned.
|
// each component is cloned.
|
||||||
|
@ -7,7 +6,7 @@ fn test_clone<T: Clone>(arg: T) {
|
||||||
let _ = arg.clone();
|
let _ = arg.clone();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn foo() { }
|
fn foo() {}
|
||||||
|
|
||||||
#[derive(Debug, PartialEq, Eq)]
|
#[derive(Debug, PartialEq, Eq)]
|
||||||
struct S(i32);
|
struct S(i32);
|
||||||
|
@ -18,7 +17,8 @@ impl Clone for S {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
#[test]
|
||||||
|
fn builtin_clone() {
|
||||||
test_clone(foo);
|
test_clone(foo);
|
||||||
test_clone([1; 56]);
|
test_clone([1; 56]);
|
||||||
test_clone((1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1));
|
test_clone((1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1));
|
||||||
|
@ -27,19 +27,7 @@ fn main() {
|
||||||
let b = [S(1), S(2), S(3)];
|
let b = [S(1), S(2), S(3)];
|
||||||
assert_eq!(b, a.clone());
|
assert_eq!(b, a.clone());
|
||||||
|
|
||||||
let a = (
|
let a = ((S(1), S(0)), ((S(0), S(0), S(1)), S(0)));
|
||||||
(S(1), S(0)),
|
let b = ((S(2), S(1)), ((S(1), S(1), S(2)), S(1)));
|
||||||
(
|
|
||||||
(S(0), S(0), S(1)),
|
|
||||||
S(0)
|
|
||||||
)
|
|
||||||
);
|
|
||||||
let b = (
|
|
||||||
(S(2), S(1)),
|
|
||||||
(
|
|
||||||
(S(1), S(1), S(2)),
|
|
||||||
S(1)
|
|
||||||
)
|
|
||||||
);
|
|
||||||
assert_eq!(b, a.clone());
|
assert_eq!(b, a.clone());
|
||||||
}
|
}
|
51
library/std/tests/eq-multidispatch.rs
Normal file
51
library/std/tests/eq-multidispatch.rs
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
#[derive(PartialEq, Debug)]
|
||||||
|
struct Bar;
|
||||||
|
#[derive(Debug)]
|
||||||
|
struct Baz;
|
||||||
|
#[derive(Debug)]
|
||||||
|
struct Foo;
|
||||||
|
#[derive(Debug)]
|
||||||
|
struct Fu;
|
||||||
|
|
||||||
|
impl PartialEq for Baz {
|
||||||
|
fn eq(&self, _: &Baz) -> bool {
|
||||||
|
true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl PartialEq<Fu> for Foo {
|
||||||
|
fn eq(&self, _: &Fu) -> bool {
|
||||||
|
true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl PartialEq<Foo> for Fu {
|
||||||
|
fn eq(&self, _: &Foo) -> bool {
|
||||||
|
true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl PartialEq<Bar> for Foo {
|
||||||
|
fn eq(&self, _: &Bar) -> bool {
|
||||||
|
false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl PartialEq<Foo> for Bar {
|
||||||
|
fn eq(&self, _: &Foo) -> bool {
|
||||||
|
false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn eq_multidispatch() {
|
||||||
|
assert!(Bar != Foo);
|
||||||
|
assert!(Foo != Bar);
|
||||||
|
|
||||||
|
assert_eq!(Bar, Bar);
|
||||||
|
|
||||||
|
assert_eq!(Baz, Baz);
|
||||||
|
|
||||||
|
assert_eq!(Foo, Fu);
|
||||||
|
assert_eq!(Fu, Foo);
|
||||||
|
}
|
|
@ -1,5 +1,4 @@
|
||||||
//@ run-pass
|
#[test]
|
||||||
|
|
||||||
fn test_stack_assign() {
|
fn test_stack_assign() {
|
||||||
let s: String = "a".to_string();
|
let s: String = "a".to_string();
|
||||||
println!("{}", s.clone());
|
println!("{}", s.clone());
|
||||||
|
@ -9,8 +8,12 @@ fn test_stack_assign() {
|
||||||
assert!((s != u));
|
assert!((s != u));
|
||||||
}
|
}
|
||||||
|
|
||||||
fn test_heap_lit() { "a big string".to_string(); }
|
#[test]
|
||||||
|
fn test_heap_lit() {
|
||||||
|
"a big string".to_string();
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
fn test_heap_assign() {
|
fn test_heap_assign() {
|
||||||
let s: String = "a big ol' string".to_string();
|
let s: String = "a big ol' string".to_string();
|
||||||
let t: String = "a big ol' string".to_string();
|
let t: String = "a big ol' string".to_string();
|
||||||
|
@ -19,11 +22,13 @@ fn test_heap_assign() {
|
||||||
assert!((s != u));
|
assert!((s != u));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
fn test_heap_log() {
|
fn test_heap_log() {
|
||||||
let s = "a big ol' string".to_string();
|
let s = "a big ol' string".to_string();
|
||||||
println!("{}", s);
|
println!("{}", s);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
fn test_append() {
|
fn test_append() {
|
||||||
let mut s = String::new();
|
let mut s = String::new();
|
||||||
s.push_str("a");
|
s.push_str("a");
|
||||||
|
@ -41,11 +46,3 @@ fn test_append() {
|
||||||
s.push_str("&tea");
|
s.push_str("&tea");
|
||||||
assert_eq!(s, "coffee&tea");
|
assert_eq!(s, "coffee&tea");
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn main() {
|
|
||||||
test_stack_assign();
|
|
||||||
test_heap_lit();
|
|
||||||
test_heap_assign();
|
|
||||||
test_heap_log();
|
|
||||||
test_append();
|
|
||||||
}
|
|
|
@ -1,18 +1,18 @@
|
||||||
//@ run-pass
|
|
||||||
|
|
||||||
#![allow(non_camel_case_types)]
|
#![allow(non_camel_case_types)]
|
||||||
#![allow(dead_code)]
|
#![allow(dead_code)]
|
||||||
|
|
||||||
#[derive(Clone, Debug)]
|
#[derive(Clone, Debug)]
|
||||||
enum foo {
|
enum foo {
|
||||||
a(usize),
|
a(usize),
|
||||||
b(String),
|
b(String),
|
||||||
}
|
}
|
||||||
|
|
||||||
fn check_log<T: std::fmt::Debug>(exp: String, v: T) {
|
fn check_log<T: std::fmt::Debug>(exp: String, v: T) {
|
||||||
assert_eq!(exp, format!("{:?}", v));
|
assert_eq!(exp, format!("{:?}", v));
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn main() {
|
#[test]
|
||||||
|
fn log_knows_the_names_of_variants_in_std() {
|
||||||
let mut x = Some(foo::a(22));
|
let mut x = Some(foo::a(22));
|
||||||
let exp = "Some(a(22))".to_string();
|
let exp = "Some(a(22))".to_string();
|
||||||
let act = format!("{:?}", x);
|
let act = format!("{:?}", x);
|
|
@ -1,12 +1,10 @@
|
||||||
//@ run-pass
|
|
||||||
|
|
||||||
use std::fmt::Debug;
|
|
||||||
use std::cmp::{self, Ordering};
|
use std::cmp::{self, Ordering};
|
||||||
|
use std::fmt::Debug;
|
||||||
|
|
||||||
#[derive(Debug, Copy, Clone, PartialEq, Eq)]
|
#[derive(Debug, Copy, Clone, PartialEq, Eq)]
|
||||||
struct Foo {
|
struct Foo {
|
||||||
n: u8,
|
n: u8,
|
||||||
name: &'static str
|
name: &'static str,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl PartialOrd for Foo {
|
impl PartialOrd for Foo {
|
||||||
|
@ -21,7 +19,8 @@ impl Ord for Foo {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
#[test]
|
||||||
|
fn minmax_stability() {
|
||||||
let a = Foo { n: 4, name: "a" };
|
let a = Foo { n: 4, name: "a" };
|
||||||
let b = Foo { n: 4, name: "b" };
|
let b = Foo { n: 4, name: "b" };
|
||||||
let c = Foo { n: 8, name: "c" };
|
let c = Foo { n: 8, name: "c" };
|
|
@ -1,6 +1,5 @@
|
||||||
//@ run-pass
|
#[test]
|
||||||
|
fn seq_compare() {
|
||||||
pub fn main() {
|
|
||||||
assert!(("hello".to_string() < "hellr".to_string()));
|
assert!(("hello".to_string() < "hellr".to_string()));
|
||||||
assert!(("hello ".to_string() > "hello".to_string()));
|
assert!(("hello ".to_string() > "hello".to_string()));
|
||||||
assert!(("hello".to_string() != "there".to_string()));
|
assert!(("hello".to_string() != "there".to_string()));
|
|
@ -1,9 +1,8 @@
|
||||||
//@ check-pass
|
|
||||||
|
|
||||||
// This intends to use the unsizing coercion from array to slice, but it only
|
// This intends to use the unsizing coercion from array to slice, but it only
|
||||||
// works if we resolve `<&[u8]>::from` as the reflexive `From<T> for T`. In
|
// works if we resolve `<&[u8]>::from` as the reflexive `From<T> for T`. In
|
||||||
// #113238, we found that gimli had added its own `From<EndianSlice> for &[u8]`
|
// #113238, we found that gimli had added its own `From<EndianSlice> for &[u8]`
|
||||||
// that affected all `std/backtrace` users.
|
// that affected all `std/backtrace` users.
|
||||||
fn main() {
|
#[test]
|
||||||
|
fn slice_from_array() {
|
||||||
let _ = <&[u8]>::from(&[]);
|
let _ = <&[u8]>::from(&[]);
|
||||||
}
|
}
|
|
@ -1,10 +1,13 @@
|
||||||
//@ run-pass
|
|
||||||
#![allow(dead_code)]
|
#![allow(dead_code)]
|
||||||
|
|
||||||
use std::fmt::Debug;
|
use std::fmt::Debug;
|
||||||
|
|
||||||
struct NT(str);
|
struct NT(str);
|
||||||
struct DST { a: u32, b: str }
|
|
||||||
|
struct DST {
|
||||||
|
a: u32,
|
||||||
|
b: str,
|
||||||
|
}
|
||||||
|
|
||||||
macro_rules! check {
|
macro_rules! check {
|
||||||
(val: $ty_of:expr, $expected:expr) => {
|
(val: $ty_of:expr, $expected:expr) => {
|
||||||
|
@ -15,23 +18,24 @@ macro_rules! check {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
/// Tests that [`std::any::type_name`] supports unsized types.
|
||||||
// type_name should support unsized types
|
#[test]
|
||||||
|
fn type_name_unsized() {
|
||||||
check!([u8], "[u8]");
|
check!([u8], "[u8]");
|
||||||
check!(str, "str");
|
check!(str, "str");
|
||||||
check!(dyn Send, "dyn core::marker::Send");
|
check!(dyn Send, "dyn core::marker::Send");
|
||||||
check!(NT, "issue_21058::NT");
|
check!(NT, "type_name_unsized::NT");
|
||||||
check!(DST, "issue_21058::DST");
|
check!(DST, "type_name_unsized::DST");
|
||||||
check!(&i32, "&i32");
|
check!(&i32, "&i32");
|
||||||
check!(&'static i32, "&i32");
|
check!(&'static i32, "&i32");
|
||||||
check!((i32, u32), "(i32, u32)");
|
check!((i32, u32), "(i32, u32)");
|
||||||
check!(val: foo(), "issue_21058::Foo");
|
check!(val: foo(), "type_name_unsized::Foo");
|
||||||
check!(val: Foo::new, "issue_21058::Foo::new");
|
check!(val: Foo::new, "type_name_unsized::Foo::new");
|
||||||
check!(val:
|
check!(val:
|
||||||
<Foo as Debug>::fmt,
|
<Foo as Debug>::fmt,
|
||||||
"<issue_21058::Foo as core::fmt::Debug>::fmt"
|
"<type_name_unsized::Foo as core::fmt::Debug>::fmt"
|
||||||
);
|
);
|
||||||
check!(val: || {}, "issue_21058::main::{{closure}}");
|
check!(val: || {}, "type_name_unsized::type_name_unsized::{{closure}}");
|
||||||
bar::<i32>();
|
bar::<i32>();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -56,7 +60,9 @@ fn type_name_of_val<T>(_: T) -> &'static str {
|
||||||
struct Foo;
|
struct Foo;
|
||||||
|
|
||||||
impl Foo {
|
impl Foo {
|
||||||
fn new() -> Self { Foo }
|
fn new() -> Self {
|
||||||
|
Foo
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn foo() -> impl Debug {
|
fn foo() -> impl Debug {
|
|
@ -1,10 +1,10 @@
|
||||||
//@ run-pass
|
|
||||||
|
|
||||||
#![allow(stable_features)]
|
#![allow(stable_features)]
|
||||||
#![feature(volatile)]
|
#![feature(volatile)]
|
||||||
|
|
||||||
use std::ptr::{read_volatile, write_volatile};
|
use std::ptr::{read_volatile, write_volatile};
|
||||||
|
|
||||||
fn main() {
|
#[test]
|
||||||
|
fn volatile_fat_ptr() {
|
||||||
let mut x: &'static str = "test";
|
let mut x: &'static str = "test";
|
||||||
unsafe {
|
unsafe {
|
||||||
let a = read_volatile(&x);
|
let a = read_volatile(&x);
|
|
@ -3862,7 +3862,6 @@ ui/statics/issue-91050-1.rs
|
||||||
ui/statics/issue-91050-2.rs
|
ui/statics/issue-91050-2.rs
|
||||||
ui/std/issue-3563-3.rs
|
ui/std/issue-3563-3.rs
|
||||||
ui/std/issue-81357-unsound-file-methods.rs
|
ui/std/issue-81357-unsound-file-methods.rs
|
||||||
ui/stdlib-unit-tests/issue-21058.rs
|
|
||||||
ui/structs-enums/enum-rec/issue-17431-6.rs
|
ui/structs-enums/enum-rec/issue-17431-6.rs
|
||||||
ui/structs-enums/enum-rec/issue-17431-7.rs
|
ui/structs-enums/enum-rec/issue-17431-7.rs
|
||||||
ui/structs-enums/issue-103869.rs
|
ui/structs-enums/issue-103869.rs
|
||||||
|
|
|
@ -1,30 +0,0 @@
|
||||||
//@ run-pass
|
|
||||||
|
|
||||||
#[derive(PartialEq, Debug)]
|
|
||||||
struct Bar;
|
|
||||||
#[derive(Debug)]
|
|
||||||
struct Baz;
|
|
||||||
#[derive(Debug)]
|
|
||||||
struct Foo;
|
|
||||||
#[derive(Debug)]
|
|
||||||
struct Fu;
|
|
||||||
|
|
||||||
impl PartialEq for Baz { fn eq(&self, _: &Baz) -> bool { true } }
|
|
||||||
|
|
||||||
impl PartialEq<Fu> for Foo { fn eq(&self, _: &Fu) -> bool { true } }
|
|
||||||
impl PartialEq<Foo> for Fu { fn eq(&self, _: &Foo) -> bool { true } }
|
|
||||||
|
|
||||||
impl PartialEq<Bar> for Foo { fn eq(&self, _: &Bar) -> bool { false } }
|
|
||||||
impl PartialEq<Foo> for Bar { fn eq(&self, _: &Foo) -> bool { false } }
|
|
||||||
|
|
||||||
fn main() {
|
|
||||||
assert!(Bar != Foo);
|
|
||||||
assert!(Foo != Bar);
|
|
||||||
|
|
||||||
assert_eq!(Bar, Bar);
|
|
||||||
|
|
||||||
assert_eq!(Baz, Baz);
|
|
||||||
|
|
||||||
assert_eq!(Foo, Fu);
|
|
||||||
assert_eq!(Fu, Foo);
|
|
||||||
}
|
|
Loading…
Add table
Reference in a new issue