2024-11-22 15:40:10 +01:00
|
|
|
const std = @import("std");
|
|
|
|
const pg = @import("pg");
|
|
|
|
const zrm = @import("zrm");
|
|
|
|
const repository = @import("repository.zig");
|
|
|
|
|
|
|
|
/// PostgreSQL database connection.
|
|
|
|
var database: *pg.Pool = undefined;
|
|
|
|
|
|
|
|
/// Initialize database connection.
|
|
|
|
fn initDatabase(allocator: std.mem.Allocator) !void {
|
|
|
|
database = try pg.Pool.init(allocator, .{
|
|
|
|
.connect = .{
|
|
|
|
.host = "localhost",
|
|
|
|
.port = 5432,
|
|
|
|
},
|
|
|
|
.auth = .{
|
|
|
|
.username = "zrm",
|
|
|
|
.password = "zrm",
|
|
|
|
.database = "zrm",
|
|
|
|
},
|
2024-11-25 13:02:59 +01:00
|
|
|
.size = 5,
|
2024-11-22 15:40:10 +01:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
test "belongsTo" {
|
|
|
|
zrm.setDebug(true);
|
|
|
|
|
|
|
|
try initDatabase(std.testing.allocator);
|
|
|
|
defer database.deinit();
|
|
|
|
var poolConnector = zrm.database.PoolConnector{
|
|
|
|
.pool = database,
|
|
|
|
};
|
|
|
|
|
|
|
|
// Build a query of submodels.
|
2024-11-22 22:36:51 +01:00
|
|
|
var myQuery = repository.MySubmodelRepository.QueryWith(
|
|
|
|
// Retrieve parents of submodels from relation.
|
2024-11-25 18:41:29 +01:00
|
|
|
&[_]zrm.relations.Relation{repository.MySubmodelRelations.parent}
|
2024-11-22 22:36:51 +01:00
|
|
|
).init(std.testing.allocator, poolConnector.connector(), .{});
|
2024-11-22 15:40:10 +01:00
|
|
|
defer myQuery.deinit();
|
|
|
|
|
|
|
|
try myQuery.buildSql();
|
|
|
|
|
|
|
|
// Get query result.
|
|
|
|
var result = try myQuery.get(std.testing.allocator);
|
|
|
|
defer result.deinit();
|
|
|
|
|
|
|
|
// Checking result.
|
|
|
|
try std.testing.expectEqual(2, result.models.len);
|
|
|
|
try std.testing.expectEqual(1, result.models[0].parent_id);
|
|
|
|
try std.testing.expectEqual(1, result.models[1].parent_id);
|
|
|
|
try std.testing.expectEqual(repository.MyModel, @TypeOf(result.models[0].parent.?));
|
|
|
|
try std.testing.expectEqual(1, result.models[0].parent.?.id);
|
|
|
|
try std.testing.expectEqual(1, result.models[1].parent.?.id);
|
|
|
|
}
|
2024-11-25 13:02:59 +01:00
|
|
|
|
|
|
|
test "hasMany" {
|
|
|
|
zrm.setDebug(true);
|
|
|
|
|
|
|
|
try initDatabase(std.testing.allocator);
|
|
|
|
defer database.deinit();
|
|
|
|
var poolConnector = zrm.database.PoolConnector{
|
|
|
|
.pool = database,
|
|
|
|
};
|
|
|
|
|
|
|
|
// Build a query of submodels.
|
|
|
|
var myQuery = repository.MyModelRepository.QueryWith(
|
2024-11-25 18:41:29 +01:00
|
|
|
// Retrieve parents of submodels from relation.
|
|
|
|
&[_]zrm.relations.Relation{repository.MyModelRelations.submodels}
|
2024-11-25 13:02:59 +01:00
|
|
|
).init(std.testing.allocator, poolConnector.connector(), .{});
|
|
|
|
defer myQuery.deinit();
|
|
|
|
|
|
|
|
try myQuery.buildSql();
|
|
|
|
|
|
|
|
// Get query result.
|
|
|
|
var result = try myQuery.get(std.testing.allocator);
|
|
|
|
defer result.deinit();
|
|
|
|
|
|
|
|
// Checking result.
|
|
|
|
try std.testing.expectEqual(4, result.models.len);
|
|
|
|
try std.testing.expectEqual(repository.MySubmodel, @TypeOf(result.models[0].submodels.?[0]));
|
|
|
|
|
|
|
|
// Checking retrieved submodels.
|
|
|
|
for (result.models) |model| {
|
|
|
|
try std.testing.expect(model.submodels != null);
|
|
|
|
|
|
|
|
if (model.submodels.?.len > 0) {
|
|
|
|
try std.testing.expectEqual(1, model.id);
|
|
|
|
try std.testing.expectEqual(2, model.submodels.?.len);
|
|
|
|
for (model.submodels.?) |submodel| {
|
|
|
|
try std.testing.expectEqual(1, submodel.parent_id.?);
|
|
|
|
try std.testing.expect(
|
|
|
|
std.mem.eql(u8, &try pg.uuidToHex(submodel.uuid), "f6868a5b-2efc-455f-b76e-872df514404f")
|
|
|
|
or std.mem.eql(u8, &try pg.uuidToHex(submodel.uuid), "013ef171-9781-40e9-b843-f6bc11890070")
|
|
|
|
);
|
|
|
|
try std.testing.expect(
|
|
|
|
std.mem.eql(u8, submodel.label, "test") or std.mem.eql(u8, submodel.label, "another")
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|