diff options
| author | Jakub Konka <kubkon@jakubkonka.com> | 2022-06-25 10:57:56 +0200 |
|---|---|---|
| committer | Jakub Konka <kubkon@jakubkonka.com> | 2022-06-25 10:57:56 +0200 |
| commit | 8f00bc9d231c0c686b2ffa3bd0b14181afa7a171 (patch) | |
| tree | 9aac8869b99ae2927dad90be5ec2a75b1cd20bad /test | |
| parent | dfdb807543a03eec27341deec6a5f3b88f87fac3 (diff) | |
| download | zig-8f00bc9d231c0c686b2ffa3bd0b14181afa7a171.tar.gz zig-8f00bc9d231c0c686b2ffa3bd0b14181afa7a171.zip | |
link-tests: put macho search strategy tests into one test case
Diffstat (limited to 'test')
| -rw-r--r-- | test/link.zig | 6 | ||||
| -rw-r--r-- | test/link/macho/search_paths_first/a.c | 7 | ||||
| -rw-r--r-- | test/link/macho/search_paths_first/build.zig | 41 | ||||
| -rw-r--r-- | test/link/macho/search_paths_first/main.c | 9 | ||||
| -rw-r--r-- | test/link/macho/search_strategy/a.c (renamed from test/link/macho/search_dylibs_first/a.c) | 0 | ||||
| -rw-r--r-- | test/link/macho/search_strategy/build.zig (renamed from test/link/macho/search_dylibs_first/build.zig) | 44 | ||||
| -rw-r--r-- | test/link/macho/search_strategy/main.c (renamed from test/link/macho/search_dylibs_first/main.c) | 0 |
7 files changed, 33 insertions, 74 deletions
diff --git a/test/link.zig b/test/link.zig index c00c960626..62bdcff4b0 100644 --- a/test/link.zig +++ b/test/link.zig @@ -61,11 +61,7 @@ pub fn addCases(cases: *tests.StandaloneContext) void { .build_modes = true, }); - cases.addBuildFile("test/link/macho/search_paths_first/build.zig", .{ - .build_modes = true, - }); - - cases.addBuildFile("test/link/macho/search_dylibs_first/build.zig", .{ + cases.addBuildFile("test/link/macho/search_strategy/build.zig", .{ .build_modes = true, }); } diff --git a/test/link/macho/search_paths_first/a.c b/test/link/macho/search_paths_first/a.c deleted file mode 100644 index 199b31e1a0..0000000000 --- a/test/link/macho/search_paths_first/a.c +++ /dev/null @@ -1,7 +0,0 @@ -#include <stdio.h> - -char world[] = "world"; - -char* hello() { - return "Hello"; -} diff --git a/test/link/macho/search_paths_first/build.zig b/test/link/macho/search_paths_first/build.zig deleted file mode 100644 index 63c807bd4c..0000000000 --- a/test/link/macho/search_paths_first/build.zig +++ /dev/null @@ -1,41 +0,0 @@ -const std = @import("std"); -const Builder = std.build.Builder; - -pub fn build(b: *Builder) void { - const mode = b.standardReleaseOptions(); - - const test_step = b.step("test", "Test"); - test_step.dependOn(b.getInstallStep()); - - const static = b.addStaticLibrary("a", null); - static.setBuildMode(mode); - static.addCSourceFile("a.c", &.{}); - static.linkLibC(); - static.override_dest_dir = std.build.InstallDir{ - .custom = "static", - }; - static.install(); - - const dylib = b.addSharedLibrary("a", null, b.version(1, 0, 0)); - dylib.setBuildMode(mode); - dylib.addCSourceFile("a.c", &.{}); - dylib.linkLibC(); - dylib.override_dest_dir = std.build.InstallDir{ - .custom = "dynamic", - }; - dylib.install(); - - const exe = b.addExecutable("main", null); - exe.setBuildMode(mode); - exe.addCSourceFile("main.c", &.{}); - exe.linkSystemLibraryName("a"); - exe.linkLibC(); - exe.addLibraryPath(b.pathFromRoot("zig-out/static")); - exe.addLibraryPath(b.pathFromRoot("zig-out/dynamic")); - exe.search_strategy = .paths_first; - - const run = exe.run(); - run.cwd = b.pathFromRoot("."); - run.expectStdOutEqual("Hello world"); - test_step.dependOn(&run.step); -} diff --git a/test/link/macho/search_paths_first/main.c b/test/link/macho/search_paths_first/main.c deleted file mode 100644 index be1647ddad..0000000000 --- a/test/link/macho/search_paths_first/main.c +++ /dev/null @@ -1,9 +0,0 @@ -#include <stdio.h> - -char* hello(); -extern char world[]; - -int main() { - printf("%s %s", hello(), world); - return 0; -} diff --git a/test/link/macho/search_dylibs_first/a.c b/test/link/macho/search_strategy/a.c index 199b31e1a0..199b31e1a0 100644 --- a/test/link/macho/search_dylibs_first/a.c +++ b/test/link/macho/search_strategy/a.c diff --git a/test/link/macho/search_dylibs_first/build.zig b/test/link/macho/search_strategy/build.zig index 90c6a4a849..c5e867c8d0 100644 --- a/test/link/macho/search_dylibs_first/build.zig +++ b/test/link/macho/search_strategy/build.zig @@ -1,5 +1,6 @@ const std = @import("std"); const Builder = std.build.Builder; +const LibExeObjectStep = std.build.LibExeObjStep; pub fn build(b: *Builder) void { const mode = b.standardReleaseOptions(); @@ -7,6 +8,36 @@ pub fn build(b: *Builder) void { const test_step = b.step("test", "Test"); test_step.dependOn(b.getInstallStep()); + { + // -search_dylibs_first + const exe = createScenario(b, mode); + exe.search_strategy = .dylibs_first; + + const check = exe.checkObject(.macho); + check.checkStart("cmd LOAD_DYLIB"); + check.checkNext("name @rpath/liba.dylib"); + + test_step.dependOn(&check.step); + + const run = exe.run(); + run.cwd = b.pathFromRoot("."); + run.expectStdOutEqual("Hello world"); + test_step.dependOn(&run.step); + } + + { + // -search_paths_first + const exe = createScenario(b, mode); + exe.search_strategy = .paths_first; + + const run = exe.run(); + run.cwd = b.pathFromRoot("."); + run.expectStdOutEqual("Hello world"); + test_step.dependOn(&run.step); + } +} + +fn createScenario(b: *Builder, mode: std.builtin.Mode) *LibExeObjectStep { const static = b.addStaticLibrary("a", null); static.setBuildMode(mode); static.addCSourceFile("a.c", &.{}); @@ -33,16 +64,5 @@ pub fn build(b: *Builder) void { exe.addLibraryPath(b.pathFromRoot("zig-out/static")); exe.addLibraryPath(b.pathFromRoot("zig-out/dynamic")); exe.addRPath(b.pathFromRoot("zig-out/dynamic")); - exe.search_strategy = .dylibs_first; - - const check = exe.checkObject(.macho); - check.checkStart("cmd LOAD_DYLIB"); - check.checkNext("name @rpath/liba.dylib"); - - test_step.dependOn(&check.step); - - const run = exe.run(); - run.cwd = b.pathFromRoot("."); - run.expectStdOutEqual("Hello world"); - test_step.dependOn(&run.step); + return exe; } diff --git a/test/link/macho/search_dylibs_first/main.c b/test/link/macho/search_strategy/main.c index be1647ddad..be1647ddad 100644 --- a/test/link/macho/search_dylibs_first/main.c +++ b/test/link/macho/search_strategy/main.c |
