Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Keystone e2e test #15182

Open
wants to merge 122 commits into
base: develop
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
122 commits
Select commit Hold shift + click to select a range
36031ed
init, wip
skudasov Oct 17, 2024
5420691
fix go mod
skudasov Oct 17, 2024
fc73619
fix go mod again
skudasov Oct 17, 2024
038b11e
update
skudasov Oct 17, 2024
b7a94b5
fix go mod
skudasov Oct 17, 2024
05b2233
ready to test
skudasov Oct 17, 2024
ab0baf3
update deps
skudasov Oct 17, 2024
0a13f5e
update
skudasov Oct 18, 2024
7d8ffb3
update README
skudasov Oct 18, 2024
dce9c56
fix
skudasov Oct 18, 2024
d6cc825
fix readme
skudasov Oct 18, 2024
9be9a8a
try mockserver in CI
skudasov Oct 21, 2024
dc8fe4d
try reach the localhost mock in CI
skudasov Oct 21, 2024
cc4e526
check it can work both locally and in CI without code modification
skudasov Oct 21, 2024
e0465e6
check again
skudasov Oct 21, 2024
c75d06e
use the same Go version
skudasov Oct 21, 2024
c143938
example of CL client connection
skudasov Oct 21, 2024
85d9973
connect all the clients
skudasov Oct 21, 2024
3111ad8
example with contracts
skudasov Oct 21, 2024
d1ca470
finalize
skudasov Oct 22, 2024
cf1ea62
readmes
skudasov Oct 22, 2024
95c9562
ignore caching, update
skudasov Oct 22, 2024
2674e22
change CI workflow name
skudasov Oct 22, 2024
8e8597a
re-trigger
skudasov Oct 22, 2024
8fd3436
fix readme
skudasov Oct 22, 2024
547f054
switch to v0.1.0
skudasov Oct 23, 2024
7639522
fix go mod
skudasov Oct 23, 2024
d2581b2
use strict config version
skudasov Oct 23, 2024
430f573
update go mod
skudasov Oct 23, 2024
2ddc36c
add Sepolia example
skudasov Oct 23, 2024
81c972f
simplify configuration
skudasov Oct 24, 2024
5a82459
copy capabilities into container
skudasov Oct 24, 2024
f28c64a
expose p2p ports, add Fuji example
skudasov Oct 24, 2024
87beabc
fund nodes
skudasov Oct 24, 2024
29d8b77
use shared PG nodeset
skudasov Oct 25, 2024
db528ae
static node names
skudasov Oct 25, 2024
cde6a27
capabilities perms
skudasov Oct 25, 2024
91aa2a4
capabilities perms again
skudasov Oct 25, 2024
f5a1a79
unified config for one or more node overrides
skudasov Oct 28, 2024
b1145e3
comment config
skudasov Oct 28, 2024
7503510
docker rebuild from config
skudasov Oct 29, 2024
3cd15e1
simplify, explicit rebuild using config, no flags
skudasov Oct 29, 2024
95e45ae
--wip-- [skip CI]
DeividasK Oct 25, 2024
5298829
Fetch node keys and generate OCR3 config
DeividasK Oct 25, 2024
8c942eb
Configure KV store OCR contract
DeividasK Oct 25, 2024
dc0aeb6
--wip-- [skip CI]
DeividasK Oct 29, 2024
9bcf265
Merge
DeividasK Oct 29, 2024
725a5d3
Working capability setup
DeividasK Oct 29, 2024
67e3efa
Deploy mock streams capabilities
DeividasK Oct 31, 2024
3ce6f55
OCR3 not working (incorrect keys)
DeividasK Oct 31, 2024
e2b0887
--wip-- [skip CI]
DeividasK Nov 4, 2024
df8f8d3
OCR3 capability added successfully
DeividasK Nov 4, 2024
1590f69
Target capability configuration
DeividasK Nov 5, 2024
db84b3c
--wip-- [skip CI]
DeividasK Nov 5, 2024
d2f2a73
--wip-- [skip CI]
DeividasK Nov 6, 2024
0881f6a
--wip-- [skip CI]
DeividasK Nov 11, 2024
e0eba92
--wip-- [skip CI]
DeividasK Nov 11, 2024
e6e73fd
--wip-- [skip CI]
DeividasK Nov 11, 2024
5d381df
OCR endpoint initializes
DeividasK Nov 12, 2024
342aae6
fix, use default configs on start and replace config instead overridi…
skudasov Nov 13, 2024
4c4d151
--wip-- [skip CI]
DeividasK Nov 19, 2024
421ebf6
Merge branch 'develop' into dk-keystone-e2e-test
DeividasK Nov 19, 2024
b7fee52
Add workflows
DeividasK Nov 20, 2024
fd9acca
--wip-- [skip CI]
DeividasK Nov 21, 2024
781f6c6
E2E test sets up the environment correctly
DeividasK Nov 22, 2024
6642fee
Cleanup
DeividasK Nov 22, 2024
b7e606d
Cleanup
DeividasK Nov 22, 2024
73caca4
Run the test in CI
DeividasK Nov 22, 2024
64bbe1b
Less logs; increase timeout
DeividasK Nov 22, 2024
0dfdbfc
Reduce timeout
DeividasK Nov 22, 2024
d170c19
Move things around and cleanup
DeividasK Nov 25, 2024
a05205d
Refactor capabiliteis registry evm contract wrapper
DeividasK Nov 25, 2024
a60018e
Update go.mod and tidy
DeividasK Nov 25, 2024
f892377
Update CI config
DeividasK Nov 25, 2024
5a47543
Cleanup
DeividasK Nov 25, 2024
6e49339
Increase go test timeout
DeividasK Nov 25, 2024
dda8e3b
Upgrade CTFv2
DeividasK Nov 25, 2024
c366f08
try beefy machine
skudasov Nov 25, 2024
c9c9228
Double OCR timeouts config
DeividasK Nov 26, 2024
a86bff5
Add sleep 20
DeividasK Nov 26, 2024
1b8fe62
Log URLs
DeividasK Nov 26, 2024
001c70d
Add mroe sleep
DeividasK Nov 26, 2024
5c26247
Try another thing
DeividasK Nov 26, 2024
1a21e70
Print entire job spec
DeividasK Nov 26, 2024
1ec9511
try the version with exposed raw IPs
skudasov Nov 26, 2024
e1974e6
increase timeout, try non-aliased network
skudasov Nov 26, 2024
a3fa576
try 32 cores and log ips
skudasov Nov 26, 2024
1630563
try no-ipv6 network
skudasov Nov 26, 2024
532d64c
long blocks, add logs
skudasov Nov 26, 2024
6481c5b
fix upload
skudasov Nov 26, 2024
3aec009
update the framework, switch back the runner
skudasov Nov 26, 2024
e74c833
Use explicit linux amd64 streams binary
DeividasK Nov 27, 2024
e202dce
Polish
DeividasK Nov 27, 2024
7aa7883
Go mod tidy
DeividasK Nov 27, 2024
851990d
Remove sleep
DeividasK Nov 27, 2024
271a5db
Reduce test waiting time
DeividasK Nov 27, 2024
7058d3a
Run generate
DeividasK Nov 27, 2024
31249fe
Reduce test timeout windown
DeividasK Nov 27, 2024
f41b892
Merge remote-tracking branch 'origin/develop' into dk-keystone-e2e-test
DeividasK Nov 27, 2024
1f25769
update CTF, update dockerfile paths
skudasov Nov 27, 2024
a04e8b3
Move e2e tests to the integration-tests folder
DeividasK Nov 28, 2024
c0c9078
Update CI
DeividasK Nov 28, 2024
1b3d82e
Re-generate & tidy
DeividasK Nov 28, 2024
ef5d6d4
Fix lint issues
DeividasK Nov 28, 2024
8e4dcdd
upgrade CTF
skudasov Dec 2, 2024
53c1a3d
Merge branch 'develop' into dk-keystone-e2e-test
skudasov Dec 2, 2024
5006478
merge
skudasov Dec 2, 2024
29680ef
try with built image
skudasov Dec 2, 2024
843b6ff
debug image
skudasov Dec 2, 2024
50ac1b8
combine CL image with version
skudasov Dec 2, 2024
d16311a
try tag
skudasov Dec 2, 2024
c92fea5
require build
skudasov Dec 2, 2024
591c9f2
try different region
skudasov Dec 2, 2024
fcbd7f7
stub missing region
skudasov Dec 2, 2024
7cfab70
re-trigger
skudasov Dec 2, 2024
49b858e
auth
skudasov Dec 2, 2024
e7bd381
remove incompatible image build
skudasov Dec 2, 2024
18bc11a
rollback config
skudasov Dec 2, 2024
9f62f89
Updates to get the test working again
DeividasK Dec 3, 2024
bb02a58
Add more logs
DeividasK Dec 3, 2024
4a14601
Change OCR configuration
DeividasK Dec 3, 2024
d0b7af3
Change OCR config again
DeividasK Dec 3, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .dockerignore
Original file line number Diff line number Diff line change
Expand Up @@ -33,4 +33,4 @@ credentials.env
gcr_creds.env

go.work
go.work.sum
go.work.sum
38 changes: 37 additions & 1 deletion .github/workflows/integration-tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -200,6 +200,43 @@ jobs:
AWS_ROLE_TO_ASSUME: ${{ secrets.QA_AWS_ROLE_TO_ASSUME }}
dep_evm_sha: ${{ inputs.evm-ref }}

# TODO: Use the docker image built in the previous step
ctf-v2-test:
runs-on: ubuntu-latest
env:
CTF_IGNORE_CRITICAL_LOGS: true
CTF_CONFIGS: environment.toml
CTF_LOG_LEVEL: info
CTF_LOKI_STREAM: "false"
PRIVATE_KEY: ${{ secrets.CTF_SIMULATED_KEY_1 }}
steps:
- name: Check out code
uses: actions/checkout@v4
- name: Set up Go
uses: actions/setup-go@v5
with:
go-version: 1.22.8
- name: Cache Go modules
uses: actions/cache@v4
with:
path: |
~/.cache/go-build
~/go/pkg/mod
key: go-modules-${{ hashFiles('**/go.sum') }}-${{ runner.os }}
restore-keys: |
go-modules-${{ hashFiles('**/go.sum') }}-${{ runner.os }}
- name: Install dependencies
run: go mod download
- name: Run tests
working-directory: integration-tests/capabilities
run: go test -v -timeout 15m -run TestWorkflow
- name: Upload logs directory
if: always()
uses: actions/upload-artifact@v4
with:
name: container-logs
path: integration-tests/capabilities/logs

run-core-e2e-tests-for-pr:
name: Run Core E2E Tests For PR
permissions:
Expand Down Expand Up @@ -737,4 +774,3 @@ jobs:
name: cl_node_coverage_data_solana_tests
path: .covdata
retention-days: 1

4 changes: 4 additions & 0 deletions go.md
Original file line number Diff line number Diff line change
Expand Up @@ -122,6 +122,8 @@ flowchart LR
click chainlink-solana href "https://github.com/smartcontractkit/chainlink-solana"
chainlink-starknet/relayer --> chainlink-common
click chainlink-starknet/relayer href "https://github.com/smartcontractkit/chainlink-starknet"
chainlink-testing-framework/framework
click chainlink-testing-framework/framework href "https://github.com/smartcontractkit/chainlink-testing-framework"
chainlink-testing-framework/havoc --> chainlink-testing-framework/lib/grafana
click chainlink-testing-framework/havoc href "https://github.com/smartcontractkit/chainlink-testing-framework"
chainlink-testing-framework/lib --> chainlink-testing-framework/seth
Expand All @@ -140,6 +142,7 @@ flowchart LR
chainlink/deployment --> chainlink-testing-framework/lib
chainlink/deployment --> chainlink/v2
click chainlink/deployment href "https://github.com/smartcontractkit/chainlink"
chainlink/integration-tests --> chainlink-testing-framework/framework
chainlink/integration-tests --> chainlink-testing-framework/havoc
chainlink/integration-tests --> chainlink/deployment
click chainlink/integration-tests href "https://github.com/smartcontractkit/chainlink"
Expand Down Expand Up @@ -185,6 +188,7 @@ flowchart LR
click chainlink-protos-repo href "https://github.com/smartcontractkit/chainlink-protos"

