diff --git a/framework/components/blockchain/blockchain.go b/framework/components/blockchain/blockchain.go index c97c971c0..142ddd31d 100644 --- a/framework/components/blockchain/blockchain.go +++ b/framework/components/blockchain/blockchain.go @@ -21,6 +21,9 @@ type Input struct { // publickey to mint when solana-test-validator starts PublicKey string `toml:"public_key"` ContractsDir string `toml:"contracts_dir"` + // programs to deploy on solana-test-validator start + // a map of program name to program id + SolanaPrograms map[string]string `toml:"solana_programs"` } // Output is a blockchain network output, ChainID and one or more nodes that forms the network diff --git a/framework/components/blockchain/solana.go b/framework/components/blockchain/solana.go index 050b0090e..91fc6f409 100644 --- a/framework/components/blockchain/solana.go +++ b/framework/components/blockchain/solana.go @@ -6,6 +6,7 @@ import ( "os" "path/filepath" "strconv" + "strings" "time" "github.com/docker/docker/api/types/container" @@ -80,6 +81,16 @@ func newSolana(in *Input) (*Output, error) { return nil, err } + flags := []string{} + for k, v := range in.SolanaPrograms { + flags = append(flags, "--upgradeable-program", v, filepath.Join("/programs", k+".so"), in.PublicKey) + } + args := append([]string{ + "--reset", + "--rpc-port", in.Port, + "--mint", in.PublicKey, + }, flags...) + req := testcontainers.ContainerRequest{ AlwaysPullImage: in.PullImage, Image: in.Image, @@ -127,7 +138,7 @@ func newSolana(in *Input) (*Output, error) { FileMode: 0644, }, }, - Entrypoint: []string{"sh", "-c", fmt.Sprintf("mkdir -p /root/.config/solana/cli && solana-test-validator --rpc-port %s --mint %s", in.Port, in.PublicKey)}, + Entrypoint: []string{"sh", "-c", fmt.Sprintf("mkdir -p /root/.config/solana/cli && solana-test-validator %s", strings.Join(args, " "))}, } c, err := testcontainers.GenericContainer(ctx, testcontainers.GenericContainerRequest{