Files
etcd/tests/framework/config/client.go
Benjamin Wang 4e0ccc69c9 test: refactor the client interface
It doesn't make sense to always pass a AuthConfig parameter for
test cases which do not enable auth at all. So refactoring the
Client interface method so that it accepts a `ClientOption`
variadic parameter.

Signed-off-by: Benjamin Wang <wachao@vmware.com>
2022-10-24 19:04:34 +08:00

78 lines
1.6 KiB
Go

// Copyright 2022 The etcd Authors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package config
import (
"time"
clientv3 "go.etcd.io/etcd/client/v3"
)
// ClientOption configures the client with additional parameter.
// For example, if Auth is enabled,
// 1. e2e test cases use e2e.WithAuth to return a ClientOption;
// 2. integration test, uses integration.WithAuth to return a ClientOption.
type ClientOption func(any)
type GetOptions struct {
Revision int
End string
CountOnly bool
Serializable bool
Prefix bool
FromKey bool
Limit int
Order clientv3.SortOrder
SortBy clientv3.SortTarget
Timeout time.Duration
}
type PutOptions struct {
LeaseID clientv3.LeaseID
}
type DeleteOptions struct {
Prefix bool
FromKey bool
End string
}
type TxnOptions struct {
Interactive bool
}
type CompactOption struct {
Physical bool
Timeout time.Duration
}
type DefragOption struct {
Timeout time.Duration
}
type LeaseOption struct {
WithAttachedKeys bool
}
type UserAddOptions struct {
NoPassword bool
}
type WatchOptions struct {
Prefix bool
Revision int64
RangeEnd string
}