zig/test/behavior/bugs/5398.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

32 lines
859 B
Zig

const std = @import("std");
const testing = std.testing;
pub const Mesh = struct {
id: u32,
};
pub const Material = struct {
transparent: bool = true,
emits_shadows: bool = true,
render_color: bool = true,
};
pub const Renderable = struct {
material: Material,
// The compiler inserts some padding here to ensure Mesh is correctly aligned.
mesh: Mesh,
};
var renderable: Renderable = undefined;
test "assignment of field with padding" {
renderable = Renderable{
.mesh = Mesh{ .id = 0 },
.material = Material{
.transparent = false,
.emits_shadows = false,
},
};
try testing.expectEqual(false, renderable.material.transparent);
try testing.expectEqual(false, renderable.material.emits_shadows);
try testing.expectEqual(true, renderable.material.render_color);
}