From 78b584053d7da0f82a42f1810de85a6cbf67c31e Mon Sep 17 00:00:00 2001 From: Anna Shaleva Date: Tue, 19 Apr 2022 18:36:40 +0300 Subject: [PATCH] core: keep Oracle cache always valid and up-to-date --- pkg/core/native/native_test/oracle_test.go | 6 +++++- pkg/core/native/oracle.go | 22 ++++++---------------- 2 files changed, 11 insertions(+), 17 deletions(-) diff --git a/pkg/core/native/native_test/oracle_test.go b/pkg/core/native/native_test/oracle_test.go index 77247f80b..1542d6813 100644 --- a/pkg/core/native/native_test/oracle_test.go +++ b/pkg/core/native/native_test/oracle_test.go @@ -28,10 +28,14 @@ func newOracleClient(t *testing.T) *neotest.ContractInvoker { return newNativeClient(t, nativenames.Oracle) } -func TestGetSetPrice(t *testing.T) { +func TestOracle_GetSetPrice(t *testing.T) { testGetSet(t, newOracleClient(t), "Price", native.DefaultOracleRequestPrice, 1, math.MaxInt64) } +func TestOracle_GetSetPriceCache(t *testing.T) { + testGetSetCache(t, newOracleClient(t), "Price", native.DefaultOracleRequestPrice) +} + func putOracleRequest(t *testing.T, oracleInvoker *neotest.ContractInvoker, url string, filter *string, cb string, userData []byte, gas int64, errStr ...string) { var filtItem interface{} diff --git a/pkg/core/native/oracle.go b/pkg/core/native/oracle.go index 16903397e..25273f60f 100644 --- a/pkg/core/native/oracle.go +++ b/pkg/core/native/oracle.go @@ -47,8 +47,7 @@ type Oracle struct { } type OracleCache struct { - requestPrice int64 - requestPriceChanged bool + requestPrice int64 } const ( @@ -159,11 +158,6 @@ func (o *Oracle) OnPersist(ic *interop.Context) error { // PostPersist represents `postPersist` method. func (o *Oracle) PostPersist(ic *interop.Context) error { p := o.getPriceInternal(ic.DAO) - cache := ic.DAO.Store.GetRWCache(o.ID).(*OracleCache) - if cache.requestPriceChanged { - cache.requestPrice = p - cache.requestPriceChanged = false - } var nodes keys.PublicKeys var reward []big.Int @@ -238,9 +232,9 @@ func (o *Oracle) Initialize(ic *interop.Context) error { setIntWithKey(o.ID, ic.DAO, prefixRequestID, 0) setIntWithKey(o.ID, ic.DAO, prefixRequestPrice, DefaultOracleRequestPrice) - cache := &OracleCache{} - cache.requestPrice = int64(DefaultOracleRequestPrice) - cache.requestPriceChanged = false + cache := &OracleCache{ + requestPrice: int64(DefaultOracleRequestPrice), + } ic.DAO.Store.SetCache(o.ID, cache) return nil } @@ -248,7 +242,6 @@ func (o *Oracle) Initialize(ic *interop.Context) error { func (o *Oracle) InitializeCache(d *dao.Simple) { cache := &OracleCache{} cache.requestPrice = getIntWithKey(o.ID, d, prefixRequestPrice) - cache.requestPriceChanged = false d.Store.SetCache(o.ID, cache) } @@ -467,10 +460,7 @@ func (o *Oracle) getPrice(ic *interop.Context, _ []stackitem.Item) stackitem.Ite func (o *Oracle) getPriceInternal(d *dao.Simple) int64 { cache := d.Store.GetROCache(o.ID).(*OracleCache) - if !cache.requestPriceChanged { - return cache.requestPrice - } - return getIntWithKey(o.ID, d, prefixRequestPrice) + return cache.requestPrice } func (o *Oracle) setPrice(ic *interop.Context, args []stackitem.Item) stackitem.Item { @@ -483,7 +473,7 @@ func (o *Oracle) setPrice(ic *interop.Context, args []stackitem.Item) stackitem. } setIntWithKey(o.ID, ic.DAO, prefixRequestPrice, price.Int64()) cache := ic.DAO.Store.GetRWCache(o.ID).(*OracleCache) - cache.requestPriceChanged = true + cache.requestPrice = price.Int64() return stackitem.Null{} }