0
0
mirror of https://gitlab.nic.cz/labs/bird.git synced 2025-01-05 08:31:53 +00:00
bird/flock/bgp-secondary/test.py

117 lines
3.4 KiB
Python
Raw Normal View History

#!/usr/bin/python3
import asyncio
2024-07-25 15:18:38 +00:00
from python.BIRD.Test import Test, BIRDInstance, DumpRIB
class ThisTest(Test):
async def prepare(self):
2024-07-19 18:10:40 +00:00
# Set epoch
self.epoch = 0
# Prepare machines and links
self.src, self.dest = await self.machines(
"src", "dest",
t=BIRDInstance,
)
self.links = {
"L": await self.link("L", "src", "dest")
}
async def test(self):
# Startup check
2024-07-25 15:18:38 +00:00
await DumpRIB(self, 10, "startup")()
2024-07-19 18:10:40 +00:00
wtb = ["p170", "p180", "p190", "p200"]
btw = [*reversed(wtb)]
# 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}")()
# 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}")()
# 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}")()
# 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-19 18:10:40 +00:00
# Update configuration
self.epoch = 1
self.src.write_config(test=self)
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)
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
# 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
await self.cleanup()