Skip to content

Commit

Permalink
Merge branch 'develop' into CCIP-3570-add-support-for-rmn-in-env-tooling
Browse files Browse the repository at this point in the history
  • Loading branch information
connorwstein authored Oct 8, 2024
2 parents b403a35 + 2931822 commit 4364064
Show file tree
Hide file tree
Showing 17 changed files with 359 additions and 208 deletions.
2 changes: 1 addition & 1 deletion .github/CODEOWNERS
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@

# To be deprecated in Chainlink V3
/core/services/fluxmonitorv2 @smartcontractkit/foundations
/core/services/job @smartcontractkit/ccip
/core/services/job @smartcontractkit/foundations
/core/services/keystore @smartcontractkit/foundations
/core/services/ocr* @smartcontractkit/foundations
/core/services/periodicbackup @smartcontractkit/foundations
Expand Down
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,8 @@ race.*
golangci-lint-output.txt
/golangci-lint/
.covdata
core/services/job/testdata/wasm/testmodule.wasm
core/services/job/testdata/wasm/testmodule.br

# DB state
./db/
Expand Down
28 changes: 18 additions & 10 deletions contracts/src/v0.8/automation/testhelpers/LogUpkeepCounter.sol
Original file line number Diff line number Diff line change
Expand Up @@ -31,13 +31,15 @@ contract LogUpkeepCounter is ILogAutomation {
uint256 public previousPerformBlock;
uint256 public initialBlock;
uint256 public counter;
bool public autoExecution;

constructor(uint256 _testRange) {
testRange = _testRange;
previousPerformBlock = 0;
lastBlock = block.number;
initialBlock = 0;
counter = 0;
autoExecution = true;
}

function start() public {
Expand Down Expand Up @@ -65,16 +67,18 @@ contract LogUpkeepCounter is ILogAutomation {
counter = counter + 1;
previousPerformBlock = lastBlock;
Log memory log = abi.decode(performData, (Log));
if (log.topics[0] == sig1) {
emit Trigger();
} else if (log.topics[0] == sig2) {
emit Trigger(1);
} else if (log.topics[0] == sig3) {
emit Trigger(1, 2);
} else if (log.topics[0] == sig4) {
emit Trigger(1, 2, 3);
} else {
revert("could not find matching sig");
if (autoExecution) {
if (log.topics[0] == sig1) {
emit Trigger();
} else if (log.topics[0] == sig2) {
emit Trigger(1);
} else if (log.topics[0] == sig3) {
emit Trigger(1, 2);
} else if (log.topics[0] == sig4) {
emit Trigger(1, 2, 3);
} else {
revert("could not find matching sig");
}
}
emit PerformingUpkeep(tx.origin, initialBlock, lastBlock, previousPerformBlock, counter);
}
Expand All @@ -92,4 +96,8 @@ contract LogUpkeepCounter is ILogAutomation {
initialBlock = 0;
counter = 0;
}

function setAuto(bool _auto) external {
autoExecution = _auto;
}
}
1 change: 1 addition & 0 deletions core/capabilities/triggers/logevent/service.go
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ type Config struct {
Network string `json:"network"`
LookbackBlocks uint64 `json:"lookbakBlocks"`
PollPeriod uint32 `json:"pollPeriod"`
QueryCount uint64 `json:"queryCount"`
}

func (config Config) Version(capabilityVersion string) string {
Expand Down
7 changes: 6 additions & 1 deletion core/capabilities/triggers/logevent/trigger.go
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,10 @@ func newLogEventTrigger(ctx context.Context,
callbackCh := make(chan capabilities.TriggerResponse, defaultSendChannelBufferSize)
ticker := time.NewTicker(time.Duration(logEventConfig.PollPeriod) * time.Millisecond)

if logEventConfig.QueryCount == 0 {
logEventConfig.QueryCount = 20
}

// Initialise a Log Event Trigger
l := &logEventTrigger{
ch: callbackCh,
Expand Down Expand Up @@ -120,6 +124,7 @@ func (l *logEventTrigger) listen() {
cursor := ""
limitAndSort := query.LimitAndSort{
SortBy: []query.SortBy{query.NewSortByTimestamp(query.Asc)},
Limit: query.Limit{Count: l.logEventConfig.QueryCount},
}
for {
select {
Expand All @@ -134,7 +139,7 @@ func (l *logEventTrigger) listen() {
"startBlockNum", l.startBlockNum,
"cursor", cursor)
if cursor != "" {
limitAndSort.Limit = query.Limit{Cursor: cursor}
limitAndSort.Limit = query.CursorLimit(cursor, query.CursorFollowing, l.logEventConfig.QueryCount)
}
logs, err = l.contractReader.QueryKey(
ctx,
Expand Down

Large diffs are not rendered by default.

Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ keeper_registry_wrapper_2_1: ../../contracts/solc/v0.8.16/KeeperRegistry2_1/Keep
keepers_vrf_consumer: ../../contracts/solc/v0.8.6/KeepersVRFConsumer/KeepersVRFConsumer.abi ../../contracts/solc/v0.8.6/KeepersVRFConsumer/KeepersVRFConsumer.bin fa75572e689c9e84705c63e8dbe1b7b8aa1a8fe82d66356c4873d024bb9166e8
log_emitter: ../../contracts/solc/v0.8.19/LogEmitter/LogEmitter.abi ../../contracts/solc/v0.8.19/LogEmitter/LogEmitter.bin 4b129ab93432c95ff9143f0631323e189887668889e0b36ccccf18a571e41ccf
log_triggered_streams_lookup_wrapper: ../../contracts/solc/v0.8.16/LogTriggeredStreamsLookup/LogTriggeredStreamsLookup.abi ../../contracts/solc/v0.8.16/LogTriggeredStreamsLookup/LogTriggeredStreamsLookup.bin 920fff3b662909f12ed11b47d168036ffa74ad52070a94e2fa26cdad5e428b4e
log_upkeep_counter_wrapper: ../../contracts/solc/v0.8.6/LogUpkeepCounter/LogUpkeepCounter.abi ../../contracts/solc/v0.8.6/LogUpkeepCounter/LogUpkeepCounter.bin 42426bbb83f96dfbe55fc576d6c65020eaeed690e2289cf99b0c4aa810a5f4ec
log_upkeep_counter_wrapper: ../../contracts/solc/v0.8.6/LogUpkeepCounter/LogUpkeepCounter.abi ../../contracts/solc/v0.8.6/LogUpkeepCounter/LogUpkeepCounter.bin 5482033d55eddb653bf580de0cc950db89a329091e085ac4122583df4a9777cd
mock_aggregator_proxy: ../../contracts/solc/v0.8.6/MockAggregatorProxy/MockAggregatorProxy.abi ../../contracts/solc/v0.8.6/MockAggregatorProxy/MockAggregatorProxy.bin b16c108f3dd384c342ddff5e94da7c0a8d39d1be5e3d8f2cf61ecc7f0e50ff42
mock_ethusd_aggregator_wrapper: ../../contracts/solc/v0.8.19/MockETHUSDAggregator/MockETHUSDAggregator.abi ../../contracts/solc/v0.8.19/MockETHUSDAggregator/MockETHUSDAggregator.bin b9b361f502d2aad32311c60ca86b071de93a024ac488bcfa19725d368cd05d61
offchain_aggregator_wrapper: OffchainAggregator/OffchainAggregator.abi - 5c8d6562e94166d4790f1ee6e4321d359d9f7262e6c5452a712b1f1c896f45cf
Expand Down
25 changes: 15 additions & 10 deletions core/services/job/models.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@ import (

commonassets "github.com/smartcontractkit/chainlink-common/pkg/assets"
"github.com/smartcontractkit/chainlink-common/pkg/types"
pkgworkflows "github.com/smartcontractkit/chainlink-common/pkg/workflows"

"github.com/smartcontractkit/chainlink/v2/core/services/relay"

Expand Down Expand Up @@ -865,7 +864,8 @@ type WorkflowSpecType string

const (
YamlSpec WorkflowSpecType = "yaml"
DefaultSpecType = YamlSpec
WASMFile WorkflowSpecType = "wasm_file"
DefaultSpecType = ""
)

type WorkflowSpec struct {
Expand All @@ -879,7 +879,7 @@ type WorkflowSpec struct {
WorkflowName string `toml:"-" db:"workflow_name"` // Derived. Do not modify. the name of the workflow.
CreatedAt time.Time `toml:"-"`
UpdatedAt time.Time `toml:"-"`
SpecType WorkflowSpecType `db:"spec_type"`
SpecType WorkflowSpecType `toml:"spec_type" db:"spec_type"`
sdkWorkflow *sdk.WorkflowSpec
rawSpec []byte
}
Expand All @@ -895,12 +895,8 @@ const (

// Validate checks the workflow spec for correctness
func (w *WorkflowSpec) Validate(ctx context.Context) error {
s, err := pkgworkflows.ParseWorkflowSpecYaml(w.Workflow)
s, err := w.SDKSpec(ctx)
if err != nil {
return fmt.Errorf("%w: failed to parse workflow spec %s: %w", ErrInvalidWorkflowYAMLSpec, w.Workflow, err)
}

if _, err = w.SDKSpec(ctx); err != nil {
return err
}

Expand All @@ -919,7 +915,11 @@ func (w *WorkflowSpec) SDKSpec(ctx context.Context) (sdk.WorkflowSpec, error) {
return *w.sdkWorkflow, nil
}

spec, rawSpec, cid, err := workflowSpecFactory.Spec(ctx, w.Workflow, []byte(w.Config), w.SpecType)
workflowSpecFactory, ok := workflowSpecFactories[w.SpecType]
if !ok {
return sdk.WorkflowSpec{}, fmt.Errorf("unknown spec type %s", w.SpecType)
}
spec, rawSpec, cid, err := workflowSpecFactory.Spec(ctx, w.Workflow, []byte(w.Config))
if err != nil {
return sdk.WorkflowSpec{}, err
}
Expand All @@ -934,7 +934,12 @@ func (w *WorkflowSpec) RawSpec(ctx context.Context) ([]byte, error) {
return w.rawSpec, nil
}

rs, err := workflowSpecFactory.RawSpec(ctx, w.Workflow, w.SpecType)
workflowSpecFactory, ok := workflowSpecFactories[w.SpecType]
if !ok {
return nil, fmt.Errorf("unknown spec type %s", w.SpecType)
}

rs, err := workflowSpecFactory.RawSpec(ctx, w.Workflow, []byte(w.Config))
if err != nil {
return nil, err
}
Expand Down
37 changes: 30 additions & 7 deletions core/services/job/models_test.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
package job
package job_test

import (
_ "embed"
"encoding/json"
"reflect"
"testing"
"time"
Expand All @@ -11,8 +12,10 @@ import (
"github.com/smartcontractkit/chainlink-common/pkg/codec"
"github.com/smartcontractkit/chainlink-common/pkg/types"
pkgworkflows "github.com/smartcontractkit/chainlink-common/pkg/workflows"
"github.com/smartcontractkit/chainlink-common/pkg/workflows/sdk"

"github.com/smartcontractkit/chainlink/v2/core/internal/testutils"
"github.com/smartcontractkit/chainlink/v2/core/services/job"
"github.com/smartcontractkit/chainlink/v2/core/services/relay"

"github.com/stretchr/testify/assert"
Expand All @@ -27,7 +30,7 @@ func TestOCR2OracleSpec_RelayIdentifier(t *testing.T) {
type fields struct {
Relay string
ChainID string
RelayConfig JSONConfig
RelayConfig job.JSONConfig
}
tests := []struct {
name string
Expand Down Expand Up @@ -71,7 +74,7 @@ func TestOCR2OracleSpec_RelayIdentifier(t *testing.T) {
t.Run(tt.name, func(t *testing.T) {
t.Parallel()

s := &OCR2OracleSpec{
s := &job.OCR2OracleSpec{
Relay: tt.fields.Relay,
ChainID: tt.fields.ChainID,
RelayConfig: tt.fields.RelayConfig,
Expand All @@ -96,7 +99,7 @@ var (
)

func TestOCR2OracleSpec(t *testing.T) {
val := OCR2OracleSpec{
val := job.OCR2OracleSpec{
Relay: relay.NetworkEVM,
PluginType: types.Median,
ContractID: "foo",
Expand Down Expand Up @@ -259,13 +262,13 @@ func TestOCR2OracleSpec(t *testing.T) {
})

t.Run("round-trip", func(t *testing.T) {
var gotVal OCR2OracleSpec
var gotVal job.OCR2OracleSpec
require.NoError(t, toml.Unmarshal([]byte(compact), &gotVal))
gotB, err := toml.Marshal(gotVal)
require.NoError(t, err)
require.Equal(t, compact, string(gotB))
t.Run("pretty", func(t *testing.T) {
var gotVal OCR2OracleSpec
var gotVal job.OCR2OracleSpec
require.NoError(t, toml.Unmarshal([]byte(pretty), &gotVal))
gotB, err := toml.Marshal(gotVal)
require.NoError(t, err)
Expand Down Expand Up @@ -321,7 +324,7 @@ func TestWorkflowSpec_Validate(t *testing.T) {
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
w := &WorkflowSpec{
w := &job.WorkflowSpec{
Workflow: tt.fields.Workflow,
}
err := w.Validate(testutils.Context(t))
Expand All @@ -333,4 +336,24 @@ func TestWorkflowSpec_Validate(t *testing.T) {
}
})
}

t.Run("WASM can validate", func(t *testing.T) {
config, err := json.Marshal(sdk.NewWorkflowParams{
Owner: "owner",
Name: "name",
})
require.NoError(t, err)

w := &job.WorkflowSpec{
Workflow: createTestBinary(t),
SpecType: job.WASMFile,
Config: string(config),
}

err = w.Validate(testutils.Context(t))
require.NoError(t, err)
assert.Equal(t, "owner", w.WorkflowOwner)
assert.Equal(t, "name", w.WorkflowName)
require.NotEmpty(t, w.WorkflowID)
})
}
33 changes: 33 additions & 0 deletions core/services/job/testdata/wasm/test_workflow_spec.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
//go:build wasip1

package main

import (
"encoding/json"
"log"

"github.com/smartcontractkit/chainlink-common/pkg/workflows/wasm"

"github.com/smartcontractkit/chainlink-common/pkg/capabilities/cli/cmd/testdata/fixtures/capabilities/basictrigger"
"github.com/smartcontractkit/chainlink-common/pkg/workflows/sdk"
)

func BuildWorkflow(config []byte) *sdk.WorkflowSpecFactory {
params := sdk.NewWorkflowParams{}
if err := json.Unmarshal(config, &params); err != nil {
log.Fatal(err)
}

workflow := sdk.NewWorkflowSpecFactory(params)

triggerCfg := basictrigger.TriggerConfig{Name: "trigger", Number: 100}
_ = triggerCfg.New(workflow)

return workflow
}

func main() {
runner := wasm.NewRunner()
workflow := BuildWorkflow(runner.Config())
runner.Run(workflow)
}
Loading

0 comments on commit 4364064

Please sign in to comment.