8518618b7a
* add flags to sotrj-sim for SA dbs * add schema to postgres * add createschema with parse to sa * add metainfo db postgres support * add kv default as bolt * add debug log to see db source * add env var for postgres to test-sim.sh * fix lint errs * dynamically add postgres to args * add postgres to integration tests * add sqlite and postgres integration jenkins * fix db name * merge integration tests into one step * test integration tests w/psql * try using different schema * debug failure * use correct host for running storj-sim * rm sqlite integration * add back integration
111 lines
3.0 KiB
Go
111 lines
3.0 KiB
Go
// Copyright (C) 2019 Storj Labs, Inc.
|
|
// See LICENSE for copying information.
|
|
|
|
package main
|
|
|
|
import (
|
|
"os"
|
|
|
|
"github.com/spf13/cobra"
|
|
|
|
"storj.io/storj/internal/fpath"
|
|
)
|
|
|
|
// Flags contains different flags for commands
|
|
type Flags struct {
|
|
Directory string
|
|
Host string
|
|
|
|
SatelliteCount int
|
|
StorageNodeCount int
|
|
Identities int
|
|
|
|
IsDev bool
|
|
|
|
OnlyEnv bool // only do things necessary for loading env vars
|
|
|
|
// Connection string for the postgres database to use for storj-sim processes
|
|
Postgres string
|
|
}
|
|
|
|
var printCommands bool
|
|
|
|
func main() {
|
|
cobra.EnableCommandSorting = false
|
|
|
|
var flags Flags
|
|
|
|
rootCmd := &cobra.Command{
|
|
Use: "storj-sim",
|
|
Short: "Storj Network Simulator",
|
|
}
|
|
|
|
defaultConfigDir := fpath.ApplicationDir("storj", "local-network")
|
|
configDir := defaultConfigDir
|
|
if os.Getenv("STORJ_NETWORK_DIR") != "" {
|
|
configDir = os.Getenv("STORJ_NETWORK_DIR")
|
|
}
|
|
|
|
rootCmd.PersistentFlags().StringVarP(&flags.Directory, "config-dir", "", configDir, "base project directory")
|
|
rootCmd.PersistentFlags().StringVarP(&flags.Host, "host", "", "127.0.0.1", "host to use for network")
|
|
|
|
rootCmd.PersistentFlags().IntVarP(&flags.SatelliteCount, "satellites", "", 1, "number of satellites to start")
|
|
rootCmd.PersistentFlags().IntVarP(&flags.StorageNodeCount, "storage-nodes", "", 10, "number of storage nodes to start")
|
|
rootCmd.PersistentFlags().IntVarP(&flags.Identities, "identities", "", 10, "number of identities to create")
|
|
|
|
rootCmd.PersistentFlags().BoolVarP(&printCommands, "print-commands", "x", false, "print commands as they are run")
|
|
rootCmd.PersistentFlags().BoolVarP(&flags.IsDev, "dev", "", false, "use configuration values tuned for development")
|
|
|
|
rootCmd.PersistentFlags().StringVarP(&flags.Postgres, "postgres", "", "", "connection string for postgres. If provided, storj-sim will use postgres for all databases that support it.")
|
|
|
|
networkCmd := &cobra.Command{
|
|
Use: "network",
|
|
Short: "local network for testing",
|
|
}
|
|
|
|
networkCmd.AddCommand(
|
|
&cobra.Command{
|
|
Use: "run",
|
|
Short: "run network",
|
|
RunE: func(cmd *cobra.Command, args []string) (err error) {
|
|
return networkExec(&flags, args, "run")
|
|
},
|
|
}, &cobra.Command{
|
|
Use: "env [name]",
|
|
Short: "print environment variables",
|
|
RunE: func(cmd *cobra.Command, args []string) (err error) {
|
|
return networkEnv(&flags, args)
|
|
},
|
|
}, &cobra.Command{
|
|
Use: "setup",
|
|
Short: "setup network",
|
|
RunE: func(cmd *cobra.Command, args []string) (err error) {
|
|
return networkExec(&flags, args, "setup")
|
|
},
|
|
}, &cobra.Command{
|
|
Use: "test <command>",
|
|
Short: "run command with an actual network",
|
|
Args: cobra.MinimumNArgs(1),
|
|
RunE: func(cmd *cobra.Command, args []string) (err error) {
|
|
return networkTest(&flags, args[0], args[1:])
|
|
},
|
|
}, &cobra.Command{
|
|
Use: "destroy",
|
|
Short: "destroys network if it exists",
|
|
RunE: func(cmd *cobra.Command, args []string) (err error) {
|
|
return networkDestroy(&flags, args)
|
|
},
|
|
},
|
|
)
|
|
|
|
rootCmd.AddCommand(
|
|
networkCmd,
|
|
)
|
|
|
|
rootCmd.SilenceUsage = true
|
|
err := rootCmd.Execute()
|
|
if err != nil {
|
|
os.Exit(1)
|
|
}
|
|
}
|