subgraph chainlink-testing-framework-repo[chainlink-testing-framework]
chainlink-testing-framework/framework
chainlink-testing-framework/havoc
chainlink-testing-framework/lib
chainlink-testing-framework/lib/grafana
Expand Down
7 changes: 7 additions & 0 deletions integration-tests/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
# CTFv2 - Observability stack
**/compose
**/compose/*
**/*cache.toml

# CTFv2 - Blockscout
**/blockscout
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
package capabilities_registry

import (
"context"
"fmt"

"github.com/ethereum/go-ethereum/accounts/abi/bind"
"github.com/ethereum/go-ethereum/common"

"github.com/smartcontractkit/chainlink-testing-framework/seth"
cr "github.com/smartcontractkit/chainlink/v2/core/gethwrappers/keystone/generated/capabilities_registry"
)

type CapabilitiesRegistryInstance struct {
Address common.Address
Contract *cr.CapabilitiesRegistry
sc *seth.Client
ExistingHashedCapabilitiesIDs [][32]byte
}

func Deploy(sc *seth.Client) (*CapabilitiesRegistryInstance, error) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

can we not reuse, extend and unify on the work in deployment/keystone?

ccip is doing something similiar -- all deployment logic is unified and they have a devenv for integration tests

capabilitiesRegistryAddress, tx, capabilitiesRegistryContract, err := cr.DeployCapabilitiesRegistry(
sc.NewTXOpts(),
sc.Client,
)
if err != nil {
return nil, err
}

_, err = bind.WaitMined(context.Background(), sc.Client, tx)
if err != nil {
return nil, err
}

fmt.Printf("🚀 Deployed \033[1mcapabilities_registry\033[0m contract at \033[1m%s\033[0m\n", capabilitiesRegistryAddress)
return &CapabilitiesRegistryInstance{
sc: sc,
Address: capabilitiesRegistryAddress,
Contract: capabilitiesRegistryContract,
}, nil
}

