mirror of https://github.com/containers/podman.git
Fix farm update to check for connections
Fix farm update to verify a connection exists before removing or adding it. Also verify that the farm we want to update exists. Signed-off-by: Urvashi Mohnani <umohnani@redhat.com>
This commit is contained in:
parent
c3ab75ca45
commit
e0b44bcf37
|
|
@ -8,6 +8,7 @@ import (
|
||||||
"github.com/containers/common/pkg/config"
|
"github.com/containers/common/pkg/config"
|
||||||
"github.com/containers/podman/v4/cmd/podman/common"
|
"github.com/containers/podman/v4/cmd/podman/common"
|
||||||
"github.com/containers/podman/v4/cmd/podman/registry"
|
"github.com/containers/podman/v4/cmd/podman/registry"
|
||||||
|
"github.com/containers/podman/v4/pkg/util"
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
@ -68,6 +69,10 @@ func farmUpdate(cmd *cobra.Command, args []string) error {
|
||||||
return errors.New("no farms are created at this time, there is nothing to update")
|
return errors.New("no farms are created at this time, there is nothing to update")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if _, ok := cfg.Farms.List[farmName]; !ok {
|
||||||
|
return fmt.Errorf("cannot update farm, %q farm doesn't exist", farmName)
|
||||||
|
}
|
||||||
|
|
||||||
if defChanged {
|
if defChanged {
|
||||||
// Change the default to the given farm if --default=true
|
// Change the default to the given farm if --default=true
|
||||||
if updateOpts.Default {
|
if updateOpts.Default {
|
||||||
|
|
@ -85,13 +90,22 @@ func farmUpdate(cmd *cobra.Command, args []string) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, cRemove := range updateOpts.Remove {
|
for _, cRemove := range updateOpts.Remove {
|
||||||
|
connections := cfg.Farms.List[farmName]
|
||||||
|
if util.StringInSlice(cRemove, connections) {
|
||||||
delete(cMap, cRemove)
|
delete(cMap, cRemove)
|
||||||
|
} else {
|
||||||
|
return fmt.Errorf("cannot remove from farm, %q is not a connection in the farm", cRemove)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, cAdd := range updateOpts.Add {
|
for _, cAdd := range updateOpts.Add {
|
||||||
|
if _, ok := cfg.Engine.ServiceDestinations[cAdd]; ok {
|
||||||
if _, ok := cMap[cAdd]; !ok {
|
if _, ok := cMap[cAdd]; !ok {
|
||||||
cMap[cAdd] = 0
|
cMap[cAdd] = 0
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
return fmt.Errorf("cannot add to farm, %q is not a system connection", cAdd)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
updatedConnections := []string{}
|
updatedConnections := []string{}
|
||||||
|
|
|
||||||
|
|
@ -156,7 +156,80 @@ var _ = Describe("podman farm", func() {
|
||||||
Expect(cfg.Farms.Default).Should(BeEmpty())
|
Expect(cfg.Farms.Default).Should(BeEmpty())
|
||||||
})
|
})
|
||||||
|
|
||||||
It("remove existing farms", func() {
|
It("update farm with non-existing connections", func() {
|
||||||
|
// create farm with multiple system connections
|
||||||
|
cmd := []string{"farm", "create", "farm1", "QA", "QB"}
|
||||||
|
session := podmanTest.Podman(cmd)
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session).Should(ExitCleanly())
|
||||||
|
Expect(session.Out.Contents()).Should(ContainSubstring("Farm \"farm1\" created"))
|
||||||
|
|
||||||
|
// create farm with only one system connection
|
||||||
|
cmd = []string{"farm", "create", "farm2", "QA"}
|
||||||
|
session = podmanTest.Podman(cmd)
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session).Should(ExitCleanly())
|
||||||
|
Expect(session.Out.Contents()).Should(ContainSubstring("Farm \"farm2\" created"))
|
||||||
|
|
||||||
|
cfg, err := config.ReadCustomConfig()
|
||||||
|
Expect(err).ShouldNot(HaveOccurred())
|
||||||
|
Expect(cfg.Farms.Default).Should(Equal("farm1"))
|
||||||
|
Expect(cfg.Farms.List).Should(HaveKeyWithValue("farm1", []string{"QA", "QB"}))
|
||||||
|
Expect(cfg.Farms.List).Should(HaveKeyWithValue("farm2", []string{"QA"}))
|
||||||
|
|
||||||
|
// update farm1 to add no-node connection to it
|
||||||
|
cmd = []string{"farm", "update", "--add", "no-node", "farm1"}
|
||||||
|
session = podmanTest.Podman(cmd)
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session).Should(ExitWithError())
|
||||||
|
|
||||||
|
// update farm2 to remove node not in farm connections from it
|
||||||
|
cmd = []string{"farm", "update", "--remove", "QB", "farm2"}
|
||||||
|
session = podmanTest.Podman(cmd)
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session).Should(ExitWithError())
|
||||||
|
|
||||||
|
// read config again to ensure that nothing has changed
|
||||||
|
cfg, err = config.ReadCustomConfig()
|
||||||
|
Expect(err).ShouldNot(HaveOccurred())
|
||||||
|
Expect(cfg.Farms.Default).Should(Equal("farm1"))
|
||||||
|
Expect(cfg.Farms.List).Should(HaveKeyWithValue("farm1", []string{"QA", "QB"}))
|
||||||
|
Expect(cfg.Farms.List).Should(HaveKeyWithValue("farm2", []string{"QA"}))
|
||||||
|
})
|
||||||
|
|
||||||
|
It("update non-existent farm", func() {
|
||||||
|
// create farm with multiple system connections
|
||||||
|
cmd := []string{"farm", "create", "farm1", "QA", "QB"}
|
||||||
|
session := podmanTest.Podman(cmd)
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session).Should(ExitCleanly())
|
||||||
|
Expect(session.Out.Contents()).Should(ContainSubstring("Farm \"farm1\" created"))
|
||||||
|
|
||||||
|
cfg, err := config.ReadCustomConfig()
|
||||||
|
Expect(err).ShouldNot(HaveOccurred())
|
||||||
|
Expect(cfg.Farms.Default).Should(Equal("farm1"))
|
||||||
|
Expect(cfg.Farms.List).Should(HaveKeyWithValue("farm1", []string{"QA", "QB"}))
|
||||||
|
|
||||||
|
// update non-existent farm to add QA connection to it
|
||||||
|
cmd = []string{"farm", "update", "--add", "no-node", "non-existent"}
|
||||||
|
session = podmanTest.Podman(cmd)
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session).Should(ExitWithError())
|
||||||
|
|
||||||
|
// update non-existent farm to default
|
||||||
|
cmd = []string{"farm", "update", "--default", "non-existent"}
|
||||||
|
session = podmanTest.Podman(cmd)
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session).Should(ExitWithError())
|
||||||
|
|
||||||
|
// read config again and ensure nothing has changed
|
||||||
|
cfg, err = config.ReadCustomConfig()
|
||||||
|
Expect(err).ShouldNot(HaveOccurred())
|
||||||
|
Expect(cfg.Farms.Default).Should(Equal("farm1"))
|
||||||
|
Expect(cfg.Farms.List).Should(HaveKeyWithValue("farm1", []string{"QA", "QB"}))
|
||||||
|
})
|
||||||
|
|
||||||
|
It("remove farms", func() {
|
||||||
// create farm with multiple system connections
|
// create farm with multiple system connections
|
||||||
cmd := []string{"farm", "create", "farm1", "QA", "QB"}
|
cmd := []string{"farm", "create", "farm1", "QA", "QB"}
|
||||||
session := podmanTest.Podman(cmd)
|
session := podmanTest.Podman(cmd)
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue