etcd_release_upgrade_test.go 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. // Copyright 2016 The etcd Authors
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package e2e
  15. import (
  16. "fmt"
  17. "os"
  18. "testing"
  19. "time"
  20. "github.com/coreos/etcd/pkg/fileutil"
  21. "github.com/coreos/etcd/pkg/testutil"
  22. )
  23. // TestReleaseUpgrade ensures that changes to master branch does not affect
  24. // upgrade from latest etcd releases.
  25. func TestReleaseUpgrade(t *testing.T) {
  26. lastReleaseBinary := "../bin/etcd-last-release"
  27. if !fileutil.Exist(lastReleaseBinary) {
  28. t.Skipf("%q does not exist", lastReleaseBinary)
  29. }
  30. defer testutil.AfterTest(t)
  31. copiedCfg := configNoTLS
  32. copiedCfg.execPath = lastReleaseBinary
  33. copiedCfg.snapCount = 3
  34. copiedCfg.baseScheme = "unix" // to avoid port conflict
  35. epc, err := newEtcdProcessCluster(&copiedCfg)
  36. if err != nil {
  37. t.Fatalf("could not start etcd process cluster (%v)", err)
  38. }
  39. defer func() {
  40. if errC := epc.Close(); errC != nil {
  41. t.Fatalf("error closing etcd processes (%v)", errC)
  42. }
  43. }()
  44. os.Setenv("ETCDCTL_API", "3")
  45. defer os.Unsetenv("ETCDCTL_API")
  46. cx := ctlCtx{
  47. t: t,
  48. cfg: configNoTLS,
  49. dialTimeout: 7 * time.Second,
  50. quorum: true,
  51. epc: epc,
  52. }
  53. var kvs []kv
  54. for i := 0; i < 5; i++ {
  55. kvs = append(kvs, kv{key: fmt.Sprintf("foo%d", i), val: "bar"})
  56. }
  57. for i := range kvs {
  58. if err := ctlV3Put(cx, kvs[i].key, kvs[i].val, ""); err != nil {
  59. cx.t.Fatalf("#%d: ctlV3Put error (%v)", i, err)
  60. }
  61. }
  62. for i := range epc.procs {
  63. if err := epc.procs[i].Stop(); err != nil {
  64. t.Fatalf("#%d: error closing etcd process (%v)", i, err)
  65. }
  66. epc.procs[i].cfg.execPath = "../bin/etcd"
  67. epc.procs[i].cfg.keepDataDir = true
  68. if err := epc.procs[i].Restart(); err != nil {
  69. t.Fatalf("error restarting etcd process (%v)", err)
  70. }
  71. for j := range kvs {
  72. if err := ctlV3Get(cx, []string{kvs[j].key}, []kv{kvs[j]}...); err != nil {
  73. cx.t.Fatalf("#%d-%d: ctlV3Get error (%v)", i, j, err)
  74. }
  75. }
  76. }
  77. }