func (cr *CapabilitiesRegistryInstance) AddCapabilities(capabilities []cr.CapabilitiesRegistryCapability) error {
tx, err := cr.Contract.AddCapabilities(
cr.sc.NewTXOpts(),
capabilities,
)
if err != nil {
return err
}

_, err = bind.WaitMined(context.Background(), cr.sc.Client, tx)
if err != nil {
return err
}

for _, capability := range capabilities {
hashedCapabilityID, err := cr.Contract.GetHashedCapabilityId(
cr.sc.NewCallOpts(),
capability.LabelledName,
capability.Version,
)
if err != nil {
return err
}
cr.ExistingHashedCapabilitiesIDs = append(cr.ExistingHashedCapabilitiesIDs, hashedCapabilityID)
}

return nil
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
package forwarder

import (
"context"
"fmt"

"github.com/ethereum/go-ethereum/accounts/abi/bind"
"github.com/ethereum/go-ethereum/common"

"github.com/smartcontractkit/chainlink-testing-framework/seth"

forwarder_wrapper "github.com/smartcontractkit/chainlink/v2/core/gethwrappers/keystone/generated/forwarder"
)

type ForwarderInstance struct {
Address common.Address
Contract *forwarder_wrapper.KeystoneForwarder
sc *seth.Client
ExistingHashedCapabilitiesIDs [][32]byte
}

func Deploy(sc *seth.Client) (*ForwarderInstance, error) {
forwarderAddress, tx, forwarderContract, err := forwarder_wrapper.DeployKeystoneForwarder(
sc.NewTXOpts(),
sc.Client,
)
if err != nil {
return nil, err
}

_, err = bind.WaitMined(context.Background(), sc.Client, tx)
if err != nil {
return nil, err
}

fmt.Printf("🚀 Deployed \033[1mforwarder\033[0m contract at \033[1m%s\033[0m\n", forwarderAddress)
return &ForwarderInstance{
sc: sc,
Address: forwarderAddress,
Contract: forwarderContract,
}, nil
}

func (i *ForwarderInstance) SetConfig(
donID uint32,
configVersion uint32,
f uint8,
signers []common.Address,
) error {
tx, err := i.Contract.SetConfig(
i.sc.NewTXOpts(),
donID,
configVersion,
f,
signers,
)
if err != nil {
return err
}

_, err = bind.WaitMined(context.Background(), i.sc.Client, tx)
if err != nil {
return err
}

return nil
}
80 changes: 80 additions & 0 deletions integration-tests/capabilities/components/onchain/fund.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
package onchain

import (
"context"
"crypto/ecdsa"
"errors"
"fmt"
"math/big"

"github.com/ethereum/go-ethereum/common"
"github.com/ethereum/go-ethereum/core/types"
"github.com/ethereum/go-ethereum/crypto"
"github.com/ethereum/go-ethereum/ethclient"

"github.com/smartcontractkit/chainlink-testing-framework/framework"
"github.com/smartcontractkit/chainlink-testing-framework/framework/clclient"
"github.com/smartcontractkit/chainlink-testing-framework/seth"
)

func SendETH(client *ethclient.Client, privateKeyHex string, toAddress string, amount *big.Float) error {
privateKey, err := crypto.HexToECDSA(privateKeyHex)
if err != nil {
return fmt.Errorf("failed to parse private key: %w", err)
}
wei := new(big.Int)
amountWei := new(big.Float).Mul(amount, big.NewFloat(1e18))
amountWei.Int(wei)

publicKey := privateKey.Public()
publicKeyECDSA, ok := publicKey.(*ecdsa.PublicKey)
if !ok {
return fmt.Errorf("error casting public key to ECDSA")
}
fromAddress := crypto.PubkeyToAddress(*publicKeyECDSA)

nonce, err := client.PendingNonceAt(context.Background(), fromAddress)
if err != nil {
return fmt.Errorf("failed to fetch nonce: %w", err)
}

gasPrice, err := client.SuggestGasPrice(context.Background())
if err != nil {
return fmt.Errorf("failed to fetch gas price: %w", err)
}
gasLimit := uint64(21000) // Standard gas limit for ETH transfer

tx := types.NewTransaction(nonce, common.HexToAddress(toAddress), wei, gasLimit, gasPrice, nil)

chainID, err := client.NetworkID(context.Background())
if err != nil {
return fmt.Errorf("failed to fetch chain ID: %w", err)
}
signedTx, err := types.SignTx(tx, types.NewEIP155Signer(chainID), privateKey)
if err != nil {
return fmt.Errorf("failed to sign transaction: %w", err)
}

err = client.SendTransaction(context.Background(), signedTx)
if err != nil {
return fmt.Errorf("failed to send transaction: %w", err)
}
framework.L.Info().Msgf("Transaction sent: %s", signedTx.Hash().Hex())
return nil
}

func FundNodes(sc *seth.Client, nodes []*clclient.ChainlinkClient, pkey string, ethAmount float64) error {
if ethAmount == 0 {
return errors.New("funds_eth is 0, set some value in config, ex.: funds_eth = 30.0")
}
for _, cl := range nodes {
ek, err := cl.ReadPrimaryETHKey()
if err != nil {
return err
}
if err := SendETH(sc.Client, pkey, ek.Attributes.Address, big.NewFloat(ethAmount)); err != nil {
return fmt.Errorf("failed to fund CL node %s: %w", ek.Attributes.Address, err)
}
}
return nil
}
Loading
Loading