mirror of
https://github.com/etcd-io/etcd.git
synced 2024-09-27 06:25:44 +00:00
tests: Refactor append failed requests
Signed-off-by: Marek Siarkowicz <siarkowicz@google.com>
This commit is contained in:
parent
619ca4f5cf
commit
5ff9202027
@ -55,17 +55,9 @@ func (h *appendableHistory) AppendGet(key string, start, end time.Time, resp *cl
|
||||
}
|
||||
|
||||
func (h *appendableHistory) AppendPut(key, value string, start, end time.Time, resp *clientv3.PutResponse, err error) {
|
||||
request := EtcdRequest{Op: Put, Key: key, PutData: value}
|
||||
if err != nil {
|
||||
h.failed = append(h.failed, porcupine.Operation{
|
||||
ClientId: h.id,
|
||||
Input: EtcdRequest{Op: Put, Key: key, PutData: value},
|
||||
Call: start.UnixNano(),
|
||||
Output: EtcdResponse{Err: err},
|
||||
Return: 0, // For failed writes we don't know when request has really finished.
|
||||
})
|
||||
// Operations of single client needs to be sequential.
|
||||
// As we don't know return time of failed operations, all new writes need to be done with new client id.
|
||||
h.id = h.idProvider.ClientId()
|
||||
h.appendFailed(request, start, err)
|
||||
return
|
||||
}
|
||||
var revision int64
|
||||
@ -82,17 +74,9 @@ func (h *appendableHistory) AppendPut(key, value string, start, end time.Time, r
|
||||
}
|
||||
|
||||
func (h *appendableHistory) AppendDelete(key string, start, end time.Time, resp *clientv3.DeleteResponse, err error) {
|
||||
request := EtcdRequest{Op: Delete, Key: key}
|
||||
if err != nil {
|
||||
h.failed = append(h.failed, porcupine.Operation{
|
||||
ClientId: h.id,
|
||||
Input: EtcdRequest{Op: Delete, Key: key},
|
||||
Call: start.UnixNano(),
|
||||
Output: EtcdResponse{Err: err},
|
||||
Return: 0, // For failed writes we don't know when request has really finished.
|
||||
})
|
||||
// Operations of single client needs to be sequential.
|
||||
// As we don't know return time of failed operations, all new writes need to be done with new client id.
|
||||
h.id = h.idProvider.ClientId()
|
||||
h.appendFailed(request, start, err)
|
||||
return
|
||||
}
|
||||
var revision int64
|
||||
@ -103,13 +87,26 @@ func (h *appendableHistory) AppendDelete(key string, start, end time.Time, resp
|
||||
}
|
||||
h.successful = append(h.successful, porcupine.Operation{
|
||||
ClientId: h.id,
|
||||
Input: EtcdRequest{Op: Delete, Key: key},
|
||||
Input: request,
|
||||
Call: start.UnixNano(),
|
||||
Output: EtcdResponse{Revision: revision, Deleted: deleted, Err: err},
|
||||
Return: end.UnixNano(),
|
||||
})
|
||||
}
|
||||
|
||||
func (h *appendableHistory) appendFailed(request EtcdRequest, start time.Time, err error) {
|
||||
h.failed = append(h.failed, porcupine.Operation{
|
||||
ClientId: h.id,
|
||||
Input: request,
|
||||
Call: start.UnixNano(),
|
||||
Output: EtcdResponse{Err: err},
|
||||
Return: 0, // For failed writes we don't know when request has really finished.
|
||||
})
|
||||
// Operations of single client needs to be sequential.
|
||||
// As we don't know return time of failed operations, all new writes need to be done with new client id.
|
||||
h.id = h.idProvider.ClientId()
|
||||
}
|
||||
|
||||
type history struct {
|
||||
successful []porcupine.Operation
|
||||
// failed requests are kept separate as we don't know return time of failed operations.
|
||||
|
Loading…
x
Reference in New Issue
Block a user