Skip to content

Commit

Permalink
changefeedccl: add webhook-chaos roachtest
Browse files Browse the repository at this point in the history
Add new webhook-chaos roachtest with order validation.

Epic: CRDB-38755
Part of: cockroachdb#124148

Release note: none
  • Loading branch information
asg0451 committed Jul 18, 2024
1 parent eccb77d commit c7ee5f9
Show file tree
Hide file tree
Showing 3 changed files with 374 additions and 102 deletions.
32 changes: 32 additions & 0 deletions pkg/cmd/roachtest/cluster.go
Original file line number Diff line number Diff line change
Expand Up @@ -2032,6 +2032,38 @@ func (c *clusterImpl) Get(
return errors.Wrap(roachprod.Get(ctx, l, c.MakeNodes(opts...), src, dest), "cluster.Get")
}

// Tail tails files from remote hosts asynchronously.
func (c *clusterImpl) Tail(
ctx context.Context, l *logger.Logger, src string, opts ...option.Option,
) (stdout io.ReadCloser, errChan chan error, err error) {
if ctx.Err() != nil {
return nil, nil, ctx.Err()
}
c.status(fmt.Sprintf("tailing %v", src))
defer c.status("")
errChan = make(chan error, 1)
stdoutRead, stdoutWrite := io.Pipe()
go func() {
defer close(errChan)
defer func() { _ = stdoutWrite.Close() }()
var err error
defer l.Printf("stopped tailing %v: %v", src, err)
err = roachprod.Run(ctx, l, c.MakeNodes(opts...), "", "", false, stdoutWrite, io.Discard, []string{fmt.Sprintf("tail -F %s", src)}, install.RunOptions{})
if err != nil && ctx.Err() == nil {
errChan <- err
}
}()

// Close the pipe when the context is canceled.
go func() {
<-ctx.Done()
_ = stdoutRead.Close()
}()

c.status(fmt.Sprintf("spawned tail -F %v", src))
return stdoutRead, errChan, nil
}

// PutString into the specified file on the remote(s).
func (c *clusterImpl) PutString(
ctx context.Context, content, dest string, mode os.FileMode, nodes ...option.Option,
Expand Down
2 changes: 2 additions & 0 deletions pkg/cmd/roachtest/cluster/cluster_interface.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ package cluster
import (
"context"
gosql "database/sql"
"io"
"os"

"github.com/cockroachdb/cockroach/pkg/cmd/roachprod/grafana"
Expand Down Expand Up @@ -43,6 +44,7 @@ type Cluster interface {
// Uploading and downloading from/to nodes.

Get(ctx context.Context, l *logger.Logger, src, dest string, opts ...option.Option) error
Tail(ctx context.Context, l *logger.Logger, src string, opts ...option.Option) (stdout io.ReadCloser, errChan chan error, err error)
Put(ctx context.Context, src, dest string, opts ...option.Option)
PutE(ctx context.Context, l *logger.Logger, src, dest string, opts ...option.Option) error
PutLibraries(ctx context.Context, libraryDir string, libraries []string) error
Expand Down
Loading

0 comments on commit c7ee5f9

Please sign in to comment.