2018-11-07 21:50:43 +00:00
|
|
|
// VulcanizeDB
|
|
|
|
// Copyright © 2018 Vulcanize
|
|
|
|
|
|
|
|
// 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/>.
|
2018-05-05 20:25:54 +00:00
|
|
|
|
2018-09-19 03:15:49 +00:00
|
|
|
package dai_test
|
2018-08-28 16:45:31 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
. "github.com/onsi/ginkgo"
|
|
|
|
. "github.com/onsi/gomega"
|
|
|
|
|
|
|
|
"github.com/vulcanize/vulcanizedb/examples/erc20_watcher/event_triggered"
|
2018-09-19 03:15:49 +00:00
|
|
|
"github.com/vulcanize/vulcanizedb/examples/erc20_watcher/event_triggered/dai"
|
2018-08-28 21:03:55 +00:00
|
|
|
"github.com/vulcanize/vulcanizedb/examples/generic"
|
|
|
|
"github.com/vulcanize/vulcanizedb/examples/test_helpers"
|
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/core"
|
2018-08-28 16:45:31 +00:00
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/datastore/postgres"
|
2018-11-23 18:12:24 +00:00
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/omni/shared/constants"
|
2018-08-28 16:45:31 +00:00
|
|
|
)
|
|
|
|
|
2018-08-28 21:03:55 +00:00
|
|
|
var transferLog = core.Log{
|
2018-08-28 16:45:31 +00:00
|
|
|
BlockNumber: 5488076,
|
|
|
|
Address: constants.DaiContractAddress,
|
|
|
|
TxHash: "0x135391a0962a63944e5908e6fedfff90fb4be3e3290a21017861099bad6546ae",
|
2018-08-28 21:03:55 +00:00
|
|
|
Index: 110,
|
2018-08-28 16:45:31 +00:00
|
|
|
Topics: [4]string{
|
2018-08-31 19:48:43 +00:00
|
|
|
constants.TransferEvent.Signature(),
|
2018-08-28 21:03:55 +00:00
|
|
|
"0x000000000000000000000000000000000000000000000000000000000000af21",
|
2018-08-28 16:45:31 +00:00
|
|
|
"0x9dd48110dcc444fdc242510c09bbbbe21a5975cac061d82f7b843bce061ba391",
|
2018-08-28 21:03:55 +00:00
|
|
|
"",
|
2018-08-28 16:45:31 +00:00
|
|
|
},
|
|
|
|
Data: "0x000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc200000000000000000000000089d24a6b4ccb1b6faa2625fe562bdd9a23260359000000000000000000000000000000000000000000000000392d2e2bda9c00000000000000000000000000000000000000000000000000927f41fa0a4a418000000000000000000000000000000000000000000000000000000000005adcfebe",
|
|
|
|
}
|
|
|
|
|
2018-08-28 21:03:55 +00:00
|
|
|
var approvalLog = core.Log{
|
|
|
|
BlockNumber: 5488076,
|
|
|
|
Address: constants.DaiContractAddress,
|
|
|
|
TxHash: "0x135391a0962a63944e5908e6fedfff90fb4be3e3290a21017861099bad6546ae",
|
|
|
|
Index: 110,
|
|
|
|
Topics: [4]string{
|
2018-08-31 19:48:43 +00:00
|
|
|
constants.ApprovalEvent.Signature(),
|
2018-08-28 21:03:55 +00:00
|
|
|
"0x000000000000000000000000000000000000000000000000000000000000af21",
|
|
|
|
"0x9dd48110dcc444fdc242510c09bbbbe21a5975cac061d82f7b843bce061ba391",
|
|
|
|
"",
|
|
|
|
},
|
|
|
|
Data: "0x000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc200000000000000000000000089d24a6b4ccb1b6faa2625fe562bdd9a23260359000000000000000000000000000000000000000000000000392d2e2bda9c00000000000000000000000000000000000000000000000000927f41fa0a4a418000000000000000000000000000000000000000000000000000000000005adcfebe",
|
2018-08-28 16:45:31 +00:00
|
|
|
}
|
|
|
|
|
2018-08-28 21:03:55 +00:00
|
|
|
//converted transfer to assert against
|
2018-08-28 16:45:31 +00:00
|
|
|
var logs = []core.Log{
|
2018-08-28 21:03:55 +00:00
|
|
|
transferLog,
|
|
|
|
approvalLog,
|
2018-08-28 16:45:31 +00:00
|
|
|
{
|
|
|
|
BlockNumber: 0,
|
|
|
|
TxHash: "",
|
|
|
|
Address: "",
|
|
|
|
Topics: core.Topics{},
|
|
|
|
Index: 0,
|
|
|
|
Data: "",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
var _ = Describe("Integration test with vulcanizedb", func() {
|
|
|
|
var db *postgres.DB
|
2018-09-19 17:22:05 +00:00
|
|
|
var blk core.BlockChain
|
2018-08-28 16:45:31 +00:00
|
|
|
|
|
|
|
BeforeEach(func() {
|
2018-08-31 19:48:43 +00:00
|
|
|
db = test_helpers.SetupIntegrationDB(db, logs)
|
2018-08-28 16:45:31 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
AfterEach(func() {
|
2018-08-31 19:48:43 +00:00
|
|
|
db = test_helpers.TearDownIntegrationDB(db)
|
2018-08-28 16:45:31 +00:00
|
|
|
})
|
|
|
|
|
2018-08-31 19:48:43 +00:00
|
|
|
It("creates token_transfers entry for each Transfer event received", func() {
|
2018-09-19 17:22:05 +00:00
|
|
|
transformer, err := dai.NewTransformer(db, blk, generic.DaiConfig)
|
2018-08-31 19:48:43 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
2018-08-28 16:45:31 +00:00
|
|
|
|
|
|
|
transformer.Execute()
|
|
|
|
|
|
|
|
var count int
|
2018-08-31 19:48:43 +00:00
|
|
|
err = db.QueryRow(`SELECT COUNT(*) FROM token_transfers`).Scan(&count)
|
2018-08-28 16:45:31 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(count).To(Equal(1))
|
|
|
|
|
2018-08-31 19:48:43 +00:00
|
|
|
transfer := event_triggered.TransferModel{}
|
|
|
|
|
|
|
|
err = db.Get(&transfer, `SELECT
|
|
|
|
token_name,
|
|
|
|
token_address,
|
|
|
|
to_address,
|
|
|
|
from_address,
|
|
|
|
tokens,
|
|
|
|
block,
|
|
|
|
tx
|
|
|
|
FROM token_transfers WHERE block=$1`, logs[0].BlockNumber)
|
2018-08-28 21:03:55 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
2018-08-31 19:48:43 +00:00
|
|
|
Expect(transfer).To(Equal(expectedTransferModel))
|
2018-08-28 21:03:55 +00:00
|
|
|
})
|
|
|
|
|
2018-08-31 19:48:43 +00:00
|
|
|
It("creates token_approvals entry for each Approval event received", func() {
|
2018-09-19 17:22:05 +00:00
|
|
|
transformer, err := dai.NewTransformer(db, blk, generic.DaiConfig)
|
2018-08-31 19:48:43 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
2018-08-28 21:03:55 +00:00
|
|
|
|
|
|
|
transformer.Execute()
|
|
|
|
|
|
|
|
var count int
|
2018-08-31 19:48:43 +00:00
|
|
|
err = db.QueryRow(`SELECT COUNT(*) FROM token_approvals`).Scan(&count)
|
2018-08-28 21:03:55 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(count).To(Equal(1))
|
|
|
|
|
2018-08-31 19:48:43 +00:00
|
|
|
approval := event_triggered.ApprovalModel{}
|
|
|
|
|
|
|
|
err = db.Get(&approval, `SELECT
|
|
|
|
token_name,
|
|
|
|
token_address,
|
|
|
|
owner,
|
|
|
|
spender,
|
|
|
|
tokens,
|
|
|
|
block,
|
|
|
|
tx
|
|
|
|
FROM token_approvals WHERE block=$1`, logs[0].BlockNumber)
|
2018-08-28 16:45:31 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
2018-08-31 19:48:43 +00:00
|
|
|
Expect(approval).To(Equal(expectedApprovalModel))
|
2018-08-28 16:45:31 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
})
|