Skip to content

Commit

Permalink
more readable test expectations
Browse files Browse the repository at this point in the history
  • Loading branch information
nickbclifford committed Dec 29, 2023
1 parent 6d81f5c commit 2732025
Show file tree
Hide file tree
Showing 10 changed files with 51 additions and 46 deletions.
9 changes: 4 additions & 5 deletions tests/attributes.rs
Original file line number Diff line number Diff line change
Expand Up @@ -161,17 +161,16 @@ pub fn write() {
let console = BaseType::class(ctx.console).into();
let test_attr_t: MethodType = BaseType::class(test_attr).into();

(
vec![],
vec![
common::WriteTestResult::WithVariables {
locals: vec![
LocalVariable::new(ctype! { object[] }),
LocalVariable::new(ctype! { int }),
LocalVariable::new(test_attr_t.clone()),
LocalVariable::new(ctype! { float[] }),
LocalVariable::new(ctype! { object[] }),
LocalVariable::new(ctype! { int }),
],
asm! {
main_body: asm! {
load_token_type BaseType::class(ctx.class);
call get_type;
LoadTokenType test_attr_t;
Expand Down Expand Up @@ -240,7 +239,7 @@ pub fn write() {
@ret
Return;
},
)
}
},
b"a|0|\nb|1|\nc|0|3.14, 6.28\n",
)
Expand Down
21 changes: 19 additions & 2 deletions tests/common/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -64,9 +64,22 @@ pub fn read_fixture(name: &str, source: &str, test: impl FnOnce(Resolution)) ->
Ok(())
}

pub enum WriteTestResult {
MainBody(Vec<Instruction>),
WithVariables {
main_body: Vec<Instruction>,
locals: Vec<LocalVariable>
},
WithExceptions {
main_body: Vec<Instruction>,
locals: Vec<LocalVariable>,
exceptions: Vec<body::Exception>
}
}

pub fn write_fixture(
name: &str,
test: impl FnOnce(&mut WriteContext) -> (Vec<body::Exception>, Vec<LocalVariable>, Vec<Instruction>),
test: impl FnOnce(&mut WriteContext) -> WriteTestResult,
expect: &[u8],
) -> Result<(), Box<dyn std::error::Error>> {
let dll_name = format!("{}.dll", name);
Expand Down Expand Up @@ -96,7 +109,11 @@ pub fn write_fixture(
object,
};

let (exceptions, vars, ins) = test(&mut ctx);
let (exceptions, vars, ins) = match test(&mut ctx) {
WriteTestResult::MainBody(ins) => (vec![], vec![], ins),
WriteTestResult::WithVariables { main_body, locals } => (vec![], locals, main_body),
WriteTestResult::WithExceptions { main_body, locals, exceptions } => (exceptions, locals, main_body),
};

let main = ctx.resolution.push_method(
class,
Expand Down
9 changes: 4 additions & 5 deletions tests/events.rs
Original file line number Diff line number Diff line change
Expand Up @@ -162,13 +162,12 @@ pub fn write() {
let add = ctx.resolution.event_add_index(event);
let remove = ctx.resolution.event_remove_index(event);

(
vec![],
vec![
common::WriteTestResult::WithVariables {
locals: vec![
LocalVariable::new(BaseType::class(ctx.class).into()),
LocalVariable::new(handler_method),
],
asm! {
main_body: asm! {
// init obj
new_object ctx.default_ctor;
StoreLocal 0;
Expand Down Expand Up @@ -196,7 +195,7 @@ pub fn write() {
call invoke;
Return;
},
)
}
},
b"listener triggered\n",
)
Expand Down
10 changes: 5 additions & 5 deletions tests/exceptions.rs
Original file line number Diff line number Diff line change
Expand Up @@ -169,8 +169,8 @@ pub fn write() {
Return;
};

(
vec![
common::WriteTestResult::WithExceptions {
exceptions: vec![
body::Exception {
kind: body::ExceptionKind::Filter { offset: filter_start },
try_offset: try_start,
Expand All @@ -186,9 +186,9 @@ pub fn write() {
handler_length: ret - finally_start
}
],
vec![LocalVariable::new(ctype! { object })],
instructions
)
locals: vec![LocalVariable::new(ctype! { object })],
main_body: instructions
}
},
b"before throw\nerror code 1\nfinally\n",
)
Expand Down
9 changes: 4 additions & 5 deletions tests/fields_props.rs
Original file line number Diff line number Diff line change
Expand Up @@ -143,10 +143,9 @@ pub fn write() {
),
);

(
vec![],
vec![LocalVariable::new(BaseType::class(ctx.class).into())],
asm! {
common::WriteTestResult::WithVariables {
locals: vec![LocalVariable::new(BaseType::class(ctx.class).into())],
main_body: asm! {
// init static
LoadConstantInt32 -1;
call static_setter;
Expand Down Expand Up @@ -178,7 +177,7 @@ pub fn write() {
call write_line;
Return;
},
)
}
},
b"0, 2\n",
)
Expand Down
18 changes: 8 additions & 10 deletions tests/generics.rs
Original file line number Diff line number Diff line change
Expand Up @@ -173,10 +173,9 @@ pub fn write() {
.resolution
.push_method_reference(method_ref! { static void #console_type::WriteLine(string, object) });

(
vec![],
vec![LocalVariable::new(enum_class)],
asm! {
common::WriteTestResult::WithVariables {
locals: vec![LocalVariable::new(enum_class)],
main_body: asm! {
LoadConstantInt32 5;
call init_class;
call_virtual get_enum;
Expand All @@ -195,7 +194,7 @@ pub fn write() {
BranchTruthy loop_body;
Return;
},
)
}
},
b"0\n1\n2\n3\n4\n",
)
Expand Down Expand Up @@ -259,13 +258,12 @@ pub fn write_generic_class() {
let string_container: MethodType =
BaseType::class(TypeSource::generic(container, vec![ctype! { string }])).into();

(
vec![],
vec![
common::WriteTestResult::WithVariables {
locals: vec![
LocalVariable::new(int_container.clone()),
LocalVariable::new(string_container.clone()),
],
asm! {
main_body: asm! {
new_object ctx.resolution.push_method_reference(method_ref! { void @int_container::.ctor() });
StoreLocal 0;
new_object ctx.resolution.push_method_reference(method_ref! { void @string_container::.ctor() });
Expand Down Expand Up @@ -310,7 +308,7 @@ pub fn write_generic_class() {
call write_line;
Return;
},
)
}
},
b"1,2,3\nfoo,bar,baz\n",
)
Expand Down
4 changes: 1 addition & 3 deletions tests/hello_world.rs
Original file line number Diff line number Diff line change
Expand Up @@ -40,9 +40,7 @@ pub fn write() {
.resolution
.push_method_reference(method_ref! { static void #console_type::WriteLine(string) });

(
vec![],
vec![],
common::WriteTestResult::MainBody(
asm! {
load_string "Hello, world!";
call write_line;
Expand Down
9 changes: 4 additions & 5 deletions tests/oop.rs
Original file line number Diff line number Diff line change
Expand Up @@ -156,10 +156,9 @@ pub fn write() {

let console: MethodType = BaseType::class(ctx.console).into();

(
vec![],
vec![LocalVariable::new(array_list.clone()), LocalVariable::new(enumerator.clone())],
asm! {
common::WriteTestResult::WithVariables {
locals: vec![LocalVariable::new(array_list.clone()), LocalVariable::new(enumerator.clone())],
main_body: asm! {
new_object ctx.resolution.push_method_reference(method_ref! { void @array_list::.ctor() });
StoreLocal 0;
LoadLocal 0;
Expand Down Expand Up @@ -189,7 +188,7 @@ pub fn write() {
BranchTruthy loop_body;
Return;
},
)
}
},
b"20\n500\n",
)
Expand Down
4 changes: 1 addition & 3 deletions tests/pinvoke.rs
Original file line number Diff line number Diff line change
Expand Up @@ -42,9 +42,7 @@ pub fn write() {

let puts = libc_method("puts", msig! { static void (string) });

(
vec![],
vec![],
common::WriteTestResult::MainBody(
asm! {
load_string "hello from libc";
call puts;
Expand Down
4 changes: 1 addition & 3 deletions tests/resources.rs
Original file line number Diff line number Diff line change
Expand Up @@ -62,9 +62,7 @@ pub fn write() {
.push_type_reference(type_ref! { System.Reflection.Assembly in #mscorlib })
).into();

(
vec![],
vec![],
common::WriteTestResult::MainBody(
asm! {
load_string "strings";
load_token_type BaseType::class(ctx.class);
Expand Down

0 comments on commit 2732025

Please sign in to comment.