Source code for robots.pr2.torso_sockets

#! /usr/bin/env python
"""
This script tests the PR2 torso armature joint
"""

from morse.testing.testing import MorseTestCase
import logging; logger = logging.getLogger("morsetesting.general")

# Include this import to be able to use your test file as a regular 
# builder script, ie, usable with: 'morse [run|exec] base_testing.py
try:
    from morse.builder import *
except ImportError:
    pass

import sys

from pymorse import Morse

[docs]def getjoint(simu, name): joints = simu.pr2.joint_state.get() return joints[name]
[docs]class PR2TorsoTest(MorseTestCase):
[docs] def setUpEnv(self): from morse.builder.robots import BasePR2 pr2 = BasePR2() pr2.add_interface('socket') env = Environment('empty', fastmode=True) env.set_camera_rotation([1.0470, 0, 0.7854])
[docs] def test_torso_translate(self): joint = "torso_lift_joint" with Morse() as simu: self.assertAlmostEquals(getjoint(simu, joint), 0.0, 3) logger.info("Moving up torso to 0.2m...") action = simu.pr2.torso.translate(joint, 0.2, 0.1) # speed = 0.1 m/s simu.sleep(1) logger.info("Should be now at 0.1m...") self.assertAlmostEquals(getjoint(simu, joint), 0.1, 1) simu.sleep(1) logger.info("Should be now at 0.2m...") self.assertAlmostEquals(getjoint(simu, joint), 0.2, 1) # Check we do not move anymore logger.info("Should not move anymore...") simu.sleep(0.5) self.assertFalse(action.running()) self.assertAlmostEquals(getjoint(simu, joint), 0.2, 1) # Test limits #TODO: currently no way to stop the action when blocking on a joint limit since we can not retreive them from Python (blender 2.64) #logger.info("Let's go as high as possible to check my limits...") #action = simu.pr2.torso.translate(joint, [0, 1, 0], 0.2) # speed = 0.2 m/s #simu.sleep(2) #self.assertFalse(action.running()) #self.assertAlmostEquals(getjoint(simu, joint), 0.3, 1) # Go back to initial position logger.info("Let's go back down...") action = simu.pr2.torso.translate(joint, 0, 0.2) # speed = 0.2 m/s simu.sleep(1.6) self.assertFalse(action.running()) self.assertAlmostEquals(getjoint(simu, joint), 0.0, 1) ## Testing set_translation logger.info("Moving up torso to 0.2m...") simu.pr2.torso.set_translation(joint, 0.2) logger.info("Should be now at 0.2m...") simu.sleep(.1) self.assertAlmostEquals(getjoint(simu, joint), 0.2, 3) # Test limits logger.info("Let's go as high as possible to check my limits...") simu.pr2.torso.set_translation(joint, 1) simu.sleep(.1) self.assertAlmostEquals(getjoint(simu, joint), 0.31, 3) simu.pr2.torso.set_translation(joint, -1) simu.sleep(.1) self.assertAlmostEquals(getjoint(simu, joint), 0.0, 3)
########################## Run these tests ########################## if __name__ == "__main__": from morse.testing.testing import main main(PR2TorsoTest)