Source code for base.radar_altimeter_testing

#! /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

[docs]class RadarAltimeterTest(MorseTestCase):
[docs] 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
[docs] 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)