summaryrefslogtreecommitdiff
path: root/city/geometry-test.lua
diff options
context:
space:
mode:
Diffstat (limited to 'city/geometry-test.lua')
-rw-r--r--city/geometry-test.lua37
1 files changed, 37 insertions, 0 deletions
diff --git a/city/geometry-test.lua b/city/geometry-test.lua
index f85bec0..74ddb3a 100644
--- a/city/geometry-test.lua
+++ b/city/geometry-test.lua
@@ -93,3 +93,40 @@ test(
end
end
)
+
+test(
+ 'subdivide a square',
+ function()
+ local center = geom.point(2, 2)
+ local square = geom.square(center, 4)
+
+ local children = square:divide()
+ assert(
+ #children == 4,
+ string.format(
+ 'incorrect number of children: %d',
+ #children
+ )
+ )
+
+ local aa = children[1]
+ assert(aa.center.x == 1)
+ assert(aa.center.y == 1)
+ assert(aa.span == 2)
+
+ local ba = children[2]
+ assert(ba.center.x == 3)
+ assert(ba.center.y == 1)
+ assert(ba.span == 2)
+
+ local ab = children[3]
+ assert(ab.center.x == 1)
+ assert(ab.center.y == 3)
+ assert(ab.span == 2)
+
+ local bb = children[4]
+ assert(bb.center.x == 3)
+ assert(bb.center.y == 3)
+ assert(bb.span == 2)
+ end
+)