69afd304 |
// +build !windows
package main
import ( |
dc044f26 |
"fmt" |
e25352a4 |
"testing" |
69afd304 |
"time"
"github.com/docker/docker/api/types/swarm"
"github.com/docker/docker/integration-cli/checker"
"github.com/docker/docker/integration-cli/daemon" |
e25352a4 |
"gotest.tools/assert" |
9266ff78 |
"gotest.tools/poll" |
69afd304 |
)
|
64a928a3 |
func (s *DockerSwarmSuite) TestAPISwarmListNodes(c *testing.T) { |
69afd304 |
d1 := s.AddDaemon(c, true, true)
d2 := s.AddDaemon(c, true, false)
d3 := s.AddDaemon(c, true, false)
nodes := d1.ListNodes(c) |
673cf751 |
assert.Equal(c, len(nodes), 3, fmt.Sprintf("nodes: %#v", nodes)) |
69afd304 |
loop0:
for _, n := range nodes { |
83d18cf4 |
for _, d := range []*daemon.Daemon{d1, d2, d3} {
if n.ID == d.NodeID() { |
69afd304 |
continue loop0
}
}
c.Errorf("unknown nodeID %v", n.ID)
}
}
|
64a928a3 |
func (s *DockerSwarmSuite) TestAPISwarmNodeUpdate(c *testing.T) { |
69afd304 |
d := s.AddDaemon(c, true, true)
nodes := d.ListNodes(c)
d.UpdateNode(c, nodes[0].ID, func(n *swarm.Node) {
n.Spec.Availability = swarm.NodeAvailabilityPause
})
n := d.GetNode(c, nodes[0].ID) |
6dc7846d |
assert.Equal(c, n.Spec.Availability, swarm.NodeAvailabilityPause) |
69afd304 |
}
|
64a928a3 |
func (s *DockerSwarmSuite) TestAPISwarmNodeRemove(c *testing.T) { |
69afd304 |
testRequires(c, Network)
d1 := s.AddDaemon(c, true, true)
d2 := s.AddDaemon(c, true, false)
_ = s.AddDaemon(c, true, false)
nodes := d1.ListNodes(c) |
673cf751 |
assert.Equal(c, len(nodes), 3, fmt.Sprintf("nodes: %#v", nodes)) |
69afd304 |
// Getting the info so we can take the NodeID |
83d18cf4 |
d2Info := d2.SwarmInfo(c) |
69afd304 |
// forceful removal of d2 should work
d1.RemoveNode(c, d2Info.NodeID, true)
nodes = d1.ListNodes(c) |
673cf751 |
assert.Equal(c, len(nodes), 2, fmt.Sprintf("nodes: %#v", nodes)) |
69afd304 |
// Restart the node that was removed |
2ed512c7 |
d2.RestartNode(c) |
69afd304 |
// Give some time for the node to rejoin
time.Sleep(1 * time.Second)
// Make sure the node didn't rejoin
nodes = d1.ListNodes(c) |
673cf751 |
assert.Equal(c, len(nodes), 2, fmt.Sprintf("nodes: %#v", nodes)) |
69afd304 |
}
|
64a928a3 |
func (s *DockerSwarmSuite) TestAPISwarmNodeDrainPause(c *testing.T) { |
69afd304 |
d1 := s.AddDaemon(c, true, true)
d2 := s.AddDaemon(c, true, false)
time.Sleep(1 * time.Second) // make sure all daemons are ready to accept tasks
// start a service, expect balanced distribution |
ebdc9a3a |
instances := 2 |
69afd304 |
id := d1.CreateService(c, simpleTestService, setInstances(instances))
|
9266ff78 |
poll.WaitOn(c, pollCheck(c, d1.CheckActiveContainerCount, checker.GreaterThan(0)), poll.WithTimeout(defaultReconciliationTimeout))
poll.WaitOn(c, pollCheck(c, d2.CheckActiveContainerCount, checker.GreaterThan(0)), poll.WithTimeout(defaultReconciliationTimeout))
poll.WaitOn(c, pollCheck(c, reducedCheck(sumAsIntegers, d1.CheckActiveContainerCount, d2.CheckActiveContainerCount), checker.Equals(instances)), poll.WithTimeout(defaultReconciliationTimeout)) |
69afd304 |
// drain d2, all containers should move to d1 |
83d18cf4 |
d1.UpdateNode(c, d2.NodeID(), func(n *swarm.Node) { |
69afd304 |
n.Spec.Availability = swarm.NodeAvailabilityDrain
}) |
9266ff78 |
poll.WaitOn(c, pollCheck(c, d1.CheckActiveContainerCount, checker.Equals(instances)), poll.WithTimeout(defaultReconciliationTimeout))
poll.WaitOn(c, pollCheck(c, d2.CheckActiveContainerCount, checker.Equals(0)), poll.WithTimeout(defaultReconciliationTimeout)) |
69afd304 |
// set d2 back to active |
83d18cf4 |
d1.UpdateNode(c, d2.NodeID(), func(n *swarm.Node) { |
69afd304 |
n.Spec.Availability = swarm.NodeAvailabilityActive
})
instances = 1
d1.UpdateService(c, d1.GetService(c, id), setInstances(instances)) |
9266ff78 |
poll.WaitOn(c, pollCheck(c, reducedCheck(sumAsIntegers, d1.CheckActiveContainerCount, d2.CheckActiveContainerCount), checker.Equals(instances)), poll.WithTimeout(defaultReconciliationTimeout*2)) |
69afd304 |
|
ebdc9a3a |
instances = 2 |
69afd304 |
d1.UpdateService(c, d1.GetService(c, id), setInstances(instances))
// drained node first so we don't get any old containers |
9266ff78 |
poll.WaitOn(c, pollCheck(c, d2.CheckActiveContainerCount, checker.GreaterThan(0)), poll.WithTimeout(defaultReconciliationTimeout))
poll.WaitOn(c, pollCheck(c, d1.CheckActiveContainerCount, checker.GreaterThan(0)), poll.WithTimeout(defaultReconciliationTimeout))
poll.WaitOn(c, pollCheck(c, reducedCheck(sumAsIntegers, d1.CheckActiveContainerCount, d2.CheckActiveContainerCount), checker.Equals(instances)), poll.WithTimeout(defaultReconciliationTimeout*2)) |
69afd304 |
|
9722214c |
d2ContainerCount := len(d2.ActiveContainers(c)) |
69afd304 |
// set d2 to paused, scale service up, only d1 gets new tasks |
83d18cf4 |
d1.UpdateNode(c, d2.NodeID(), func(n *swarm.Node) { |
69afd304 |
n.Spec.Availability = swarm.NodeAvailabilityPause
})
|
ebdc9a3a |
instances = 4 |
69afd304 |
d1.UpdateService(c, d1.GetService(c, id), setInstances(instances)) |
9266ff78 |
poll.WaitOn(c, pollCheck(c, d1.CheckActiveContainerCount, checker.Equals(instances-d2ContainerCount)), poll.WithTimeout(defaultReconciliationTimeout))
poll.WaitOn(c, pollCheck(c, d2.CheckActiveContainerCount, checker.Equals(d2ContainerCount)), poll.WithTimeout(defaultReconciliationTimeout)) |
69afd304 |
} |