| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- package migrate
- import (
- "fmt"
- "net/url"
- "reflect"
- "testing"
- "time"
- "github.com/coreos/etcd/etcdserver"
- )
- func TestNewCommand(t *testing.T) {
- entries, err := DecodeLog4FromFile("fixtures/cmdlog")
- if err != nil {
- t.Errorf("read log file error: %v", err)
- }
- zeroTime, err := time.Parse(time.RFC3339, "1969-12-31T16:00:00-08:00")
- if err != nil {
- t.Errorf("couldn't create time: %v", err)
- }
- m := etcdserver.NewMember("alice", []url.URL{{Scheme: "http", Host: "127.0.0.1:7001"}}, etcdDefaultClusterName, nil)
- m.ClientURLs = []string{"http://127.0.0.1:4001"}
- tests := []interface{}{
- &JoinCommand{"alice", "http://127.0.0.1:7001", "http://127.0.0.1:4001", *m},
- &NOPCommand{},
- &NOPCommand{},
- &RemoveCommand{"alice", 0xe52ada62956ff923},
- &CompareAndDeleteCommand{"foo", "baz", 9},
- &CompareAndSwapCommand{"foo", "bar", zeroTime, "baz", 9},
- &CreateCommand{"foo", "bar", zeroTime, true, true},
- &DeleteCommand{"foo", true, true},
- &SetCommand{"foo", "bar", zeroTime, true},
- &SyncCommand{zeroTime},
- &UpdateCommand{"foo", "bar", zeroTime},
- }
- raftMap := make(map[string]uint64)
- for i, test := range tests {
- e := entries[i]
- cmd, err := NewCommand4(e.GetCommandName(), e.GetCommand(), raftMap)
- if err != nil {
- t.Errorf("#%d: %v", i, err)
- continue
- }
- if !reflect.DeepEqual(cmd, test) {
- if i == 5 {
- fmt.Println(cmd.(*CompareAndSwapCommand).ExpireTime.Location())
- }
- t.Errorf("#%d: cmd = %+v, want %+v", i, cmd, test)
- }
- }
- }
|