Files
PyCNC/tests/test_gmachine.py
Nikolay Khabarov a87e2a379b add E axis
2017-05-27 18:47:01 +03:00

177 lines
7.1 KiB
Python

import unittest
import time
from cnc.coordinates import *
from cnc.gcode import *
from cnc.gmachine import *
class TestGMachine(unittest.TestCase):
def setUp(self):
pass
def tearDown(self):
pass
def test_reset(self):
# reset() resets all configurable from gcode things.
m = GMachine()
m.do_command(GCode.parse_line("G20"))
m.do_command(GCode.parse_line("G91"))
m.do_command(GCode.parse_line("X1Y1Z1"))
m.reset()
m.do_command(GCode.parse_line("X3Y4Z5E6"))
self.assertEqual(m.position(), Coordinates(3, 4, 5, 6))
def test_release(self):
# release homes head.
m = GMachine()
m.do_command(GCode.parse_line("X1Y2Z3E4"))
m.release()
self.assertEqual(m.position(), Coordinates(0, 0, 0, 4))
def test_home(self):
m = GMachine()
m.do_command(GCode.parse_line("X1Y2Z3E4"))
m.home()
self.assertEqual(m.position(), Coordinates(0, 0, 0, 4))
def test_none(self):
# GMachine must ignore None commands, since GCode.parse_line()
# returns None if no gcode found in line.
m = GMachine()
m.do_command(None)
self.assertEqual(m.position(), Coordinates(0, 0, 0, 0))
def test_unknown(self):
# Test commands which doesn't exists
m = GMachine()
self.assertRaises(GMachineException,
m.do_command, GCode.parse_line("G99699X1Y2Z3"))
self.assertRaises(GMachineException,
m.do_command, GCode.parse_line("M99699"))
# Test gcode commands.
def test_g0_g1(self):
m = GMachine()
m.do_command(GCode.parse_line("G0X3Y2Z1E-2"))
self.assertEqual(m.position(), Coordinates(3, 2, 1, -2))
m.do_command(GCode.parse_line("G1X1Y2Z3E4"))
self.assertEqual(m.position(), Coordinates(1, 2, 3, 4))
self.assertRaises(GMachineException,
m.do_command, GCode.parse_line("G1F-1"))
self.assertRaises(GMachineException,
m.do_command, GCode.parse_line("G1F999999"))
self.assertRaises(GMachineException,
m.do_command, GCode.parse_line("G1X-1Y0Z0"))
self.assertRaises(GMachineException,
m.do_command, GCode.parse_line("G1X0Y-1Z0"))
self.assertRaises(GMachineException,
m.do_command, GCode.parse_line("G1X0Y0Z-1"))
def test_g2_g3(self):
m = GMachine()
self.assertRaises(GMachineException,
m.do_command, GCode.parse_line("G3I1J1F-1"))
m.do_command(GCode.parse_line("G19"))
self.assertRaises(GMachineException,
m.do_command, GCode.parse_line("G3I1J0K0"))
m.do_command(GCode.parse_line("G18"))
self.assertRaises(GMachineException,
m.do_command, GCode.parse_line("G3I0J1K0"))
m.do_command(GCode.parse_line("G17"))
self.assertRaises(GMachineException,
m.do_command, GCode.parse_line("G3I0J0K1"))
self.assertRaises(GMachineException,
m.do_command, GCode.parse_line("G2X99999999Y99999999I1J1"))
self.assertRaises(GMachineException,
m.do_command, GCode.parse_line("G2X2Y2Z99999999I1J1"))
self.assertEqual(m.position(), Coordinates(0, 0, 0, 0))
self.assertRaises(GMachineException,
m.do_command, GCode.parse_line("G2X4Y4I2J2"))
self.assertRaises(GMachineException,
m.do_command, GCode.parse_line("G3X4Y4I2J2"))
m.do_command(GCode.parse_line("G1X1"))
m.do_command(GCode.parse_line("G2J1"))
m.do_command(GCode.parse_line("G3J1"))
self.assertEqual(m.position(), Coordinates(1, 0, 0, 0))
m.do_command(GCode.parse_line("G1X5Y5"))
m.do_command(GCode.parse_line("G2X0Y0Z5I-2J-2"))
self.assertEqual(m.position(), Coordinates(0, 0, 5, 0))
def test_g4(self):
m = GMachine()
st = time.time()
m.do_command(GCode.parse_line("G4P0.5"))
self.assertLess(0.5, time.time() - st)
self.assertRaises(GMachineException,
m.do_command, GCode.parse_line("G4P-0.5"))
def test_g17_g18_g19(self):
m = GMachine()
m.do_command(GCode.parse_line("G19"))
self.assertEqual(m.plane(), PLANE_YZ)
m.do_command(GCode.parse_line("G18"))
self.assertEqual(m.plane(), PLANE_ZX)
m.do_command(GCode.parse_line("G17"))
self.assertEqual(m.plane(), PLANE_XY)
def test_g20_g21(self):
m = GMachine()
m.do_command(GCode.parse_line("G20"))
m.do_command(GCode.parse_line("X3Y2Z1E0.5"))
self.assertEqual(m.position(), Coordinates(76.2, 50.8, 25.4, 12.7))
m.do_command(GCode.parse_line("G21"))
m.do_command(GCode.parse_line("X3Y2Z1E0.5"))
self.assertEqual(m.position(), Coordinates(3, 2, 1, 0.5))
def test_g90_g91(self):
m = GMachine()
m.do_command(GCode.parse_line("G91"))
m.do_command(GCode.parse_line("X1Y1Z1E1"))
m.do_command(GCode.parse_line("X1Y1Z1"))
m.do_command(GCode.parse_line("X1Y1"))
m.do_command(GCode.parse_line("X1"))
self.assertEqual(m.position(), Coordinates(4, 3, 2, 1))
m.do_command(GCode.parse_line("X-1Y-1Z-1E-1"))
m.do_command(GCode.parse_line("G90"))
m.do_command(GCode.parse_line("X1Y1Z1E1"))
self.assertEqual(m.position(), Coordinates(1, 1, 1, 1))
def test_g90_g92(self):
m = GMachine()
m.do_command(GCode.parse_line("G92X100Y100Z100E100"))
m.do_command(GCode.parse_line("X101Y102Z103E104"))
self.assertEqual(m.position(), Coordinates(1, 2, 3, 4))
m.do_command(GCode.parse_line("G92X-1Y-1Z-1E-1"))
m.do_command(GCode.parse_line("X1Y1Z1E1"))
self.assertEqual(m.position(), Coordinates(3, 4, 5, 6))
m.do_command(GCode.parse_line("G92X3Y4Z5E6"))
m.do_command(GCode.parse_line("X0Y0Z0E0"))
self.assertEqual(m.position(), Coordinates(0, 0, 0, 0))
m.do_command(GCode.parse_line("G90"))
m.do_command(GCode.parse_line("X6Y7Z8E9"))
self.assertEqual(m.position(), Coordinates(6, 7, 8, 9))
def test_g53_g91_g92(self):
m = GMachine()
m.do_command(GCode.parse_line("G92X-50Y-60Z-70E-80"))
m.do_command(GCode.parse_line("X-45Y-55Z-65E-75"))
self.assertEqual(m.position(), Coordinates(5, 5, 5, 5))
m.do_command(GCode.parse_line("G91"))
m.do_command(GCode.parse_line("X-1Y-2Z-3E-4"))
self.assertEqual(m.position(), Coordinates(4, 3, 2, 1))
def test_m3_m5(self):
m = GMachine()
m.do_command(GCode.parse_line("M3S" + str(SPINDLE_MAX_RPM)))
self.assertRaises(GMachineException,
m.do_command, GCode.parse_line("M3S-10"))
self.assertRaises(GMachineException,
m.do_command, GCode.parse_line("M3S999999999"))
m.do_command(GCode.parse_line("M5"))
if __name__ == '__main__':
unittest.main()