mirror of
https://github.com/dolthub/dolt.git
synced 2026-04-23 13:48:42 -05:00
111 lines
3.0 KiB
Go
111 lines
3.0 KiB
Go
// Copyright 2019-2022 Dolthub, Inc.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
package sysbench_runner
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"os"
|
|
"path/filepath"
|
|
)
|
|
|
|
// Run runs sysbench runner
|
|
func Run(config *Config) error {
|
|
err := config.Validate()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
ctx := context.Background()
|
|
|
|
err = sysbenchVersion(ctx)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
for _, serverConfig := range config.Servers {
|
|
var results Results
|
|
switch serverConfig.Server {
|
|
case Dolt:
|
|
// handle a profiling run
|
|
if serverConfig.ServerProfile != "" {
|
|
fmt.Println("Profiling dolt while running sysbench tests")
|
|
return ProfileDolt(ctx, config, serverConfig)
|
|
}
|
|
fmt.Println("Running dolt sysbench test")
|
|
results, err = BenchmarkDolt(ctx, config, serverConfig)
|
|
case Doltgres:
|
|
fmt.Println("Running doltgres sysbench test")
|
|
results, err = BenchmarkDoltgres(ctx, config, serverConfig)
|
|
case MySql:
|
|
fmt.Println("Running mysql sysbench test")
|
|
results, err = BenchmarkMysql(ctx, config, serverConfig)
|
|
case Postgres:
|
|
fmt.Println("Running postgres sysbench test")
|
|
results, err = BenchmarkPostgres(ctx, config, serverConfig)
|
|
default:
|
|
panic(fmt.Sprintf("unexpected server type: %s", serverConfig.Server))
|
|
}
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
fmt.Printf("Successfuly finished %s\n", serverConfig.Server)
|
|
|
|
err = WriteResults(serverConfig, results)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
fmt.Printf("Successfuly wrote results for %s\n", serverConfig.Server)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func sysbenchVersion(ctx context.Context) error {
|
|
sysbenchVersion := ExecCommand(ctx, "sysbench", "--version")
|
|
return sysbenchVersion.Run()
|
|
}
|
|
|
|
func WriteResults(serverConfig *ServerConfig, results Results) error {
|
|
cwd, err := os.Getwd()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
var writePath string
|
|
switch serverConfig.ResultsFormat {
|
|
case CsvFormat, CsvExt:
|
|
writePath = filepath.Join(
|
|
cwd,
|
|
"results",
|
|
string(serverConfig.Server),
|
|
serverConfig.Version,
|
|
serverConfig.GetId(),
|
|
fmt.Sprintf(ResultFileTemplate, serverConfig.GetId(), serverConfig.Server, serverConfig.Version, CsvExt))
|
|
return WriteResultsCsv(writePath, results)
|
|
case JsonFormat, JsonExt:
|
|
writePath = filepath.Join(
|
|
cwd,
|
|
"results",
|
|
string(serverConfig.Server),
|
|
serverConfig.Version,
|
|
serverConfig.GetId(),
|
|
fmt.Sprintf(ResultFileTemplate, serverConfig.GetId(), serverConfig.Server, serverConfig.Version, JsonExt))
|
|
return WriteResultsJson(writePath, results)
|
|
default:
|
|
}
|
|
return fmt.Errorf("unsupported results format: %s", serverConfig.ResultsFormat)
|
|
}
|