Skip to content

Commit

Permalink
Merge pull request #112 from github/hoenn/add-options-for-alloc-explain
Browse files Browse the repository at this point in the history
Add new method and tests for ClusterAllocationExplainWithQueryParams
  • Loading branch information
hoenn authored Feb 22, 2024
2 parents df49acb + fc21e7f commit 40a2451
Show file tree
Hide file tree
Showing 2 changed files with 123 additions and 0 deletions.
24 changes: 24 additions & 0 deletions es.go
Original file line number Diff line number Diff line change
Expand Up @@ -1688,6 +1688,30 @@ func (c *Client) ClusterAllocationExplain(req *ClusterAllocationExplainRequest,
return string(body), nil
}

// ClusterAllocationExplainWithQueryParams provides an explanation for a shard’s current allocation with optional query parameters.
// For more info, please check https://www.elastic.co/guide/en/elasticsearch/reference/current/cluster-allocation-explain.html
func (c *Client) ClusterAllocationExplainWithQueryParams(req *ClusterAllocationExplainRequest, params map[string]string) (string, error) {
uri := "_cluster/allocation/explain"
queryStrings := []string{}
for param, val := range params {
queryStrings = append(queryStrings, fmt.Sprintf("%s=%s", param, val))
}

uri = fmt.Sprintf("%s?%s", uri, strings.Join(queryStrings, "&"))

agent := c.buildGetRequest(uri)
if req != nil {
agent.Set("Content-Type", "application/json").Send(req)
}

body, err := handleErrWithBytes(agent)
if err != nil {
return "", err
}

return string(body), nil
}

type RerouteRequest struct {
// The commands to perform (move, cancel, allocate, etc)
Commands []RerouteCommand `json:"commands,omitempty"`
Expand Down
99 changes: 99 additions & 0 deletions es_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -2211,6 +2211,105 @@ func TestClusterAllocationExplain(t *testing.T) {
}
}

func TestClusterAllocationExplainWithQueryParams(t *testing.T) {
shardID := 0
tests := []struct {
name string
request *ClusterAllocationExplainRequest
params map[string]string
expectedBody string
}{
{
name: "with nil request",
request: nil,
expectedBody: "",
params: map[string]string{},
},
{
name: "with current_node set",
request: &ClusterAllocationExplainRequest{
CurrentNode: "test-node",
},
expectedBody: `{"current_node":"test-node"}`,
params: map[string]string{},
},
{
name: "with index set",
request: &ClusterAllocationExplainRequest{
Index: "test-index",
},
expectedBody: `{"index":"test-index"}`,
params: map[string]string{},
},
{
name: "with primary set",
request: &ClusterAllocationExplainRequest{
Primary: true,
},
expectedBody: `{"primary":true}`,
params: map[string]string{},
},
{
name: "with shard set",
request: &ClusterAllocationExplainRequest{
Shard: &shardID,
},
expectedBody: `{"shard":0}`,
params: map[string]string{},
},
{
name: "with pretty param",
request: nil,
params: map[string]string{
"pretty": "true",
},
},
{
name: "with multiple params",
request: nil,
params: map[string]string{
"pretty": "true",
"include_disk_info": "true",
"include_yes_decisions": "true",
},
},
}

for _, tt := range tests {
tc := tt
t.Run(tc.name, func(t *testing.T) {
testSetup := &ServerSetup{
Method: "GET",
Path: "/_cluster/allocation/explain",
Body: tc.expectedBody,
}

if len(tc.params) > 0 {
testSetup.extraChecksFn = func(t *testing.T, r *http.Request) {
vals := r.URL.Query()
if len(vals) != len(tc.params) {
t.Errorf("expected %d query params but got %d", len(tc.params), len(vals))
}
for param, val := range tc.params {
if actual := vals.Get(param); actual != val {
t.Errorf("expected val '%s' for query parameter '%s' but got '%s'", val, param, actual)
}
}
}
}

host, port, ts := setupTestServers(t, []*ServerSetup{testSetup})
defer ts.Close()
client := NewClient(host, port)

_, err := client.ClusterAllocationExplainWithQueryParams(tc.request, tc.params)
if err != nil {
t.Fatalf("Unexpected error. expected nil, got %s", err)
}
})
}
}

func TestReroute(t *testing.T) {
testSetup := &ServerSetup{
Method: "POST",
Expand Down

0 comments on commit 40a2451

Please sign in to comment.