libcruft-util/test/geom/line.cpp

28 lines
692 B
C++
Raw Permalink Normal View History

#include <cruft/util/tap.hpp>
2018-04-20 15:04:54 +10:00
#include <cruft/util/geom/line.hpp>
2018-04-20 15:04:54 +10:00
int
main (int, char**)
{
cruft::TAP::logger tap;
2018-04-20 15:04:54 +10:00
static struct {
cruft::point3f origin;
cruft::vector3f direction;
cruft::point3f q;
2018-04-20 15:04:54 +10:00
float distance;
const char *message;
} TESTS[] = {
{ { 0, 0, 0 }, { 1, 0, 0}, { 0, 0, 0 }, 0, "origin line, origin point" } ,
{ { 0, 1, 0 }, { 1, 0, 0}, { 0, 0, 0 }, 1, "+x line, unit distance" },
};
for (auto const& t: TESTS) {
cruft::geom::line3f l { t.origin, t.direction };
2018-04-20 15:04:54 +10:00
auto d = distance2 (l, t.q);
2021-04-13 16:05:08 +10:00
tap.expect_eq (d, t.distance, "{}", t.message);
2018-04-20 15:04:54 +10:00
}
return tap.status ();
}