mirror of
https://github.com/etcd-io/etcd.git
synced 2024-09-27 06:25:44 +00:00

State field indicates the state of each machine. For now, its value could be follower or leader.
53 lines
1.6 KiB
Go
53 lines
1.6 KiB
Go
package test
|
|
|
|
import (
|
|
"bytes"
|
|
"encoding/json"
|
|
"os"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/coreos/etcd/tests"
|
|
"github.com/coreos/etcd/third_party/github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
// Ensure that the cluster configuration can be updated.
|
|
func TestClusterConfig(t *testing.T) {
|
|
_, etcds, err := CreateCluster(3, &os.ProcAttr{Files: []*os.File{nil, os.Stdout, os.Stderr}}, false)
|
|
assert.NoError(t, err)
|
|
defer DestroyCluster(etcds)
|
|
|
|
resp, _ := tests.Put("http://localhost:7001/v2/admin/config", "application/json", bytes.NewBufferString(`{"activeSize":3, "promoteDelay":60}`))
|
|
assert.Equal(t, resp.StatusCode, 200)
|
|
|
|
time.Sleep(1 * time.Second)
|
|
|
|
resp, _ = tests.Get("http://localhost:7002/v2/admin/config")
|
|
body := tests.ReadBodyJSON(resp)
|
|
assert.Equal(t, resp.StatusCode, 200)
|
|
assert.Equal(t, body["activeSize"], 3)
|
|
assert.Equal(t, body["promoteDelay"], 60)
|
|
}
|
|
|
|
// TestGetMachines tests '/v2/admin/machines' sends back messages of all machines.
|
|
func TestGetMachines(t *testing.T) {
|
|
_, etcds, err := CreateCluster(3, &os.ProcAttr{Files: []*os.File{nil, os.Stdout, os.Stderr}}, false)
|
|
assert.NoError(t, err)
|
|
defer DestroyCluster(etcds)
|
|
|
|
time.Sleep(1 * time.Second)
|
|
|
|
resp, err := tests.Get("http://localhost:7001/v2/admin/machines")
|
|
if !assert.Equal(t, err, nil) {
|
|
t.FailNow()
|
|
}
|
|
assert.Equal(t, resp.StatusCode, 200)
|
|
machines := make([]map[string]interface{}, 0)
|
|
b := tests.ReadBody(resp)
|
|
json.Unmarshal(b, &machines)
|
|
assert.Equal(t, len(machines), 3)
|
|
if machines[0]["state"] != "leader" && machines[1]["state"] != "leader" && machines[2]["state"] != "leader" {
|
|
t.Errorf("no leader in the cluster")
|
|
}
|
|
}
|