You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
soil/tests/test_time.py

75 lines
2.0 KiB
Python

2 years ago
from unittest import TestCase
from soil import time, agents, environment
2 years ago
2 years ago
class TestMain(TestCase):
def test_cond(self):
2 years ago
"""
2 years ago
A condition should match a When if the concition is True
2 years ago
"""
2 years ago
t = time.Cond(lambda t: True)
f = time.Cond(lambda t: False)
for i in range(10):
w = time.When(i)
assert w == t
assert w is not f
def test_cond(self):
2 years ago
"""
2 years ago
Comparing a Cond to a Delta should always return False
2 years ago
"""
2 years ago
c = time.Cond(lambda t: False)
d = time.Delta(1)
assert c is not d
def test_cond_env(self):
2 years ago
""" """
2 years ago
times_started = []
times_awakened = []
times_asleep = []
2 years ago
times = []
done = []
2 years ago
class CondAgent(agents.BaseAgent):
def step(self):
nonlocal done
times_started.append(self.now)
while True:
times_asleep.append(self.now)
2 years ago
yield time.Cond(lambda agent: agent.now >= 10, delta=2)
2 years ago
times_awakened.append(self.now)
if self.now >= 10:
break
done.append(self.now)
2 years ago
2 years ago
env = environment.Environment(agents=[{"agent_class": CondAgent}])
2 years ago
while env.schedule.time < 11:
times.append(env.now)
env.step()
2 years ago
assert env.schedule.time == 11
assert times_started == [0]
assert times_awakened == [10]
assert done == [10]
2 years ago
# The first time will produce the Cond.
assert env.schedule.steps == 6
assert len(times) == 6
2 years ago
while env.schedule.time < 13:
2 years ago
times.append(env.now)
env.step()
2 years ago
assert times == [0, 2, 4, 6, 8, 10, 11]
assert env.schedule.time == 13
2 years ago
assert times_started == [0, 11]
assert times_awakened == [10]
assert done == [10]
2 years ago
# Once more to yield the cond, another one to continue
assert env.schedule.steps == 7
assert len(times) == 7