2019-02-11 10:08:24 +00:00
|
|
|
// VulcanizeDB
|
2019-03-12 15:46:42 +00:00
|
|
|
// Copyright © 2019 Vulcanize
|
2019-02-11 10:08:24 +00:00
|
|
|
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU Affero General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU Affero General Public License for more details.
|
|
|
|
|
|
|
|
// You should have received a copy of the GNU Affero General Public License
|
|
|
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
2019-01-25 08:59:23 +00:00
|
|
|
package test_helpers
|
|
|
|
|
|
|
|
import (
|
2019-02-18 11:23:36 +00:00
|
|
|
"fmt"
|
2019-01-25 08:59:23 +00:00
|
|
|
"github.com/ethereum/go-ethereum/ethclient"
|
|
|
|
"github.com/ethereum/go-ethereum/rpc"
|
|
|
|
. "github.com/onsi/gomega"
|
|
|
|
|
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/config"
|
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/core"
|
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/datastore/postgres"
|
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/geth"
|
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/geth/client"
|
|
|
|
rpc2 "github.com/vulcanize/vulcanizedb/pkg/geth/converters/rpc"
|
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/geth/node"
|
|
|
|
)
|
|
|
|
|
2019-02-28 14:59:04 +00:00
|
|
|
// TODO: consider whether this should be moved to libraries/shared
|
2019-01-25 08:59:23 +00:00
|
|
|
func SetupDBandBC() (*postgres.DB, core.BlockChain) {
|
|
|
|
infuraIPC := "http://kovan0.vulcanize.io:8545"
|
|
|
|
rawRpcClient, err := rpc.Dial(infuraIPC)
|
|
|
|
Expect(err).NotTo(HaveOccurred())
|
|
|
|
rpcClient := client.NewRpcClient(rawRpcClient, infuraIPC)
|
|
|
|
ethClient := ethclient.NewClient(rawRpcClient)
|
|
|
|
blockChainClient := client.NewEthClient(ethClient)
|
2019-02-28 14:59:04 +00:00
|
|
|
blockChainNode := node.MakeNode(rpcClient)
|
2019-01-25 08:59:23 +00:00
|
|
|
transactionConverter := rpc2.NewRpcTransactionConverter(ethClient)
|
2019-02-28 14:59:04 +00:00
|
|
|
blockChain := geth.NewBlockChain(blockChainClient, rpcClient, blockChainNode, transactionConverter)
|
2019-01-25 08:59:23 +00:00
|
|
|
|
|
|
|
db, err := postgres.NewDB(config.Database{
|
|
|
|
Hostname: "localhost",
|
|
|
|
Name: "vulcanize_private",
|
|
|
|
Port: 5432,
|
|
|
|
}, blockChain.Node())
|
|
|
|
Expect(err).NotTo(HaveOccurred())
|
|
|
|
|
|
|
|
return db, blockChain
|
|
|
|
}
|
|
|
|
|
|
|
|
func TearDown(db *postgres.DB) {
|
2019-03-14 21:49:27 +00:00
|
|
|
tx, err := db.Beginx()
|
2019-01-25 08:59:23 +00:00
|
|
|
Expect(err).NotTo(HaveOccurred())
|
|
|
|
|
|
|
|
_, err = tx.Exec(`DELETE FROM headers`)
|
|
|
|
Expect(err).NotTo(HaveOccurred())
|
|
|
|
|
|
|
|
_, err = tx.Exec(`DELETE FROM logs`)
|
|
|
|
Expect(err).NotTo(HaveOccurred())
|
|
|
|
|
|
|
|
_, err = tx.Exec(`DELETE FROM log_filters`)
|
|
|
|
Expect(err).NotTo(HaveOccurred())
|
|
|
|
|
2019-03-19 19:11:26 +00:00
|
|
|
_, err = tx.Exec(`DELETE FROM full_sync_transactions`)
|
2019-01-25 08:59:23 +00:00
|
|
|
Expect(err).NotTo(HaveOccurred())
|
|
|
|
|
|
|
|
_, err = tx.Exec(`DELETE FROM receipts`)
|
|
|
|
Expect(err).NotTo(HaveOccurred())
|
|
|
|
|
|
|
|
_, err = tx.Exec(`DELETE FROM checked_headers`)
|
|
|
|
Expect(err).NotTo(HaveOccurred())
|
|
|
|
|
2019-02-13 21:00:09 +00:00
|
|
|
err = tx.Commit()
|
2019-01-25 08:59:23 +00:00
|
|
|
Expect(err).NotTo(HaveOccurred())
|
2019-02-13 21:00:09 +00:00
|
|
|
}
|
2019-01-25 08:59:23 +00:00
|
|
|
|
2019-02-18 11:23:36 +00:00
|
|
|
func DropTestSchema(db *postgres.DB, schema string) {
|
|
|
|
_, err := db.Exec(fmt.Sprintf(`DROP SCHEMA IF EXISTS %s CASCADE`, schema))
|
2019-01-25 08:59:23 +00:00
|
|
|
Expect(err).NotTo(HaveOccurred())
|
|
|
|
}
|