mirror of
https://github.com/ziglang/zig.git
synced 2025-12-16 03:03:09 +00:00
allow custom test runners to import modules
This commit is contained in:
parent
1f7390f399
commit
edc0e84270
@ -1624,16 +1624,21 @@ pub fn create(gpa: Allocator, options: InitOptions) !*Compilation {
|
|||||||
const test_pkg = if (options.test_runner_path) |test_runner| test_pkg: {
|
const test_pkg = if (options.test_runner_path) |test_runner| test_pkg: {
|
||||||
const test_dir = std.fs.path.dirname(test_runner);
|
const test_dir = std.fs.path.dirname(test_runner);
|
||||||
const basename = std.fs.path.basename(test_runner);
|
const basename = std.fs.path.basename(test_runner);
|
||||||
break :test_pkg try Package.create(gpa, "root", test_dir, basename);
|
const pkg = try Package.create(gpa, "root", test_dir, basename);
|
||||||
}
|
|
||||||
else
|
// copy package table from main_pkg to root_pkg
|
||||||
try Package.createWithDir(
|
var iter = main_pkg.table.valueIterator();
|
||||||
gpa,
|
while (iter.next()) |v| {
|
||||||
"root",
|
try pkg.add(gpa, v.*);
|
||||||
options.zig_lib_directory,
|
}
|
||||||
null,
|
break :test_pkg pkg;
|
||||||
"test_runner.zig",
|
} else try Package.createWithDir(
|
||||||
);
|
gpa,
|
||||||
|
"root",
|
||||||
|
options.zig_lib_directory,
|
||||||
|
null,
|
||||||
|
"test_runner.zig",
|
||||||
|
);
|
||||||
errdefer test_pkg.destroy(gpa);
|
errdefer test_pkg.destroy(gpa);
|
||||||
|
|
||||||
break :root_pkg test_pkg;
|
break :root_pkg test_pkg;
|
||||||
|
|||||||
19
test/standalone/test_runner_module_imports/build.zig
Normal file
19
test/standalone/test_runner_module_imports/build.zig
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
const std = @import("std");
|
||||||
|
|
||||||
|
pub fn build(b: *std.Build) void {
|
||||||
|
const t = b.addTest(.{
|
||||||
|
.root_source_file = .{ .path = "src/main.zig" },
|
||||||
|
});
|
||||||
|
t.setTestRunner("test_runner/main.zig");
|
||||||
|
|
||||||
|
const module1 = b.createModule(.{ .source_file = .{ .path = "module1/main.zig" } });
|
||||||
|
const module2 = b.createModule(.{
|
||||||
|
.source_file = .{ .path = "module2/main.zig" },
|
||||||
|
.dependencies = &.{.{ .name = "module1", .module = module1 }},
|
||||||
|
});
|
||||||
|
|
||||||
|
t.addModule("module2", module2);
|
||||||
|
|
||||||
|
const test_step = b.step("test", "Run unit tests");
|
||||||
|
test_step.dependOn(&t.step);
|
||||||
|
}
|
||||||
@ -0,0 +1 @@
|
|||||||
|
pub const decl: usize = 1234567890;
|
||||||
@ -0,0 +1 @@
|
|||||||
|
pub const mod1 = @import("module1");
|
||||||
6
test/standalone/test_runner_module_imports/src/main.zig
Normal file
6
test/standalone/test_runner_module_imports/src/main.zig
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
const mod2 = @import("module2");
|
||||||
|
const std = @import("std");
|
||||||
|
|
||||||
|
test {
|
||||||
|
try std.testing.expectEqual(@as(usize, 1234567890), mod2.mod1.decl);
|
||||||
|
}
|
||||||
@ -0,0 +1,9 @@
|
|||||||
|
const std = @import("std");
|
||||||
|
const mod2 = @import("module2");
|
||||||
|
|
||||||
|
pub fn main() !void {
|
||||||
|
try std.testing.expectEqual(@as(usize, 1234567890), mod2.mod1.decl);
|
||||||
|
for (@import("builtin").test_functions) |test_fn| {
|
||||||
|
try test_fn.func();
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
x
Reference in New Issue
Block a user