zig/test/behavior/switch_prong_err_enum.zig
Andrew Kelley 5619ce2406 Merge remote-tracking branch 'origin/master' into stage2-whole-file-astgen
Conflicts:
 * doc/langref.html.in
 * lib/std/enums.zig
 * lib/std/fmt.zig
 * lib/std/hash/auto_hash.zig
 * lib/std/math.zig
 * lib/std/mem.zig
 * lib/std/meta.zig
 * test/behavior/alignof.zig
 * test/behavior/bitcast.zig
 * test/behavior/bugs/1421.zig
 * test/behavior/cast.zig
 * test/behavior/ptrcast.zig
 * test/behavior/type_info.zig
 * test/behavior/vector.zig

Master branch added `try` to a bunch of testing function calls, and some
lines also had changed how to refer to the native architecture and other
`@import("builtin")` stuff.
2021-05-08 14:45:21 -07:00

31 lines
646 B
Zig

const expect = @import("std").testing.expect;
var read_count: u64 = 0;
fn readOnce() anyerror!u64 {
read_count += 1;
return read_count;
}
const FormValue = union(enum) {
Address: u64,
Other: bool,
};
fn doThing(form_id: u64) anyerror!FormValue {
return switch (form_id) {
17 => FormValue{ .Address = try readOnce() },
else => error.InvalidDebugInfo,
};
}
test "switch prong returns error enum" {
switch (doThing(17) catch unreachable) {
FormValue.Address => |payload| {
try expect(payload == 1);
},
else => unreachable,
}
try expect(read_count == 1);
}