test_scripts.py 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. import gymnasium as gym
  2. import numpy as np
  3. from pytest_mock import MockerFixture
  4. from minigrid.benchmark import benchmark
  5. from minigrid.manual_control import ManualControl
  6. from minigrid.minigrid_env import MiniGridEnv
  7. from minigrid.utils.window import Window
  8. def test_benchmark():
  9. "Test that the benchmark function works for a specific environment"
  10. env_id = "MiniGrid-Empty-16x16-v0"
  11. benchmark(env_id, num_resets=10, num_frames=100)
  12. def test_window():
  13. "Testing the class functions of window.Window. This should locally open a window !"
  14. title = "testing window"
  15. window = Window(title)
  16. img = np.random.rand(100, 100, 3)
  17. window.show_img(img)
  18. caption = "testing caption"
  19. window.set_caption(caption)
  20. window.show(block=False)
  21. window.close()
  22. def test_manual_control(mocker: MockerFixture):
  23. class FakeRandomKeyboardEvent:
  24. active_actions = ["left", "right", "up", " ", "pageup", "pagedown"]
  25. reset_action = "backspace"
  26. close_action = "escape"
  27. def __init__(self, reset: bool = False, close: bool = False) -> None:
  28. if reset:
  29. self.key = self.reset_action
  30. return
  31. if close:
  32. self.key = self.close_action
  33. return
  34. self.key = np.random.choice(self.active_actions)
  35. env_id = "MiniGrid-Empty-16x16-v0"
  36. env: MiniGridEnv = gym.make(env_id)
  37. window = mocker.MagicMock()
  38. window.close = mocker.MagicMock()
  39. window.set_caption = mocker.MagicMock()
  40. manual_control = ManualControl(env, window=window)
  41. for i in range(3): # 3 resets
  42. mission = f"Mission {i}"
  43. env.mission = mission
  44. manual_control.reset()
  45. window.set_caption.assert_called_with(mission)
  46. for j in range(20): # Do 20 steps
  47. manual_control.key_handler(FakeRandomKeyboardEvent())
  48. fake_event = FakeRandomKeyboardEvent(reset=True)
  49. manual_control.key_handler(fake_event)
  50. window.close.assert_not_called()
  51. # Close the environment
  52. fake_event = FakeRandomKeyboardEvent(close=True)
  53. manual_control.key_handler(fake_event)
  54. window.close.assert_called()