2017-09-17 00:57:12 +02:00
|
|
|
# system modules
|
2013-04-14 18:39:47 -04:00
|
|
|
import sys
|
2013-04-16 22:29:06 -04:00
|
|
|
import unittest
|
|
|
|
from tests import BaseTest
|
2017-05-14 12:35:20 +02:00
|
|
|
from OCC.gp import gp_Vec, gp_Pnt, gp_Ax2, gp_Circ, gp_DZ
|
|
|
|
from OCC.BRepBuilderAPI import (BRepBuilderAPI_MakeVertex,
|
|
|
|
BRepBuilderAPI_MakeEdge,
|
|
|
|
BRepBuilderAPI_MakeFace)
|
2017-09-17 00:57:12 +02:00
|
|
|
|
2017-05-14 12:35:20 +02:00
|
|
|
from OCC.GC import GC_MakeCircle
|
2013-04-27 23:49:41 -07:00
|
|
|
|
2013-04-16 22:29:06 -04:00
|
|
|
from cadquery import *
|
2013-04-27 23:49:41 -07:00
|
|
|
|
2017-09-17 00:57:12 +02:00
|
|
|
|
2013-04-14 18:39:47 -04:00
|
|
|
class TestCadObjects(BaseTest):
|
2017-09-17 00:57:12 +02:00
|
|
|
|
2017-05-14 12:35:20 +02:00
|
|
|
def _make_circle(self):
|
2017-09-17 00:57:12 +02:00
|
|
|
|
|
|
|
circle = gp_Circ(gp_Ax2(gp_Pnt(1, 2, 3), gp_DZ()),
|
2017-05-14 12:35:20 +02:00
|
|
|
2.)
|
|
|
|
return Shape.cast(BRepBuilderAPI_MakeEdge(circle).Edge())
|
2013-04-14 18:39:47 -04:00
|
|
|
|
|
|
|
def testVectorConstructors(self):
|
2014-12-08 21:19:27 -05:00
|
|
|
v1 = Vector(1, 2, 3)
|
|
|
|
v2 = Vector((1, 2, 3))
|
2017-05-14 12:35:20 +02:00
|
|
|
v3 = Vector(gp_Vec(1, 2, 3))
|
2013-04-14 18:39:47 -04:00
|
|
|
|
2014-12-08 21:19:27 -05:00
|
|
|
for v in [v1, v2, v3]:
|
|
|
|
self.assertTupleAlmostEquals((1, 2, 3), v.toTuple(), 4)
|
2013-04-14 18:39:47 -04:00
|
|
|
|
|
|
|
def testVertex(self):
|
|
|
|
"""
|
|
|
|
Tests basic vertex functions
|
|
|
|
"""
|
2017-05-14 12:35:20 +02:00
|
|
|
v = Vertex.makeVertex(1, 1, 1)
|
2014-12-08 21:19:27 -05:00
|
|
|
self.assertEqual(1, v.X)
|
2017-09-17 00:57:12 +02:00
|
|
|
self.assertEqual(Vector, type(v.Center()))
|
2013-04-14 18:39:47 -04:00
|
|
|
|
|
|
|
def testBasicBoundingBox(self):
|
2017-05-14 12:35:20 +02:00
|
|
|
v = Vertex.makeVertex(1, 1, 1)
|
|
|
|
v2 = Vertex.makeVertex(2, 2, 2)
|
2017-09-17 00:57:12 +02:00
|
|
|
self.assertEqual(BoundBox, type(v.BoundingBox()))
|
|
|
|
self.assertEqual(BoundBox, type(v2.BoundingBox()))
|
2013-04-14 18:39:47 -04:00
|
|
|
|
|
|
|
bb1 = v.BoundingBox().add(v2.BoundingBox())
|
|
|
|
|
2017-09-17 00:57:12 +02:00
|
|
|
# OCC uses some approximations
|
|
|
|
self.assertAlmostEqual(bb1.xlen, 1.0, 1)
|
2013-04-14 18:39:47 -04:00
|
|
|
|
|
|
|
def testEdgeWrapperCenter(self):
|
2017-05-14 12:35:20 +02:00
|
|
|
e = self._make_circle()
|
2017-09-17 00:57:12 +02:00
|
|
|
|
2014-12-08 21:19:27 -05:00
|
|
|
self.assertTupleAlmostEquals((1.0, 2.0, 3.0), e.Center().toTuple(), 3)
|
2013-04-14 18:39:47 -04:00
|
|
|
|
2016-11-28 23:04:30 +08:00
|
|
|
def testEdgeWrapperMakeCircle(self):
|
2017-09-17 00:57:12 +02:00
|
|
|
halfCircleEdge = Edge.makeCircle(radius=10, pnt=(
|
|
|
|
0, 0, 0), dir=(0, 0, 1), angle1=0, angle2=180)
|
2016-11-28 23:04:30 +08:00
|
|
|
|
2017-05-14 12:35:20 +02:00
|
|
|
#self.assertTupleAlmostEquals((0.0, 5.0, 0.0), halfCircleEdge.CenterOfBoundBox(0.0001).toTuple(),3)
|
2017-09-17 00:57:12 +02:00
|
|
|
self.assertTupleAlmostEquals(
|
|
|
|
(10.0, 0.0, 0.0), halfCircleEdge.startPoint().toTuple(), 3)
|
|
|
|
self.assertTupleAlmostEquals(
|
|
|
|
(-10.0, 0.0, 0.0), halfCircleEdge.endPoint().toTuple(), 3)
|
2016-11-28 23:04:30 +08:00
|
|
|
|
|
|
|
def testFaceWrapperMakePlane(self):
|
2017-09-17 00:57:12 +02:00
|
|
|
mplane = Face.makePlane(10, 10)
|
2016-11-28 23:04:30 +08:00
|
|
|
|
2017-09-17 00:57:12 +02:00
|
|
|
self.assertTupleAlmostEquals(
|
|
|
|
(0.0, 0.0, 1.0), mplane.normalAt().toTuple(), 3)
|
2016-11-28 23:04:30 +08:00
|
|
|
|
|
|
|
def testCenterOfBoundBox(self):
|
|
|
|
pass
|
|
|
|
|
|
|
|
def testCombinedCenterOfBoundBox(self):
|
|
|
|
pass
|
|
|
|
|
2015-09-17 19:13:05 -04:00
|
|
|
def testCompoundCenter(self):
|
|
|
|
"""
|
|
|
|
Tests whether or not a proper weighted center can be found for a compound
|
|
|
|
"""
|
2017-09-17 00:57:12 +02:00
|
|
|
|
2015-09-17 19:13:05 -04:00
|
|
|
def cylinders(self, radius, height):
|
|
|
|
def _cyl(pnt):
|
|
|
|
# Inner function to build a cylinder
|
|
|
|
return Solid.makeCylinder(radius, height, pnt)
|
|
|
|
|
|
|
|
# Combine all the cylinders into a single compound
|
|
|
|
r = self.eachpoint(_cyl, True).combineSolids()
|
|
|
|
|
|
|
|
return r
|
|
|
|
|
|
|
|
Workplane.cyl = cylinders
|
|
|
|
|
|
|
|
# Now test. here we want weird workplane to see if the objects are transformed right
|
2017-09-17 00:57:12 +02:00
|
|
|
s = Workplane("XY").rect(
|
|
|
|
2.0, 3.0, forConstruction=True).vertices().cyl(0.25, 0.5)
|
2015-09-17 19:13:05 -04:00
|
|
|
|
2017-09-17 00:57:12 +02:00
|
|
|
self.assertEqual(4, len(s.val().Solids()))
|
|
|
|
self.assertTupleAlmostEquals(
|
|
|
|
(0.0, 0.0, 0.25), s.val().Center().toTuple(), 3)
|
2015-09-17 19:13:05 -04:00
|
|
|
|
2013-04-14 18:39:47 -04:00
|
|
|
def testDot(self):
|
2014-12-08 21:19:27 -05:00
|
|
|
v1 = Vector(2, 2, 2)
|
|
|
|
v2 = Vector(1, -1, 1)
|
2017-09-17 00:57:12 +02:00
|
|
|
self.assertEqual(2.0, v1.dot(v2))
|
2013-04-14 18:39:47 -04:00
|
|
|
|
|
|
|
def testVectorAdd(self):
|
2014-12-08 21:19:27 -05:00
|
|
|
result = Vector(1, 2, 0) + Vector(0, 0, 3)
|
|
|
|
self.assertTupleAlmostEquals((1.0, 2.0, 3.0), result.toTuple(), 3)
|
2013-04-14 18:39:47 -04:00
|
|
|
|
2018-11-18 21:33:17 -08:00
|
|
|
def testVectorOperators(self):
|
|
|
|
result = Vector(1, 1, 1) + Vector(2, 2, 2)
|
|
|
|
self.assertEqual(Vector(3, 3, 3), result)
|
|
|
|
|
|
|
|
result = Vector(1, 2, 3) - Vector(3, 2, 1)
|
|
|
|
self.assertEqual(Vector(-2, 0, 2), result)
|
|
|
|
|
|
|
|
result = Vector(1, 2, 3) * 2
|
|
|
|
self.assertEqual(Vector(2, 4, 6), result)
|
|
|
|
|
|
|
|
result = Vector(2, 4, 6) / 2
|
|
|
|
self.assertEqual(Vector(1, 2, 3), result)
|
|
|
|
|
2018-11-21 18:32:30 -08:00
|
|
|
self.assertEqual(Vector(-1, -1, -1), -Vector(1, 1, 1))
|
|
|
|
|
|
|
|
self.assertEqual(0, abs(Vector(0, 0, 0)))
|
|
|
|
self.assertEqual(1, abs(Vector(1, 0, 0)))
|
|
|
|
self.assertEqual((1+4+9)**0.5, abs(Vector(1, 2, 3)))
|
|
|
|
|
2018-11-18 13:02:21 -08:00
|
|
|
def testVectorEquals(self):
|
|
|
|
a = Vector(1, 2, 3)
|
|
|
|
b = Vector(1, 2, 3)
|
|
|
|
c = Vector(1, 2, 3.000001)
|
|
|
|
self.assertEqual(a, b)
|
|
|
|
self.assertEqual(a, c)
|
|
|
|
|
2018-11-28 22:06:08 -08:00
|
|
|
def testMatrixCreationAndAccess(self):
|
|
|
|
def matrix_vals(m):
|
2018-12-12 00:21:56 -08:00
|
|
|
return [[m[r,c] for c in range(4)] for r in range(4)]
|
2018-11-28 22:06:08 -08:00
|
|
|
# default constructor creates a 4x4 identity matrix
|
|
|
|
m = Matrix()
|
2018-12-12 00:21:56 -08:00
|
|
|
identity = [[1., 0., 0., 0.],
|
|
|
|
[0., 1., 0., 0.],
|
|
|
|
[0., 0., 1., 0.],
|
|
|
|
[0., 0., 0., 1.]]
|
2018-11-28 22:06:08 -08:00
|
|
|
self.assertEqual(identity, matrix_vals(m))
|
|
|
|
|
2018-12-12 00:21:56 -08:00
|
|
|
vals4x4 = [[1., 0., 0., 1.],
|
|
|
|
[0., 1., 0., 2.],
|
|
|
|
[0., 0., 1., 3.],
|
|
|
|
[0., 0., 0., 1.]]
|
2018-11-28 22:06:08 -08:00
|
|
|
|
|
|
|
# test constructor with 16-value input
|
|
|
|
m = Matrix(vals4x4)
|
|
|
|
self.assertEqual(vals4x4, matrix_vals(m))
|
|
|
|
|
|
|
|
# test constructor with 12-value input (the last 4 are an implied
|
|
|
|
# [0,0,0,1])
|
|
|
|
m = Matrix(vals4x4[0:12])
|
|
|
|
self.assertEqual(vals4x4, matrix_vals(m))
|
|
|
|
|
|
|
|
# Test 16-value input with invalid values for the last 4
|
2018-12-12 00:21:56 -08:00
|
|
|
invalid = [[1., 0., 0., 1.],
|
|
|
|
[0., 1., 0., 2.],
|
|
|
|
[0., 0., 1., 3.],
|
|
|
|
[1., 2., 3., 4.]]
|
2018-11-28 22:06:08 -08:00
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
Matrix(invalid)
|
|
|
|
|
|
|
|
# Test input with invalid size
|
|
|
|
with self.assertRaises(TypeError):
|
|
|
|
Matrix([1,2,3])
|
|
|
|
|
|
|
|
# test out-of-bounds access
|
|
|
|
m = Matrix()
|
|
|
|
with self.assertRaises(IndexError):
|
|
|
|
m[5, 5]
|
|
|
|
|
|
|
|
|
2017-09-17 00:57:12 +02:00
|
|
|
def testTranslate(self):
|
|
|
|
e = Edge.makeCircle(2, (1, 2, 3))
|
2014-12-08 21:19:27 -05:00
|
|
|
e2 = e.translate(Vector(0, 0, 1))
|
2013-04-14 18:39:47 -04:00
|
|
|
|
2014-12-08 21:19:27 -05:00
|
|
|
self.assertTupleAlmostEquals((1.0, 2.0, 4.0), e2.Center().toTuple(), 3)
|
2013-04-14 18:39:47 -04:00
|
|
|
|
|
|
|
def testVertices(self):
|
2017-05-14 12:35:20 +02:00
|
|
|
e = Shape.cast(BRepBuilderAPI_MakeEdge(gp_Pnt(0, 0, 0),
|
|
|
|
gp_Pnt(1, 1, 0)).Edge())
|
2017-09-17 00:57:12 +02:00
|
|
|
self.assertEqual(2, len(e.Vertices()))
|
|
|
|
|
2013-04-27 23:49:41 -07:00
|
|
|
|
2013-04-16 22:29:06 -04:00
|
|
|
if __name__ == '__main__':
|
2013-04-27 23:49:41 -07:00
|
|
|
unittest.main()
|