Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

link_linux: Add deserialization of IFF_RUNNING flag #1038

Open
wants to merge 2 commits into
base: main
Choose a base branch
from

Conversation

dylandreimerink
Copy link

I noticed that the decoded link flags never include net.FlagRunning. It seems deserialization logic was never added for this particular flag. Having access to the running flag is actually useful to detect when a link is in a NO-CARRIER state, which happens when a layer 1 issue occurs such as an unplugged or broken cable.

I also removed the comment since the function now deviates from the original.

Add deserialization of the `IFF_RUNNING` link flag which translates to
`net.FlagRunning`.

Signed-off-by: Dylan Reimerink <dylan.reimerink@isovalent.com>
@aboch
Copy link
Collaborator

aboch commented Dec 12, 2024

Thank you @dylandreimerink
Please check the test failure is related
image

@dylandreimerink
Copy link
Author

dylandreimerink commented Dec 12, 2024

Hmm, it seems net.FlagRunning was added in go v1.20. But CI run go v1.17. Go v1.22 is currently the earliest supported version according to the go release policy, so would it be reasonable to bump the minimum go version?

Update the Go version we test against to Go v1.22 which is currently the
oldest version still receiving security updates.

Signed-off-by: Dylan Reimerink <dylan.reimerink@isovalent.com>
@dylandreimerink
Copy link
Author

dylandreimerink commented Dec 13, 2024

I bumped the Go version, which seems to have fixed the original failure. But now we have a new one:

=== RUN   TestRuleListFiltered/IPv6/returns_rules_filtered_by_fwmark_0/0xFFFFFFFF#01
    rule_test.go:592: Expected len: 1, got: 0

        --- PASS: TestRuleListFiltered/IPv6/returns_rules_filtered_by_fwmark_0/0xFFFFFFFF (0.00s)
        --- PASS: TestRuleListFiltered/IPv6/returns_rules_filtered_by_fwmark_0x1234/0 (0.00s)
        --- FAIL: TestRuleListFiltered/IPv6/returns_rules_filtered_by_fwmark_0/0xFFFFFFFF#01 (0.00s)

Interestingly the suite contains the exact same test twice (hence the #01 at the end of the last sub-test name). Both the name, and the test case is the same: First and Second. But it is only on the second that fails.

Not sure if this is test flakyness or something the Go bump might have caused 🤔 .

@aboch
Copy link
Collaborator

aboch commented Jan 8, 2025

Thanks @dylandreimerink
The #01 suffix on those tests is there in older runs (w/ go1.17) as well.

Can you please push a separate PR to bump go to 1.22. This project follows a 1 fix/change/feature per PR.

Thanks

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants