|
| 1 | +package chainlink_price_feed |
| 2 | + |
| 3 | +import ( |
| 4 | + "math/big" |
| 5 | + "testing" |
| 6 | + |
| 7 | + "github.com/Gearbox-protocol/sdk-go/core" |
| 8 | + "github.com/Gearbox-protocol/sdk-go/core/schemas" |
| 9 | + "github.com/Gearbox-protocol/sdk-go/utils" |
| 10 | + "github.com/Gearbox-protocol/third-eye/ds" |
| 11 | + "github.com/ethereum/go-ethereum/common" |
| 12 | + "github.com/ethereum/go-ethereum/core/types" |
| 13 | +) |
| 14 | + |
| 15 | +type OnLogsChecker struct { |
| 16 | + ds.DummyRepo |
| 17 | + pfs []*schemas.PriceFeed |
| 18 | +} |
| 19 | + |
| 20 | +func (x *OnLogsChecker) AddPriceFeed(pf *schemas.PriceFeed) { |
| 21 | + x.pfs = append(x.pfs, pf) |
| 22 | +} |
| 23 | +func TestOnLogs(t *testing.T) { |
| 24 | + validPf := &schemas.PriceFeed{ |
| 25 | + Feed: utils.RandomAddr(), |
| 26 | + Token: utils.RandomAddr(), |
| 27 | + BlockNumber: 1, |
| 28 | + PriceBI: (*core.BigInt)(big.NewInt(222)), |
| 29 | + RoundId: 3, |
| 30 | + } |
| 31 | + repo := &OnLogsChecker{} |
| 32 | + obj := &ChainlinkPriceFeed{SyncAdapter: &ds.SyncAdapter{ |
| 33 | + Repo: repo, |
| 34 | + SyncAdapterSchema: &schemas.SyncAdapterSchema{ |
| 35 | + Contract: &schemas.Contract{ |
| 36 | + Address: validPf.Feed, |
| 37 | + }, |
| 38 | + Details: core.Json{"token": validPf.Token}, |
| 39 | + }, |
| 40 | + }} |
| 41 | + txLogs := []types.Log{ |
| 42 | + { |
| 43 | + BlockNumber: 1, |
| 44 | + Index: 1, |
| 45 | + Topics: []common.Hash{ |
| 46 | + core.Topic("AnswerUpdated(int256,uint256,uint256)"), |
| 47 | + common.BytesToHash([]byte{1}), |
| 48 | + common.BytesToHash([]byte{1}), |
| 49 | + }, |
| 50 | + }, |
| 51 | + { |
| 52 | + BlockNumber: uint64(validPf.BlockNumber), |
| 53 | + Index: 2, |
| 54 | + Topics: []common.Hash{ |
| 55 | + core.Topic("AnswerUpdated(int256,uint256,uint256)"), |
| 56 | + common.BytesToHash(validPf.PriceBI.Convert().Bytes()), |
| 57 | + common.BytesToHash([]byte{byte(validPf.RoundId)}), |
| 58 | + }, |
| 59 | + }, |
| 60 | + } |
| 61 | + obj.OnLogs(txLogs) |
| 62 | + if len(repo.pfs) != 1 || |
| 63 | + repo.pfs[0].BlockNumber != validPf.BlockNumber || |
| 64 | + repo.pfs[0].Feed != validPf.Feed || |
| 65 | + repo.pfs[0].RoundId != validPf.RoundId || |
| 66 | + repo.pfs[0].PriceBI.Cmp(validPf.PriceBI) != 0 { |
| 67 | + t.Fatal(utils.ToJson(repo.pfs)) |
| 68 | + } |
| 69 | +} |
0 commit comments