Change filename in thread_manager::test-thread_context

This commit is contained in:
Quentin Legot 2023-03-28 19:47:42 +02:00
parent e170256c9b
commit cfcdce750b

View File

@ -206,20 +206,21 @@ mod test {
#[ignore = "Pas encore terminé, contient des bugs"]
fn test_thread_context() {
let mut machine = Machine::init_machine();
loader::load("../test.o", &mut machine, 0).expect("IO Error");
loader::load("./test/riscv_instructions/simple_arithmetics/unsigned_addition", &mut machine, 0).expect("IO Error");
let start_pc = 0x4000;
let system = &mut System::default();
let thread1 = Thread::new("th1");
let thread1 = Rc::new(RefCell::new(thread1));
system.get_thread_manager().get_g_alive().push(Rc::clone(&thread1));
let owner = Process { num_thread: 0 };
system.get_thread_manager().start_thread(Rc::clone(&thread1), owner, 0x94 as u64, 0);
debug_assert_eq!(thread1.borrow_mut().thread_context.pc, 0x94 as u64);
system.get_thread_manager().start_thread(Rc::clone(&thread1), owner, start_pc, 0);
debug_assert_eq!(thread1.borrow_mut().thread_context.pc, start_pc);
let to_run = system.get_thread_manager().find_next_to_run().unwrap();
debug_assert_eq!(to_run, Rc::clone(&thread1));
debug_assert!(system.get_thread_manager().get_g_alive().contains(&Rc::clone(&thread1)));
system.get_thread_manager().switch_to(&mut machine, Rc::clone(&to_run));
debug_assert_eq!(system.get_thread_manager().g_current_thread, Option::Some(Rc::clone(&thread1)));
debug_assert_eq!(machine.pc, 0x94);
debug_assert_eq!(machine.pc, start_pc);
machine.run();
}