|
| 1 | +from droneapi.lib import VehicleMode |
| 2 | +from pymavlink import mavutil |
| 3 | +import time |
| 4 | +import sys |
| 5 | +import os |
| 6 | +from testlib import assert_equals |
| 7 | + |
| 8 | +def test_110(local_connect): |
| 9 | + api = local_connect() |
| 10 | + v = api.get_vehicles()[0] |
| 11 | + |
| 12 | + # Change the vehicle into STABILIZE mode |
| 13 | + v.mode = VehicleMode("STABILIZE") |
| 14 | + |
| 15 | + # NOTE wait crudely for ACK on mode update |
| 16 | + time.sleep(3) |
| 17 | + |
| 18 | + # Define example callback for mode |
| 19 | + def armed_callback(attribute): |
| 20 | + armed_callback.called += 1 |
| 21 | + armed_callback.called = 0 |
| 22 | + |
| 23 | + # When the same (event, callback) pair is passed to add_attribute_observer, |
| 24 | + # only one instance of the observer callback should be added. |
| 25 | + v.add_attribute_observer('armed', armed_callback) |
| 26 | + v.add_attribute_observer('armed', armed_callback) |
| 27 | + v.add_attribute_observer('armed', armed_callback) |
| 28 | + v.add_attribute_observer('armed', armed_callback) |
| 29 | + v.add_attribute_observer('armed', armed_callback) |
| 30 | + |
| 31 | + # Disarm and see update. |
| 32 | + v.armed = False |
| 33 | + v.flush() |
| 34 | + # Wait for ACK. |
| 35 | + time.sleep(3) |
| 36 | + |
| 37 | + # Ensure the callback was called. |
| 38 | + assert armed_callback.called > 0, "Callback should have been called." |
| 39 | + |
| 40 | + # Rmove all observers. The first call should remove all listeners |
| 41 | + # we've added; the second call should be ignored and not throw. |
| 42 | + # NOTE: We test if armed_callback were treating adding each additional callback |
| 43 | + # and remove_attribute_observer were removing them one at a time; in this |
| 44 | + # case, there would be three callbacks still attached. |
| 45 | + v.remove_attribute_observer('armed', armed_callback) |
| 46 | + v.remove_attribute_observer('armed', armed_callback) |
| 47 | + callcount = armed_callback.called |
| 48 | + |
| 49 | + # Re-arm and see update. |
| 50 | + v.armed = True |
| 51 | + v.flush() |
| 52 | + # Wait for ack |
| 53 | + time.sleep(3) |
| 54 | + |
| 55 | + # Ensure the callback was called zero times. |
| 56 | + assert_equals(armed_callback.called, callcount, "Callback should not have been called once removed.") |
0 commit comments