mirror of
https://codeberg.org/andyscott/exercism.git
synced 2024-12-22 14:43:10 -05:00
110 lines
3.3 KiB
Zig
110 lines
3.3 KiB
Zig
|
const std = @import("std");
|
||
|
const testing = std.testing;
|
||
|
|
||
|
const triangle = @import("triangle.zig");
|
||
|
|
||
|
test "equilateral all sides are equal" {
|
||
|
const actual = try triangle.Triangle.init(2, 2, 2);
|
||
|
try testing.expect(actual.isEquilateral());
|
||
|
}
|
||
|
|
||
|
test "equilateral any side is unequal" {
|
||
|
const actual = try triangle.Triangle.init(2, 3, 2);
|
||
|
try testing.expect(!actual.isEquilateral());
|
||
|
}
|
||
|
|
||
|
test "equilateral no sides are equal" {
|
||
|
const actual = try triangle.Triangle.init(5, 4, 6);
|
||
|
try testing.expect(!actual.isEquilateral());
|
||
|
}
|
||
|
|
||
|
test "equilateral all zero sides is not a triangle" {
|
||
|
const actual = triangle.Triangle.init(0, 0, 0);
|
||
|
try testing.expectError(triangle.TriangleError.Invalid, actual);
|
||
|
}
|
||
|
|
||
|
test "equilateral sides may be floats" {
|
||
|
const actual = try triangle.Triangle.init(0.5, 0.5, 0.5);
|
||
|
try testing.expect(actual.isEquilateral());
|
||
|
}
|
||
|
|
||
|
test "isosceles last two sides are equal" {
|
||
|
const actual = try triangle.Triangle.init(3, 4, 4);
|
||
|
try testing.expect(actual.isIsosceles());
|
||
|
}
|
||
|
|
||
|
test "isosceles first two sides are equal" {
|
||
|
const actual = try triangle.Triangle.init(4, 4, 3);
|
||
|
try testing.expect(actual.isIsosceles());
|
||
|
}
|
||
|
|
||
|
test "isosceles first and last sides are equal" {
|
||
|
const actual = try triangle.Triangle.init(4, 3, 4);
|
||
|
try testing.expect(actual.isIsosceles());
|
||
|
}
|
||
|
|
||
|
test "equilateral triangles are also isosceles" {
|
||
|
const actual = try triangle.Triangle.init(4, 3, 4);
|
||
|
try testing.expect(actual.isIsosceles());
|
||
|
}
|
||
|
|
||
|
test "isosceles no sides are equal" {
|
||
|
const actual = try triangle.Triangle.init(2, 3, 4);
|
||
|
try testing.expect(!actual.isIsosceles());
|
||
|
}
|
||
|
|
||
|
test "isosceles first triangle inequality violation" {
|
||
|
const actual = triangle.Triangle.init(1, 1, 3);
|
||
|
try testing.expectError(triangle.TriangleError.Invalid, actual);
|
||
|
}
|
||
|
|
||
|
test "isosceles second triangle inequality violation" {
|
||
|
const actual = triangle.Triangle.init(1, 3, 1);
|
||
|
try testing.expectError(triangle.TriangleError.Invalid, actual);
|
||
|
}
|
||
|
|
||
|
test "isosceles third triangle inequality violation" {
|
||
|
const actual = triangle.Triangle.init(3, 1, 1);
|
||
|
try testing.expectError(triangle.TriangleError.Invalid, actual);
|
||
|
}
|
||
|
|
||
|
test "isosceles sides may be floats" {
|
||
|
const actual = try triangle.Triangle.init(0.5, 0.4, 0.5);
|
||
|
try testing.expect(actual.isIsosceles());
|
||
|
}
|
||
|
|
||
|
test "scalene no sides are equal" {
|
||
|
const actual = try triangle.Triangle.init(5, 4, 6);
|
||
|
try testing.expect(actual.isScalene());
|
||
|
}
|
||
|
|
||
|
test "scalene all sides are equal" {
|
||
|
const actual = try triangle.Triangle.init(4, 4, 4);
|
||
|
try testing.expect(!actual.isScalene());
|
||
|
}
|
||
|
|
||
|
test "scalene first and second sides are equal" {
|
||
|
const actual = try triangle.Triangle.init(4, 4, 3);
|
||
|
try testing.expect(!actual.isScalene());
|
||
|
}
|
||
|
|
||
|
test "scalene first and third sides are equal" {
|
||
|
const actual = try triangle.Triangle.init(3, 4, 3);
|
||
|
try testing.expect(!actual.isScalene());
|
||
|
}
|
||
|
|
||
|
test "scalene second and third sides are equal" {
|
||
|
const actual = try triangle.Triangle.init(4, 3, 3);
|
||
|
try testing.expect(!actual.isScalene());
|
||
|
}
|
||
|
|
||
|
test "scalene may not violate triangle inequality" {
|
||
|
const actual = triangle.Triangle.init(7, 3, 2);
|
||
|
try testing.expectError(triangle.TriangleError.Invalid, actual);
|
||
|
}
|
||
|
|
||
|
test "scalene sides may be floats" {
|
||
|
const actual = try triangle.Triangle.init(0.5, 0.4, 0.6);
|
||
|
try testing.expect(actual.isScalene());
|
||
|
}
|