Page MenuHomeFreeBSD

carp tests: Basic functionality test
ClosedPublic

Authored by kp on Apr 5 2020, 5:01 PM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Jan 15, 3:27 PM
Unknown Object (File)
Wed, Jan 15, 1:48 PM
Unknown Object (File)
Wed, Jan 15, 12:36 PM
Unknown Object (File)
Wed, Jan 1, 3:00 AM
Unknown Object (File)
Tue, Dec 31, 2:44 AM
Unknown Object (File)
Mon, Dec 30, 2:50 AM
Unknown Object (File)
Sun, Dec 29, 2:47 AM
Unknown Object (File)
Dec 28 2024, 3:25 AM

Details

Summary

Set up three vnet jails, bridged together. Run carp between two of them.
Attempt to provoke locking / epoch issues.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

Remove incorrect sponsorship lines.

LGTM, please see comment inline.

tests/sys/net/if_carp.sh
48 ↗(On Diff #70243)

Would it be possible to prefix jail names with the the test name to reduce the possibility of jail name clashes?

This revision is now accepted and ready to land.Apr 6 2020, 10:45 AM
tests/sys/net/if_carp.sh
57 ↗(On Diff #70243)

Maybe worth moving this test to netinet/, as it doesn't share any ipv4/ipv6 code?

Would it be possible to add IPv6 counterpart to this test, so both IPv4 and IPv6 control plane parts gets covered?

Generally looks good to me, especially if we just test locking. For genera-purpose testing would be good to test master election, failover, etc.

tests/sys/net/if_carp.sh
58 ↗(On Diff #70243)

Shouldn't this have /32 mask? I am curios how it works for routing table with another IP from the same subnet with /29, if it works.

Would it be possible to add IPv6 counterpart to this test, so both IPv4 and IPv6 control plane parts gets covered?

That'll hopefully be pretty straightforward. I'll give that a try.

tests/sys/net/if_carp.sh
48 ↗(On Diff #70243)

Possibly, but I'm not sure it'll help. Many of these tests mess with the host system routing table (by keeping epair interfaces in the host vnet, and assigning addresses). So we'd have to do more than just change the jail names.

We'd also want to do that manually (or at least deterministically), because debugging tests with random jail names is painful.

57 ↗(On Diff #70243)

Yeah, that makes sense. I'd put it here because it's somewhat similar in nature to the bridge and epair tests, but that code does live in net/.
I'll update the test and move it.

58 ↗(On Diff #70243)

I have no idea. I don't pretend to understand carp. I mostly transposed the test script I initially used to trigger the panics this test tries to provoke.
It might make sense to use a different subnet for the real IPs from the carp IP.

Move the test, add IPv6 test

This revision now requires review to proceed.Apr 6 2020, 5:39 PM
tests/sys/netinet/carp.sh
52 ↗(On Diff #70265)

Better to use RFC5737 addresses: 192.0.2.0/24

63 ↗(On Diff #70265)

Why the hard-coded sleep?

tests/sys/netinet/carp.sh
63 ↗(On Diff #70265)

That gives carp a bit of time to come up. Otherwise we risk trying to ping an address that's not there yet.

Fix IP addresses and general cleanup

tests/sys/netinet/carp.sh
63 ↗(On Diff #70265)

It's unnecessarily slow on fast systems, and could potentially cause false negatives on slow systems. Please change it to a polling loop.

tests/sys/net/if_carp.sh
48 ↗(On Diff #70243)

Indeed, there are a bunch of tests that changes routing in the host system. Ideally we'd want to reduce the number of such tests or at least not increase it :-) I've changed a bunch of mine tests to use dual jail configuration to avoid changes in the host system and I plan to convert more.

I totally agree that random jail names complicates debugging a lot.
I'm proposing prefixing each jail with a test name, so they're unique and one can easily understand relationship between the jail name and pariticular test piece.

57 ↗(On Diff #70243)

Thank you!
One note - my understanding is that we split af-specific tests into netinet/ and netinet6/ , so one can easily test for specific address family.

Replace 'sleep 3' by a polling loop for carp readiness

Wait until one of the two jails has become carp master

Waiting until one of them leaves INIT state is insufficient. There's a
transition period where both carp jails are in BACKUP state, and the carp
address is unreachable.

This revision is now accepted and ready to land.Apr 8 2020, 2:03 PM
This revision was automatically updated to reflect the committed changes.