aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorJakub Konka <kubkon@jakubkonka.com>2022-06-25 10:57:56 +0200
committerJakub Konka <kubkon@jakubkonka.com>2022-06-25 10:57:56 +0200
commit8f00bc9d231c0c686b2ffa3bd0b14181afa7a171 (patch)
tree9aac8869b99ae2927dad90be5ec2a75b1cd20bad /test
parentdfdb807543a03eec27341deec6a5f3b88f87fac3 (diff)
downloadzig-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.zig6
-rw-r--r--test/link/macho/search_paths_first/a.c7
-rw-r--r--test/link/macho/search_paths_first/build.zig41
-rw-r--r--test/link/macho/search_paths_first/main.c9
-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