]> git.proxmox.com Git - rustc.git/blame - vendor/chalk-solve-0.55.0/src/solve/test/bench.rs
Merge tag 'debian/1.52.1+dfsg1-1_exp2' into proxmox/buster
[rustc.git] / vendor / chalk-solve-0.55.0 / src / solve / test / bench.rs
CommitLineData
f9f354fc
XL
1//! Benchmarking tests.
2
3extern crate test;
4use self::test::Bencher;
5
6use crate::db::ChalkDatabase;
7use crate::query::{ProgramSolverChoice, ProgramText};
8use chalk_solve::SolverChoice;
9use ir;
10use std::sync::Arc;
11
12use super::{assert_result, parse_and_lower_goal, parse_and_lower_program};
13
14fn run_bench(
15 program_text: &str,
16 solver_choice: SolverChoice,
17 goal_text: &str,
18 bencher: &mut Bencher,
19 expected: &str,
20) {
21 ChalkDatabase::with_program(Arc::new(program_text.to_string()), solver_choice, |db| {
22 let program = db.lowered_program().unwrap();
23 let env = db.environment().unwrap();
24 ir::tls::set_current_program(&program, || {
25 let goal = parse_and_lower_goal(&program, goal_text).unwrap();
26 let peeled_goal = goal.into_peeled_goal();
27
28 // Execute once to get an expected result.
29 let result = solver_choice.solve_root_goal(&env, &peeled_goal);
30
31 // Check expectation.
32 assert_result(&result, expected);
33
34 // Then do it many times to measure time.
35 bencher.iter(|| solver_choice.solve_root_goal(&env, &peeled_goal));
36 });
37 });
38}
39
40const CYCLEY: &str = "
41trait AsRef<T> { }
42trait Clone { }
43trait Copy where Self: Clone { }
44trait Sized { }
45
46struct i32 { }
47impl Copy for i32 { }
48impl Clone for i32 { }
49impl Sized for i32 { }
50
51struct u32 { }
52impl Copy for u32 { }
53impl Clone for u32 { }
54impl Sized for u32 { }
55
56struct Rc<T> { }
57impl<T> Clone for Rc<T> { }
58impl<T> Sized for Rc<T> { }
59
60struct Box<T> { }
61impl<T> AsRef<T> for Box<T> where T: Sized { }
62impl<T> Clone for Box<T> where T: Clone { }
63impl<T> Sized for Box<T> { }
64
65// Meant to be [T]
66struct Slice<T> where T: Sized { }
67impl<T> Sized for Slice<T> { }
68impl<T> AsRef<Slice<T>> for Slice<T> where T: Sized { }
69
70struct Vec<T> where T: Sized { }
71impl<T> AsRef<Slice<T>> for Vec<T> where T: Sized { }
72impl<T> AsRef<Vec<T>> for Vec<T> where T: Sized { }
73impl<T> Clone for Vec<T> where T: Clone, T: Sized { }
74impl<T> Sized for Vec<T> where T: Sized { }
75
76trait SliceExt
77 where <Self as SliceExt>::Item: Clone
78{
79 type Item;
80}
81
82impl<T> SliceExt for Slice<T>
83 where T: Clone
84{
85 type Item = T;
86}
87";
88
89const CYCLEY_GOAL: &str = "
90forall<T> {
91 if (
92 <Slice<T> as SliceExt>::Item: Clone;
93 <Slice<T> as SliceExt>::Item: Sized;
94 T: Clone;
95 T: Sized
96 ) {
97 T: Sized
98 }
99}
100";
101
102#[bench]
103fn cycley_slg(b: &mut Bencher) {
104 run_bench(
105 CYCLEY,
106 SolverChoice::SLG { max_size: 20 },
107 CYCLEY_GOAL,
108 b,
109 "Unique",
110 );
111}