2024-07-10 10:44:53 +00:00
|
|
|
#!/usr/bin/python3
|
|
|
|
|
|
|
|
import asyncio
|
2024-07-25 15:18:38 +00:00
|
|
|
from python.BIRD.Test import Test, BIRDInstance, DumpRIB
|
2024-07-10 13:41:20 +00:00
|
|
|
|
2024-07-11 20:31:06 +00:00
|
|
|
class ThisTest(Test):
|
2024-07-22 08:57:29 +00:00
|
|
|
async def prepare(self):
|
2024-07-19 18:10:40 +00:00
|
|
|
# Set epoch
|
|
|
|
self.epoch = 0
|
|
|
|
|
2024-07-12 20:01:55 +00:00
|
|
|
# Prepare machines and links
|
2024-07-11 21:06:14 +00:00
|
|
|
self.src, self.dest = await self.machines(
|
|
|
|
"src", "dest",
|
|
|
|
t=BIRDInstance,
|
|
|
|
)
|
2024-07-12 16:45:53 +00:00
|
|
|
self.links = {
|
|
|
|
"L": await self.link("L", "src", "dest")
|
|
|
|
}
|
2024-07-11 20:31:06 +00:00
|
|
|
|
2024-07-22 08:57:29 +00:00
|
|
|
async def test(self):
|
2024-07-19 14:47:29 +00:00
|
|
|
# Startup check
|
2024-07-25 15:18:38 +00:00
|
|
|
await DumpRIB(self, 10, "startup")()
|
2024-07-10 13:41:20 +00:00
|
|
|
|
2024-07-19 18:10:40 +00:00
|
|
|
wtb = ["p170", "p180", "p190", "p200"]
|
|
|
|
btw = [*reversed(wtb)]
|
2024-07-19 14:47:29 +00:00
|
|
|
|
|
|
|
# Enable worst to best
|
|
|
|
for p in wtb:
|
|
|
|
await self.src.enable(p)
|
2024-07-25 15:18:38 +00:00
|
|
|
await DumpRIB(self, 1, f"enable-{p}")()
|
2024-07-19 14:47:29 +00:00
|
|
|
|
|
|
|
# Disable worst to best
|
|
|
|
for p in wtb:
|
|
|
|
await self.src.disable(p)
|
2024-07-25 15:18:38 +00:00
|
|
|
await DumpRIB(self, 1, f"disable-{p}")()
|
2024-07-19 14:47:29 +00:00
|
|
|
|
|
|
|
# Enable best to worst
|
|
|
|
for p in btw:
|
2024-07-12 20:01:55 +00:00
|
|
|
await self.src.enable(p)
|
2024-07-25 15:18:38 +00:00
|
|
|
await DumpRIB(self, 1, f"enable-{p}")()
|
2024-07-19 14:47:29 +00:00
|
|
|
|
2024-07-19 18:10:40 +00:00
|
|
|
# Disable best to worst
|
2024-07-19 14:47:29 +00:00
|
|
|
for p in btw:
|
|
|
|
await self.src.disable(p)
|
2024-07-25 15:18:38 +00:00
|
|
|
await DumpRIB(self, 1, f"disable-{p}")()
|
2024-07-19 14:47:29 +00:00
|
|
|
|
|
|
|
# Re-enable all at once
|
|
|
|
await asyncio.gather(*[ self.src.enable(p) for p in wtb ])
|
2024-07-25 15:18:38 +00:00
|
|
|
await DumpRIB(self, 5, f"add-all")()
|
2024-07-10 10:44:53 +00:00
|
|
|
|
2024-07-19 18:10:40 +00:00
|
|
|
# Update configuration
|
|
|
|
self.epoch = 1
|
|
|
|
self.src.write_config(test=self)
|
2024-07-22 08:57:29 +00:00
|
|
|
await self.src.configure(expected_logs=[
|
|
|
|
f"<INFO> Reconfiguring$",
|
|
|
|
f"<INFO> Reloading channel LINK.ipv6",
|
|
|
|
f"<INFO> Reconfigured$",
|
|
|
|
])
|
2024-07-25 15:18:38 +00:00
|
|
|
await DumpRIB(self, 5, f"check-reconfig")()
|
2024-07-19 18:10:40 +00:00
|
|
|
|
|
|
|
# Disable worst to best
|
|
|
|
for p in wtb:
|
|
|
|
await self.src.disable(p)
|
2024-07-25 15:18:38 +00:00
|
|
|
await DumpRIB(self, 1, f"disable-{p}")()
|
2024-07-19 18:10:40 +00:00
|
|
|
|
|
|
|
# Enable best to worst
|
|
|
|
for p in btw:
|
|
|
|
await self.src.enable(p)
|
2024-07-25 15:18:38 +00:00
|
|
|
await DumpRIB(self, 1, f"enable-{p}")()
|
2024-07-19 18:10:40 +00:00
|
|
|
|
|
|
|
# Disable best to worst
|
|
|
|
for p in btw:
|
|
|
|
await self.src.disable(p)
|
2024-07-25 15:18:38 +00:00
|
|
|
await DumpRIB(self, 1, f"disable-{p}")()
|
2024-07-19 18:10:40 +00:00
|
|
|
|
|
|
|
# Enable worst to best
|
|
|
|
for p in wtb:
|
|
|
|
await self.src.enable(p)
|
2024-07-25 15:18:38 +00:00
|
|
|
await DumpRIB(self, 1, f"enable-{p}")()
|
2024-07-19 18:10:40 +00:00
|
|
|
|
|
|
|
# Update configuration once again
|
|
|
|
self.epoch = 2
|
|
|
|
self.src.write_config(test=self)
|
2024-07-22 08:57:29 +00:00
|
|
|
await self.src.configure(expected_logs=[
|
|
|
|
f"<INFO> Reconfiguring$",
|
|
|
|
f"<INFO> Reloading channel LINK.ipv6",
|
|
|
|
f"<INFO> Reconfigured$",
|
|
|
|
])
|
2024-07-25 15:18:38 +00:00
|
|
|
await DumpRIB(self, 5, f"check-reconfig")()
|
2024-07-19 18:10:40 +00:00
|
|
|
|
|
|
|
# Disable best to worst
|
|
|
|
for p in btw:
|
|
|
|
await self.src.disable(p)
|
2024-07-25 15:18:38 +00:00
|
|
|
await DumpRIB(self, 1, f"disable-{p}")()
|
2024-07-19 18:10:40 +00:00
|
|
|
|
|
|
|
# Enable best to worst
|
|
|
|
for p in btw:
|
|
|
|
await self.src.enable(p)
|
2024-07-25 15:18:38 +00:00
|
|
|
await DumpRIB(self, 1, f"enable-{p}")()
|
2024-07-19 18:10:40 +00:00
|
|
|
|
|
|
|
# Disable worst to best
|
|
|
|
for p in wtb:
|
|
|
|
await self.src.disable(p)
|
2024-07-25 15:18:38 +00:00
|
|
|
await DumpRIB(self, 1, f"disable-{p}")()
|
2024-07-19 18:10:40 +00:00
|
|
|
|
|
|
|
# Enable worst to best
|
|
|
|
for p in wtb:
|
|
|
|
await self.src.enable(p)
|
2024-07-25 15:18:38 +00:00
|
|
|
await DumpRIB(self, 1, f"enable-{p}")()
|
2024-07-19 18:10:40 +00:00
|
|
|
|
2024-07-22 08:57:29 +00:00
|
|
|
# Pre-cleanup log checker
|
|
|
|
self.src.default_log_checker.append(f"{self.src.logprefix} <RMT> LINK: Received: Administrative shutdown")
|
|
|
|
self.dest.default_log_checker.append(f"{self.dest.logprefix} <RMT> LINK: Received: Administrative shutdown")
|
|
|
|
|
|
|
|
# Regular cleanup
|
2024-07-12 20:01:55 +00:00
|
|
|
await self.cleanup()
|