Skip to content

Commit

Permalink
roachtest: fix release-20.1 roachtests failing due to double-init
Browse files Browse the repository at this point in the history
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
  • Loading branch information
irfansharif committed Jul 28, 2020
1 parent 7e36e68 commit d1ddaf5
Show file tree
Hide file tree
Showing 2 changed files with 40 additions and 0 deletions.
36 changes: 36 additions & 0 deletions pkg/cmd/roachprod/install/cockroach.go
Original file line number Diff line number Diff line change
Expand Up @@ -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 {
Expand Down Expand Up @@ -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
}
4 changes: 4 additions & 0 deletions pkg/cmd/roachtest/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -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(
Expand Down

0 comments on commit d1ddaf5

Please sign in to comment.