From d1ddaf5403405685463580cb8f5a6f7f2c90db9a Mon Sep 17 00:00:00 2001 From: irfan sharif Date: Tue, 28 Jul 2020 18:20:23 -0400 Subject: [PATCH] roachtest: fix release-20.1 roachtests failing due to double-init Fixes #51965 (and all referencing issues). Roachprod clusters running v20.1+ crdb nodes persist this `cluster-bootstrapped` file on disk after explicitly bootstrapping the cluster. Roachprod then uses the existence of this file to avoid doubly bootstrapping the cluster. Given #51897 remains unresolved, master-built roachprod is used to run roachtests against the 20.1 branch. Some of those roachtests test mixed-version clusters that start off at 19.2. Consequently, we manually add this file where roachprod expects to find it for already-initialized clusters. (This is a pretty gross hack, that we should address by addressing #51897.) Release note: None --- pkg/cmd/roachprod/install/cockroach.go | 36 ++++++++++++++++++++++++++ pkg/cmd/roachtest/main.go | 4 +++ 2 files changed, 40 insertions(+) diff --git a/pkg/cmd/roachprod/install/cockroach.go b/pkg/cmd/roachprod/install/cockroach.go index a14405ae27d9..06666908a2a5 100644 --- a/pkg/cmd/roachprod/install/cockroach.go +++ b/pkg/cmd/roachprod/install/cockroach.go @@ -168,6 +168,26 @@ func (r Cockroach) Start(c *SyncedCluster, extraArgs []string) { } } + if !vers.AtLeast(version.MustParse("v20.1.0")) { + // Given #51897 remains unresolved, master-built roachprod is used + // to run roachtests against the 20.1 branch. Some of those + // roachtests test mixed-version clusters that start off at 19.2. + // Consequently, we manually add this `cluster-bootstrapped` file + // where roachprod expects to find it for already-initialized + // clusters. This is a pretty gross hack, that we should address by + // addressing #51897. + // + // TODO(irfansharif): Remove this once #51897 is resolved. + markBootstrap := fmt.Sprintf("touch %s/%s", h.c.Impl.NodeDir(h.c, nodes[nodeIdx]), "cluster-bootstrapped") + cmdOut, err := h.run(nodeIdx, markBootstrap) + if err != nil { + log.Fatalf("unable to run cmd: %v", err) + } + if cmdOut != "" { + fmt.Println(cmdOut) + } + } + fmt.Printf("%s: setting cluster settings", h.c.Name) clusterSettingsOut, err := h.setClusterSettings(nodeIdx) if err != nil { @@ -622,3 +642,19 @@ func (h *crdbStartHelper) getEnvVars() string { } return buf.String() } + +func (h *crdbStartHelper) run(nodeIdx int, cmd string) (string, error) { + nodes := h.c.ServerNodes() + + sess, err := h.c.newSession(nodes[nodeIdx]) + if err != nil { + return "", err + } + defer sess.Close() + + out, err := sess.CombinedOutput(cmd) + if err != nil { + return "", errors.Wrapf(err, "~ %s\n%s", cmd, out) + } + return strings.TrimSpace(string(out)), nil +} diff --git a/pkg/cmd/roachtest/main.go b/pkg/cmd/roachtest/main.go index 2405784ba278..8e8b8825a826 100644 --- a/pkg/cmd/roachtest/main.go +++ b/pkg/cmd/roachtest/main.go @@ -161,6 +161,10 @@ the test tags. }, } + // TODO(irfansharif): We could remove this by directly running `cockroach + // version` against the binary being tested, instead of what we do today + // which is defaulting to checking the last git release tag present in the + // local checkout. runCmd.Flags().StringVar( &buildTag, "build-tag", "", "build tag (auto-detect if empty)") runCmd.Flags().StringVar(