Skip to content

Commit

Permalink
netavark: add bclim option for macvlan
Browse files Browse the repository at this point in the history
see containers/netavark#698

Signed-off-by: Paul Holzinger <[email protected]>
  • Loading branch information
Luap99 committed May 25, 2023
1 parent 5e0be23 commit 87bacec
Show file tree
Hide file tree
Showing 3 changed files with 79 additions and 5 deletions.
11 changes: 11 additions & 0 deletions libnetwork/netavark/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -337,6 +337,17 @@ func createIpvlanOrMacvlan(network *types.Network) error {
}
// rust only support "true" or "false" while go can parse 1 and 0 as well so we need to change it
network.Options[types.NoDefaultRoute] = strconv.FormatBool(val)
case types.BclimOption:
if isMacVlan {
_, err := strconv.ParseInt(value, 10, 32)
if err != nil {
return fmt.Errorf("failed to parse %q option: %w", key, err)
}
// do not fallthrough for macvlan
break
}
// bclim is only valid for macvlan not ipvlan so fallthrough to error case
fallthrough
default:
return fmt.Errorf("unsupported %s network option %s", driver, key)
}
Expand Down
62 changes: 62 additions & 0 deletions libnetwork/netavark/config_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -1102,6 +1102,68 @@ var _ = Describe("Config", func() {
Expect(network1.IPAMOptions).To(HaveKeyWithValue("driver", "host-local"))
})

It("create macvlan config with bclim", func() {
subnet := "10.1.0.0/24"
n, _ := types.ParseCIDR(subnet)
network := types.Network{
Driver: "macvlan",
Subnets: []types.Subnet{
{Subnet: n},
},
Options: map[string]string{
types.BclimOption: "-1",
},
}
network1, err := libpodNet.NetworkCreate(network, nil)
Expect(err).ToNot(HaveOccurred())
Expect(network1.Name).ToNot(BeEmpty())
Expect(network1.Options).To(HaveKeyWithValue("bclim", "-1"))

network = types.Network{
Driver: "macvlan",
Subnets: []types.Subnet{
{Subnet: n},
},
Options: map[string]string{
types.BclimOption: "1000",
},
}
network1, err = libpodNet.NetworkCreate(network, nil)
Expect(err).ToNot(HaveOccurred())
Expect(network1.Name).ToNot(BeEmpty())
Expect(network1.Options).To(HaveKeyWithValue("bclim", "1000"))

network = types.Network{
Driver: "macvlan",
Subnets: []types.Subnet{
{Subnet: n},
},
Options: map[string]string{
types.BclimOption: "abc",
},
}
_, err = libpodNet.NetworkCreate(network, nil)
Expect(err).To(HaveOccurred())
Expect(err.Error()).To(Equal("failed to parse \"bclim\" option: strconv.ParseInt: parsing \"abc\": invalid syntax"))
})

It("create ipvlan config with bclim should fail", func() {
subnet := "10.1.0.0/24"
n, _ := types.ParseCIDR(subnet)
network := types.Network{
Driver: "ipvlan",
Subnets: []types.Subnet{
{Subnet: n},
},
Options: map[string]string{
types.BclimOption: "-1",
},
}
_, err := libpodNet.NetworkCreate(network, nil)
Expect(err).To(HaveOccurred())
Expect(err.Error()).To(Equal("unsupported ipvlan network option bclim"))
})

It("create macvlan config with mode", func() {
subnet := "10.1.0.0/24"
n, _ := types.ParseCIDR(subnet)
Expand Down
11 changes: 6 additions & 5 deletions libnetwork/types/const.go
Original file line number Diff line number Diff line change
Expand Up @@ -36,12 +36,13 @@ const (
IPVLANModeL3s = "l3s"

// valid network options
VLANOption = "vlan"
MTUOption = "mtu"
ModeOption = "mode"
IsolateOption = "isolate"
MetricOption = "metric"
VLANOption = "vlan"
MTUOption = "mtu"
ModeOption = "mode"
IsolateOption = "isolate"
MetricOption = "metric"
NoDefaultRoute = "no_default_route"
BclimOption = "bclim"
)

type NetworkBackend string
Expand Down

0 comments on commit 87bacec

Please sign in to comment.