Merge pull request #4842 from gyuho/serial

etcdctlv3: get command with consistency flag
This commit is contained in:
Gyu-Ho Lee 2016-03-22 17:07:29 -07:00
commit e9b9b228e7
2 changed files with 34 additions and 15 deletions

View File

@ -23,6 +23,22 @@ import (
"github.com/coreos/etcd/pkg/testutil" "github.com/coreos/etcd/pkg/testutil"
) )
func TestCtlV3Set(t *testing.T) {
testCtlV3Set(t, &configNoTLS, 3*time.Second, false)
}
func TestCtlV3SetZeroTimeout(t *testing.T) {
testCtlV3Set(t, &configNoTLS, 0, false)
}
func TestCtlV3SetTimeout(t *testing.T) {
testCtlV3Set(t, &configNoTLS, time.Nanosecond, false)
}
func TestCtlV3SetPeerTLS(t *testing.T) {
testCtlV3Set(t, &configPeerTLS, 3*time.Second, false)
}
func TestCtlV3SetQuorum(t *testing.T) { func TestCtlV3SetQuorum(t *testing.T) {
testCtlV3Set(t, &configNoTLS, 3*time.Second, true) testCtlV3Set(t, &configNoTLS, 3*time.Second, true)
} }
@ -105,12 +121,10 @@ func ctlV3Put(clus *etcdProcessCluster, key, value string, dialTimeout time.Dura
} }
func ctlV3Get(clus *etcdProcessCluster, key, value string, dialTimeout time.Duration, quorum bool) error { func ctlV3Get(clus *etcdProcessCluster, key, value string, dialTimeout time.Duration, quorum bool) error {
if !quorum { // TODO: add serialized option
panic("serialized option is not implemented")
}
cmdArgs := append(ctlV3PrefixArgs(clus, dialTimeout), "get", key) cmdArgs := append(ctlV3PrefixArgs(clus, dialTimeout), "get", key)
if !quorum {
cmdArgs = append(cmdArgs, "--consistency", "s")
}
// TODO: match by value. Currently it prints out both key and value in multi-lines. // TODO: match by value. Currently it prints out both key and value in multi-lines.
return spawnWithExpectedString(cmdArgs, key) return spawnWithExpectedString(cmdArgs, key)
} }
@ -122,10 +136,6 @@ func mustCtlV3(t *testing.T) {
} }
func setupCtlV3Test(t *testing.T, cfg *etcdProcessClusterConfig, quorum bool) *etcdProcessCluster { func setupCtlV3Test(t *testing.T, cfg *etcdProcessClusterConfig, quorum bool) *etcdProcessCluster {
if !quorum { // TODO: add serialized option
panic("serialized option is not implemented")
}
mustCtlV3(t) mustCtlV3(t)
if !quorum { if !quorum {
cfg = configStandalone(*cfg) cfg = configStandalone(*cfg)

View File

@ -24,6 +24,7 @@ import (
) )
var ( var (
getConsistency string
getLimit int64 getLimit int64
getSortOrder string getSortOrder string
getSortTarget string getSortTarget string
@ -39,12 +40,12 @@ func NewGetCommand() *cobra.Command {
Run: getCommandFunc, Run: getCommandFunc,
} }
cmd.Flags().StringVar(&getConsistency, "consistency", "l", "Linearizable(l) or Serializable(s)")
cmd.Flags().StringVar(&getSortOrder, "order", "", "order of results; ASCEND or DESCEND") cmd.Flags().StringVar(&getSortOrder, "order", "", "order of results; ASCEND or DESCEND")
cmd.Flags().StringVar(&getSortTarget, "sort-by", "", "sort target; CREATE, KEY, MODIFY, VALUE, or VERSION") cmd.Flags().StringVar(&getSortTarget, "sort-by", "", "sort target; CREATE, KEY, MODIFY, VALUE, or VERSION")
cmd.Flags().Int64Var(&getLimit, "limit", 0, "maximum number of results") cmd.Flags().Int64Var(&getLimit, "limit", 0, "maximum number of results")
cmd.Flags().BoolVar(&getPrefix, "prefix", false, "get keys with matching prefix") cmd.Flags().BoolVar(&getPrefix, "prefix", false, "get keys with matching prefix")
cmd.Flags().BoolVar(&getFromKey, "from-key", false, "get keys that are greater than or equal to the given key") cmd.Flags().BoolVar(&getFromKey, "from-key", false, "get keys that are greater than or equal to the given key")
// TODO: add consistency.
return cmd return cmd
} }
@ -69,6 +70,14 @@ func getGetOp(cmd *cobra.Command, args []string) (string, []clientv3.OpOption) {
} }
opts := []clientv3.OpOption{} opts := []clientv3.OpOption{}
switch getConsistency {
case "s":
opts = append(opts, clientv3.WithSerializable())
case "l":
default:
ExitWithError(ExitBadFeature, fmt.Errorf("unknown consistency flag %q", getConsistency))
}
key := args[0] key := args[0]
if len(args) > 1 { if len(args) > 1 {
if getPrefix || getFromKey { if getPrefix || getFromKey {