admin: Set Config returns errSet and errMsg (#3822)

There is no way to see if a node encountered an error
when trying to set a new config set, this commit adds
a bool errSet field.
master
Anis Elleuch 8 years ago committed by Harshavardhana
parent 32d0d3d4ac
commit cddc684559
  1. 11
      cmd/admin-handlers.go
  2. 10
      cmd/admin-handlers_test.go
  3. 3
      pkg/madmin/API.md
  4. 5
      pkg/madmin/config-commands.go

@ -718,9 +718,11 @@ func toAdminAPIErrCode(err error) APIErrorCode {
// SetConfigResult - represents detailed results of a set-config // SetConfigResult - represents detailed results of a set-config
// operation. // operation.
type nodeSummary struct { type nodeSummary struct {
Name string `json:"name"` Name string `json:"name"`
Err string `json:"err"` ErrSet bool `json:"errSet"`
ErrMsg string `json:"errMsg"`
} }
type setConfigResult struct { type setConfigResult struct {
NodeResults []nodeSummary `json:"nodeResults"` NodeResults []nodeSummary `json:"nodeResults"`
Status bool `json:"status"` Status bool `json:"status"`
@ -733,8 +735,9 @@ func writeSetConfigResponse(w http.ResponseWriter, peers adminPeers, errs []erro
// set-config operation. // set-config operation.
for i := range errs { for i := range errs {
nodeResults = append(nodeResults, nodeSummary{ nodeResults = append(nodeResults, nodeSummary{
Name: peers[i].addr, Name: peers[i].addr,
Err: fmt.Sprintf("%v", errs[i]), ErrSet: errs[i] != nil,
ErrMsg: fmt.Sprintf("%v", errs[i]),
}) })
} }

@ -1279,9 +1279,13 @@ func TestWriteSetConfigResponse(t *testing.T) {
if res.Name != testPeers[p].addr { if res.Name != testPeers[p].addr {
t.Errorf("Test %d: Expected node name %s but received %s", i+1, testPeers[p].addr, res.Name) t.Errorf("Test %d: Expected node name %s but received %s", i+1, testPeers[p].addr, res.Name)
} }
expectedErrStr := fmt.Sprintf("%v", test.errs[p]) expectedErrMsg := fmt.Sprintf("%v", test.errs[p])
if res.Err != expectedErrStr { if res.ErrMsg != expectedErrMsg {
t.Errorf("Test %d: Expected error %s but received %s", i+1, expectedErrStr, res.Err) t.Errorf("Test %d: Expected error %s but received %s", i+1, expectedErrMsg, res.ErrMsg)
}
expectedErrSet := test.errs[p] != nil
if res.ErrSet != expectedErrSet {
t.Errorf("Test %d: Expected ErrSet %v but received %v", i+1, expectedErrSet, res.ErrSet)
} }
} }
} }

@ -330,7 +330,8 @@ change to take effect.
|---|---|---| |---|---|---|
|`st.Status` | _bool_ | true if set-config succeeded, false otherwise. | |`st.Status` | _bool_ | true if set-config succeeded, false otherwise. |
|`st.NodeSummary.Name` | _string_ | Network address of the node. | |`st.NodeSummary.Name` | _string_ | Network address of the node. |
|`st.NodeSummary.Err` | _string_ | String representation of the error (if any) on the node.| |`st.NodeSummary.ErrSet` | _bool_ | Bool representation indicating if an error is encountered with the node.|
|`st.NodeSummary.ErrMsg` | _string_ | String representation of the error (if any) on the node.|
__Example__ __Example__

@ -33,8 +33,9 @@ const (
// NodeSummary - represents the result of an operation part of // NodeSummary - represents the result of an operation part of
// set-config on a node. // set-config on a node.
type NodeSummary struct { type NodeSummary struct {
Name string `json:"name"` Name string `json:"name"`
Err string `json:"err"` ErrSet bool `json:"errSet"`
ErrMsg string `json:"errMsg"`
} }
// SetConfigResult - represents detailed results of a set-config // SetConfigResult - represents detailed results of a set-config

Loading…
Cancel
Save