Skip to content

Commit

Permalink
workload: fixture create can make table subset
Browse files Browse the repository at this point in the history
The new --only-tables flag allows specifying a subset of the tables in a
workload for creation. This is useful for benchmarking the workload
program itself, as well as creating partial backups of very large
datasets.

Release note: None
  • Loading branch information
jordanlewis committed Mar 5, 2018
1 parent 17576e1 commit 57c267e
Showing 1 changed file with 37 additions and 0 deletions.
37 changes: 37 additions & 0 deletions pkg/cmd/workload/fixtures.go
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,10 @@ var fixturesMakeCSVServerURL = fixturesMakeCmd.PersistentFlags().String(
`csv-server`, ``,
`Skip saving CSVs to cloud storage, instead get them from a 'csv-server' running at this url`)

var fixturesMakeOnlyTable = fixturesMakeCmd.PersistentFlags().String(
`only-tables`, ``,
`Only load the tables with the given comma-separated names`)

// gcs-bucket-override and gcs-prefix-override are exposed for testing.
var gcsBucketOverride, gcsPrefixOverride *string

Expand Down Expand Up @@ -150,6 +154,25 @@ func fixturesList(_ *cobra.Command, _ []string) error {
return nil
}

type filteringGenerator struct {
gen workload.Generator
filter map[string]struct{}
}

func (f filteringGenerator) Meta() workload.Meta {
return f.gen.Meta()
}

func (f filteringGenerator) Tables() []workload.Table {
ret := make([]workload.Table, 0)
for _, t := range f.gen.Tables() {
if _, ok := f.filter[t.Name]; ok {
ret = append(ret, t)
}
}
return ret
}

func fixturesMake(gen workload.Generator, urls []string, dbName string) error {
ctx := context.Background()
gcs, err := getStorage(ctx)
Expand All @@ -162,6 +185,20 @@ func fixturesMake(gen workload.Generator, urls []string, dbName string) error {
if err != nil {
return err
}
if *fixturesMakeOnlyTable != "" {
tableNames := strings.Split(*fixturesMakeOnlyTable, ",")
if len(tableNames) == 0 {
return errors.New("no table names specified")
}
filter := make(map[string]struct{}, len(tableNames))
for _, tableName := range tableNames {
filter[tableName] = struct{}{}
}
gen = filteringGenerator{
gen: gen,
filter: filter,
}
}
fixture, err := workloadccl.MakeFixture(ctx, sqlDB, gcs, config(), gen)
if err != nil {
return err
Expand Down

0 comments on commit 57c267e

Please sign in to comment.