# © Crown-owned copyright 2024, Defence Science and Technology Laboratory UK """Test that we can create a primaite environment and train sb3 agent with no crash.""" import tempfile from pathlib import Path import pytest import yaml from stable_baselines3 import PPO from primaite.config.load import data_manipulation_config_path from primaite.game.game import PrimaiteGame from primaite.session.environment import PrimaiteGymEnv def test_sb3_compatibility(): """Test that the Gymnasium environment can be used with an SB3 agent.""" with open(data_manipulation_config_path(), "r") as f: cfg = yaml.safe_load(f) gym = PrimaiteGymEnv(env_config=cfg) model = PPO("MlpPolicy", gym) model.learn(total_timesteps=256) save_path = Path(tempfile.gettempdir()) / "model.zip" model.save(save_path) assert (save_path).exists() save_path.unlink() # clean up