1
0
mirror of https://github.com/JustinSDK/dotSCAD.git synced 2025-01-17 22:28:16 +01:00
dotSCAD/test/test_polyline3d.scad
2019-06-11 14:32:21 +08:00

184 lines
5.1 KiB
OpenSCAD

include <unittest.scad>;
include <line3d.scad>;
module test_polyline3d() {
$fn = 24;
points = [
[1, 2, 1],
[-5, -4, 2],
[-5, 3, 3],
[5, 5, 4]
];
line_thickness = 1;
leng_points = len(points);
module assertCorrectSegment(expected, actual, thickness) {
assertEqualPoint(expected[0], actual[0]);
assertEqualPoint(expected[1], actual[1]);
assertEqualNum(line_thickness, thickness);
}
module assertCorrectCaps(leng_pts, startStyle, endStyle, index, p1Style, p2Style) {
function correctMiddleCaps(p1Style, p2Style) =
p1Style == "CAP_SPHERE" && p2Style == "CAP_BUTT";
if(index == 1 && (p1Style != startStyle || p2Style != "CAP_BUTT")) {
fail(
"Wrong start caps",
str(
"expected: [", startStyle, ", \"CAP_BUTT\"]",
", but: ", [p1Style, p2Style]
)
);
}
if((1 < index && index < leng_pts - 1) && !correctMiddleCaps(p1Style, p2Style)) {
fail(
"Wrong middle caps",
str(
"expected: [\"CAP_SPHERE\", \"CAP_BUTT\"]",
", but: ", [p1Style, p2Style]
)
);
}
if(index == leng_pts - 1 && (p1Style != "CAP_SPHERE" || p2Style != endStyle)) {
fail(
"Wrong end caps",
str(
"expected: [\"CAP_SPHERE\, ", endStyle, "]",
", but: ", [p1Style, p2Style]
)
);
}
}
// testcases
module test_polyline3d_cap_default() {
echo("==== test_polyline3d_cap_default ====");
include <polyline3d.scad>;
module test_line3d_segment(index, point1, point2, thickness, p1Style, p2Style) {
assertCorrectSegment(
[points[index - 1], points[index]],
[point1, point2],
thickness
);
assertCorrectCaps(
leng_points,
"CAP_CIRCLE", "CAP_CIRCLE",
index, p1Style, p2Style
);
}
polyline3d(
points = points,
thickness = line_thickness,
$fn = 24
);
}
module test_polyline3d_end_cap_sphere() {
echo("==== test_polyline3d_end_cap_sphere ====");
include <polyline3d.scad>;
module test_line3d_segment(index, point1, point2, thickness, p1Style, p2Style) {
assertCorrectSegment(
[points[index - 1], points[index]],
[point1, point2],
thickness
);
assertCorrectCaps(
leng_points,
"CAP_CIRCLE", "CAP_SPHERE",
index, p1Style, p2Style
);
}
polyline3d(
points = points,
thickness = line_thickness,
endingStyle = "CAP_SPHERE",
$fn = 24
);
}
module test_polyline3d_cap_spheres() {
echo("==== test_polyline3d_cap_spheres ====");
include <polyline3d.scad>;
module test_line3d_segment(index, point1, point2, thickness, p1Style, p2Style) {
assertCorrectSegment(
[points[index - 1], points[index]],
[point1, point2],
thickness
);
assertCorrectCaps(
leng_points,
"CAP_SPHERE", "CAP_SPHERE",
index, p1Style, p2Style
);
}
polyline3d(
points = points,
thickness = line_thickness,
startingStyle = "CAP_SPHERE",
endingStyle = "CAP_SPHERE",
$fn = 24
);
}
module test_polyline3d_helix() {
echo("==== test_polyline3d_helix ====");
r = 20;
h = 5;
fa = 15;
circles = 10;
points = [
for(a = [0:fa:360 * circles])
[r * cos(a), r * sin(a), h / (360 / fa) * (a / fa)]
];
include <polyline3d.scad>;
module test_line3d_segment(index, point1, point2, thickness, p1Style, p2Style) {
assertCorrectSegment(
[points[index - 1], points[index]],
[point1, point2],
thickness
);
assertCorrectCaps(
len(points),
"CAP_CIRCLE", "CAP_CIRCLE",
index, p1Style, p2Style
);
}
polyline3d(
points = points,
thickness = line_thickness,
$fn = 24
);
}
test_polyline3d_cap_default();
test_polyline3d_end_cap_sphere();
test_polyline3d_cap_spheres();
test_polyline3d_helix();
}
test_polyline3d();