aboutsummaryrefslogtreecommitdiffstats
path: root/syz-cluster/tools/db-mgmt/main.go
blob: b5ba3b341dc9c39111bf331df6cc54fd0f68ec38 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
// Copyright 2024 syzkaller project authors. All rights reserved.
// Use of this source code is governed by Apache 2 LICENSE that can be found in the LICENSE file.

package main

import (
	"context"
	"fmt"
	"log"
	"os"

	"cloud.google.com/go/spanner"
	"github.com/google/syzkaller/syz-cluster/pkg/app"
	"github.com/google/syzkaller/syz-cluster/pkg/db"
	"google.golang.org/api/iterator"
)

func runSQL(ctx context.Context, uri db.ParsedURI, command string) error {
	client, err := spanner.NewClient(ctx, uri.Full)
	if err != nil {
		return err
	}
	defer client.Close()
	stmt := spanner.Statement{SQL: command}
	iter := client.Single().Query(ctx, stmt)
	defer iter.Stop()

	for {
		row, err := iter.Next()
		if err == iterator.Done {
			break
		}
		if err != nil {
			return err
		}
		cols := row.ColumnNames()
		fmt.Println(cols)
		for i := 0; i < len(cols); i++ {
			fmt.Printf("\t%s", row.ColumnValue(i))
		}
		fmt.Printf("\n")
	}
	return nil
}

func main() {
	ctx := context.Background()
	uri, err := app.DefaultSpannerURI()
	if err != nil {
		app.Fatalf("failed to get Spanner URI: %v", err)
	}
	if os.Getenv("SPANNER_EMULATOR_HOST") != "" {
		// Should only be done in the test/dev environment.
		log.Printf("check if a Spanner instance is present")
		err = db.CreateSpannerInstance(ctx, uri)
		if err != nil {
			app.Fatalf("failed to create Spanner instance: %v", err)
		}
	}
	log.Printf("check if DB is present")
	err = db.CreateSpannerDB(ctx, uri, nil)
	if err != nil {
		app.Fatalf("failed to create Spanner DB: %v", err)
	}
	if len(os.Args) > 1 {
		switch os.Args[1] {
		case "migrate":
			log.Printf("running schema migrations")
			err = db.RunMigrations(uri.Full)
		case "run":
			if len(os.Args) < 3 {
				app.Fatalf("second argument is the SQL query to run")
			}
			err = runSQL(ctx, uri, os.Args[2])
		default:
			app.Fatalf("unknown command: %s", os.Args[1])
		}
		if err != nil {
			log.Fatal(err)
		}
	}
	log.Printf("finished!")
}