1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
|
#! /usr/bin/env python
"""
This script tests the 'data stream' oriented feature of the socket interface.
"""
from morse.testing.testing import MorseTestCase
try:
# Include this import to be able to use your test file as a regular
# builder script, ie, usable with: 'morse [run|exec] <your test>.py
from morse.builder import *
except ImportError:
pass
import math
from pymorse import Morse
class RadarAltimeterTest(MorseTestCase):
def setUpEnv(self):
robot = RMax('robot')
robot.translate(0.0, 0.0, 20.0)
teleport = Teleport()
teleport.add_stream('socket')
robot.append(teleport)
altimeter = RadarAltimeter()
robot.append(altimeter)
altimeter.add_stream('socket')
altimeter.properties(MaxRange = 25.0)
env = Environment('indoors-1/boxes', fastmode = True)
env.add_service('socket')
ground = bpymorse.get_object('Ground')
ground.game.use_actor = True
def test_teleport(self):
""" Test if we can connect to the pose data stream, and read from it.
"""
with Morse() as morse:
teleport_stream = morse.robot.teleport
altimeter_stream = morse.robot.altimeter
precision = 0.01
altitude = altimeter_stream.get()
self.assertAlmostEquals(altitude['z'], 20.0, delta = precision)
teleport_stream.publish({'x': 0.0, 'y': 0.0, 'z': 15.0,
'yaw': 0.0, 'pitch': 0.0, 'roll': 0.0})
morse.sleep(0.1)
altitude = altimeter_stream.get()
self.assertAlmostEquals(altitude['z'], 15.0, delta = precision)
teleport_stream.publish({'x': 0.0, 'y': 0.0, 'z': 30.0,
'yaw': 0.0, 'pitch': 0.0, 'roll': 0.0})
morse.sleep(0.1)
altitude = altimeter_stream.get()
self.assertEqual(altitude['z'], float('inf'))
teleport_stream.publish({'x': 0.0, 'y': 0.0, 'z': 12.0,
'yaw': 0.0, 'pitch': math.pi/2, 'roll': math.pi/2})
morse.sleep(0.1)
altitude = altimeter_stream.get()
self.assertAlmostEquals(altitude['z'], 12.0, delta = precision)
# Goes on top on the red box, size ~1.8m
teleport_stream.publish({'x': -7.5, 'y': 0.0, 'z': 15.0,
'yaw': 0.0, 'pitch': 0.0, 'roll': 0.0})
morse.sleep(0.1)
altitude = altimeter_stream.get()
self.assertAlmostEquals(altitude['z'], 13.14, delta = precision)
########################## Run these tests ##########################
if __name__ == "__main__":
from morse.testing.testing import main
main(RadarAltimeterTest)
|