Files
hakorune/src/mir/instruction/tests.rs
Selfhosting Dev a800acdb63 refactor: MIR instruction.rs 4-Phase大型リファクタリング完了(888→315行、64%削減)
Single Responsibility Principle適用による完全分離:
- Phase 1: テスト分離 → instruction/tests.rs (196行)
- Phase 2: Display実装分離 → instruction/display.rs (130行)
- Phase 3: メソッド実装分離 → instruction/methods.rs (247行)
- Phase 4: 統合テスト成功(全コンパイルエラー解決)

技術的成果:
- MirInstruction enumを単一責任に集中
- 各実装が独立して保守可能な構造
- EffectMask::read→READ修正も完了
- ビルド成功確認済み(警告のみ)

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-25 03:46:37 +09:00

199 lines
5.3 KiB
Rust

//! Tests for MIR Instructions
//!
//! Comprehensive test suite for all MIR instruction types and their methods.
use super::super::{Effect, EffectMask, ValueId};
use super::MirInstruction;
use crate::mir::types::{BinaryOp, ConstValue};
#[test]
fn test_const_instruction() {
let dst = ValueId::new(0);
let inst = MirInstruction::Const {
dst,
value: ConstValue::Integer(42),
};
assert_eq!(inst.dst_value(), Some(dst));
assert!(inst.used_values().is_empty());
assert!(inst.effects().is_pure());
}
#[test]
fn test_binop_instruction() {
let dst = ValueId::new(0);
let lhs = ValueId::new(1);
let rhs = ValueId::new(2);
let inst = MirInstruction::BinOp {
dst,
op: BinaryOp::Add,
lhs,
rhs,
};
assert_eq!(inst.dst_value(), Some(dst));
assert_eq!(inst.used_values(), vec![lhs, rhs]);
assert!(inst.effects().is_pure());
}
#[test]
fn test_call_instruction() {
let dst = ValueId::new(0);
let func = ValueId::new(1);
let arg1 = ValueId::new(2);
let arg2 = ValueId::new(3);
let inst = MirInstruction::Call {
dst: Some(dst),
func,
args: vec![arg1, arg2],
effects: EffectMask::IO,
};
assert_eq!(inst.dst_value(), Some(dst));
assert_eq!(inst.used_values(), vec![func, arg1, arg2]);
assert_eq!(inst.effects(), EffectMask::IO);
}
/*
#[test]
fn test_const_value_conversion() {
let const_val = ConstValue::Integer(42);
let nyash_val = const_val.to_nyash_value();
assert_eq!(nyash_val, NyashValue::new_integer(42));
let back = ConstValue::from_nyash_value(&nyash_val).unwrap();
assert_eq!(back, const_val);
}
*/
#[test]
fn test_ref_new_instruction() {
let dst = ValueId::new(0);
let box_val = ValueId::new(1);
let inst = MirInstruction::RefNew { dst, box_val };
assert_eq!(inst.dst_value(), Some(dst));
assert_eq!(inst.used_values(), vec![box_val]);
assert!(inst.effects().is_pure());
}
#[test]
fn test_ref_get_instruction() {
let dst = ValueId::new(0);
let reference = ValueId::new(1);
let field = "name".to_string();
let inst = MirInstruction::RefGet {
dst,
reference,
field,
};
assert_eq!(inst.dst_value(), Some(dst));
assert_eq!(inst.used_values(), vec![reference]);
assert!(!inst.effects().is_pure());
assert!(inst
.effects()
.contains(super::super::effect::Effect::ReadHeap));
}
#[test]
fn test_ref_set_instruction() {
let reference = ValueId::new(0);
let field = "value".to_string();
let value = ValueId::new(1);
let inst = MirInstruction::RefSet {
reference,
field,
value,
};
assert_eq!(inst.dst_value(), None);
assert_eq!(inst.used_values(), vec![reference, value]);
assert!(!inst.effects().is_pure());
assert!(inst
.effects()
.contains(super::super::effect::Effect::WriteHeap));
}
#[test]
fn test_weak_new_instruction() {
let dst = ValueId::new(0);
let box_val = ValueId::new(1);
let inst = MirInstruction::WeakNew { dst, box_val };
assert_eq!(inst.dst_value(), Some(dst));
assert_eq!(inst.used_values(), vec![box_val]);
assert!(inst.effects().is_pure());
}
#[test]
fn test_weak_load_instruction() {
let dst = ValueId::new(0);
let weak_ref = ValueId::new(1);
let inst = MirInstruction::WeakLoad { dst, weak_ref };
assert_eq!(inst.dst_value(), Some(dst));
assert_eq!(inst.used_values(), vec![weak_ref]);
assert!(!inst.effects().is_pure());
assert!(inst
.effects()
.contains(super::super::effect::Effect::ReadHeap));
}
#[test]
fn test_barrier_instructions() {
let ptr = ValueId::new(0);
let read_barrier = MirInstruction::BarrierRead { ptr };
assert_eq!(read_barrier.dst_value(), None);
assert_eq!(read_barrier.used_values(), vec![ptr]);
assert!(read_barrier
.effects()
.contains(super::super::effect::Effect::Barrier));
assert!(read_barrier
.effects()
.contains(super::super::effect::Effect::ReadHeap));
let write_barrier = MirInstruction::BarrierWrite { ptr };
assert_eq!(write_barrier.dst_value(), None);
assert_eq!(write_barrier.used_values(), vec![ptr]);
assert!(write_barrier
.effects()
.contains(super::super::effect::Effect::Barrier));
assert!(write_barrier
.effects()
.contains(super::super::effect::Effect::WriteHeap));
}
#[test]
fn test_extern_call_instruction() {
let dst = ValueId::new(0);
let arg1 = ValueId::new(1);
let arg2 = ValueId::new(2);
let inst = MirInstruction::ExternCall {
dst: Some(dst),
iface_name: "env.console".to_string(),
method_name: "log".to_string(),
args: vec![arg1, arg2],
effects: super::super::effect::EffectMask::IO,
};
assert_eq!(inst.dst_value(), Some(dst));
assert_eq!(inst.used_values(), vec![arg1, arg2]);
assert_eq!(inst.effects(), super::super::effect::EffectMask::IO);
// Test void extern call
let void_inst = MirInstruction::ExternCall {
dst: None,
iface_name: "env.canvas".to_string(),
method_name: "fillRect".to_string(),
args: vec![arg1],
effects: super::super::effect::EffectMask::IO,
};
assert_eq!(void_inst.dst_value(), None);
assert_eq!(void_inst.used_values(), vec![arg1]);
}