2024-05-29 09:47:09 +00:00
|
|
|
package test_helpers
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/jmoiron/sqlx"
|
|
|
|
)
|
|
|
|
|
|
|
|
// ClearDB is used to empty the IPLD-ETH tables after tests
|
|
|
|
func ClearDB(db *sqlx.DB) error {
|
|
|
|
tx, err := db.Beginx()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
statements := []string{
|
|
|
|
`TRUNCATE nodes`,
|
|
|
|
`TRUNCATE ipld.blocks`,
|
|
|
|
`TRUNCATE eth.header_cids`,
|
|
|
|
`TRUNCATE eth.uncle_cids`,
|
|
|
|
`TRUNCATE eth.transaction_cids`,
|
|
|
|
`TRUNCATE eth.receipt_cids`,
|
|
|
|
`TRUNCATE eth.state_cids`,
|
|
|
|
`TRUNCATE eth.storage_cids`,
|
|
|
|
`TRUNCATE eth.log_cids`,
|
2024-06-28 09:44:58 +00:00
|
|
|
`TRUNCATE eth.withdrawal_cids`,
|
2024-05-29 09:47:09 +00:00
|
|
|
`TRUNCATE eth_meta.watched_addresses`,
|
|
|
|
}
|
|
|
|
for _, stm := range statements {
|
|
|
|
if _, err = tx.Exec(stm); err != nil {
|
|
|
|
return fmt.Errorf("error executing `%s`: %w", stm, err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return tx.Commit()
|
|
|
|
}
|