Commit 933231868a

Jakub Konka <kubkon@jakubkonka.com>
2024-01-15 11:34:47
test/link/macho: test re-exports in zig
1 parent 7dc6900
Changed files (1)
test
test/link/macho.zig
@@ -28,6 +28,7 @@ pub fn testAll(b: *Build, build_opts: BuildOptions) *Step {
     macho_step.dependOn(testNoDeadStrip(b, .{ .target = default_target }));
     macho_step.dependOn(testNoExportsDylib(b, .{ .target = default_target }));
     macho_step.dependOn(testPagezeroSize(b, .{ .target = default_target }));
+    macho_step.dependOn(testReexportsZig(b, .{ .target = default_target }));
     macho_step.dependOn(testRelocatable(b, .{ .target = default_target }));
     macho_step.dependOn(testRelocatableZig(b, .{ .target = default_target }));
     macho_step.dependOn(testSectionBoundarySymbols(b, .{ .target = default_target }));
@@ -897,6 +898,35 @@ fn testPagezeroSize(b: *Build, opts: Options) *Step {
     return test_step;
 }
 
+fn testReexportsZig(b: *Build, opts: Options) *Step {
+    const test_step = addTestStep(b, "macho-reexports-zig", opts);
+
+    const lib = addStaticLibrary(b, opts, .{ .name = "a", .zig_source_bytes = 
+    \\const x: i32 = 42;
+    \\export fn foo() i32 {
+    \\    return x;
+    \\}
+    \\comptime {
+    \\    @export(foo, .{ .name = "bar", .linkage = .Strong });
+    \\}
+    });
+
+    const exe = addExecutable(b, opts, .{ .name = "main", .c_source_bytes = 
+    \\extern int foo();
+    \\extern int bar();
+    \\int main() {
+    \\  return bar() - foo();
+    \\}
+    });
+    exe.linkLibrary(lib);
+
+    const run = addRunArtifact(exe);
+    run.expectExitCode(0);
+    test_step.dependOn(&run.step);
+
+    return test_step;
+}
+
 fn testRelocatable(b: *Build, opts: Options) *Step {
     const test_step = addTestStep(b, "macho-relocatable", opts);