mirror of
https://github.com/etcd-io/etcd.git
synced 2024-09-27 06:25:44 +00:00
Merge pull request #2341 from yichengq/326
migrate/starter: fix flag parsing
This commit is contained in:
commit
4228c703a7
@ -353,6 +353,7 @@ func newDefaultClient(tls *TLSInfo) (*http.Client, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type value struct {
|
type value struct {
|
||||||
|
isBoolFlag bool
|
||||||
s string
|
s string
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -363,14 +364,20 @@ func (v *value) Set(s string) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v *value) IsBoolFlag() bool { return true }
|
func (v *value) IsBoolFlag() bool { return v.isBoolFlag }
|
||||||
|
|
||||||
|
type boolFlag interface {
|
||||||
|
flag.Value
|
||||||
|
IsBoolFlag() bool
|
||||||
|
}
|
||||||
|
|
||||||
// parseConfig parses out the input config from cmdline arguments and
|
// parseConfig parses out the input config from cmdline arguments and
|
||||||
// environment variables.
|
// environment variables.
|
||||||
func parseConfig(args []string) (*flag.FlagSet, error) {
|
func parseConfig(args []string) (*flag.FlagSet, error) {
|
||||||
fs := flag.NewFlagSet("full flagset", flag.ContinueOnError)
|
fs := flag.NewFlagSet("full flagset", flag.ContinueOnError)
|
||||||
etcdmain.NewConfig().VisitAll(func(f *flag.Flag) {
|
etcdmain.NewConfig().VisitAll(func(f *flag.Flag) {
|
||||||
fs.Var(&value{}, f.Name, "")
|
_, isBoolFlag := f.Value.(boolFlag)
|
||||||
|
fs.Var(&value{isBoolFlag: isBoolFlag}, f.Name, "")
|
||||||
})
|
})
|
||||||
if err := fs.Parse(args); err != nil {
|
if err := fs.Parse(args); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
70
migrate/starter/starter_test.go
Normal file
70
migrate/starter/starter_test.go
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
// Copyright 2015 CoreOS, Inc.
|
||||||
|
//
|
||||||
|
// 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 starter
|
||||||
|
|
||||||
|
import (
|
||||||
|
"flag"
|
||||||
|
"reflect"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestParseConfig(t *testing.T) {
|
||||||
|
tests := []struct {
|
||||||
|
args []string
|
||||||
|
wvals map[string]string
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
[]string{"--name", "etcd", "--data-dir", "dir"},
|
||||||
|
map[string]string{
|
||||||
|
"name": "etcd",
|
||||||
|
"data-dir": "dir",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
[]string{"--name=etcd", "--data-dir=dir"},
|
||||||
|
map[string]string{
|
||||||
|
"name": "etcd",
|
||||||
|
"data-dir": "dir",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
[]string{"--version", "--name", "etcd"},
|
||||||
|
map[string]string{
|
||||||
|
"version": "true",
|
||||||
|
"name": "etcd",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
[]string{"--version=true", "--name", "etcd"},
|
||||||
|
map[string]string{
|
||||||
|
"version": "true",
|
||||||
|
"name": "etcd",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
for i, tt := range tests {
|
||||||
|
fs, err := parseConfig(tt.args)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("#%d: unexpected parseConfig error: %v", i, err)
|
||||||
|
}
|
||||||
|
vals := make(map[string]string)
|
||||||
|
fs.Visit(func(f *flag.Flag) {
|
||||||
|
vals[f.Name] = f.Value.String()
|
||||||
|
})
|
||||||
|
if !reflect.DeepEqual(vals, tt.wvals) {
|
||||||
|
t.Errorf("#%d: vals = %+v, want %+v", i, vals, tt.wvals)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user