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

Electrum integration tests for mainnet servers #3599

Merged
merged 30 commits into from
Jun 15, 2023
Merged
Show file tree
Hide file tree
Changes from 18 commits
Commits
Show all changes
30 commits
Select commit Hold shift + click to select a range
96aeb5f
Add more bitcoin testdata
nkuba Jun 2, 2023
6d54bb2
Extract server's error message assertions
nkuba Jun 2, 2023
2c38452
Define a generic assertNumberCloseTo function
nkuba Jun 2, 2023
473132b
Use invalidTxID defined on the package scope
nkuba Jun 2, 2023
d508c04
Cancel context for connections in test
nkuba Jun 2, 2023
0e89bf7
Read embeded electrum servers in the electrum integration tests
nkuba Jun 2, 2023
960ee65
Improve integration tests for electrum
nkuba Jun 2, 2023
4c4cd19
Remove config electrum integration tests
nkuba Jun 2, 2023
b675222
Fix for loop
nkuba Jun 5, 2023
36949fa
Make timeout 4 seconds
nkuba Jun 5, 2023
7d2a277
Merge remote-tracking branch 'origin/main' into integration-tests-mai…
nkuba Jun 6, 2023
1942c1f
Set 20m timeout for integration tests execution
nkuba Jun 6, 2023
00af3a9
Align timeouts for esplora
nkuba Jun 8, 2023
0eb9560
Add parallel execution for transactions test
nkuba Jun 8, 2023
68c9b7b
Update golang version in Dockerfile to 1.18.10
nkuba Jun 8, 2023
6039d49
Cancel context after all sub tests are completed
nkuba Jun 8, 2023
4e1a767
Remove electrum tcp server
nkuba Jun 8, 2023
5045e30
Add script for running integration tests
nkuba Jun 8, 2023
cbb601b
Add details of actual sweep transactions
nkuba Jun 13, 2023
6dec1b9
Use deep.Equal to compare
nkuba Jun 13, 2023
2c890ee
Try sleep before cancel
nkuba Jun 13, 2023
69ce129
Merge remote-tracking branch 'origin/main' into integration-tests-mai…
nkuba Jun 13, 2023
4298722
Use consistent timeouts
nkuba Jun 13, 2023
edc100a
Fix duplicate servers removal
nkuba Jun 13, 2023
6a69437
Capture vars for parallel test execution
nkuba Jun 13, 2023
040ba33
Use longer timeouts in tests
nkuba Jun 13, 2023
e071a74
Add integration test build tag
nkuba Jun 13, 2023
5d081d1
Add more context for error message
nkuba Jun 13, 2023
9ba2d3c
Remove space from go build tag comment
nkuba Jun 15, 2023
a0dd61e
Clarify why we add sleep in test
nkuba Jun 15, 2023
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 .github/workflows/client.yml
Original file line number Diff line number Diff line change
Expand Up @@ -323,4 +323,4 @@ jobs:
docker run \
--workdir /go/src/github.com/keep-network/keep-core \
go-build-env \
gotestsum -- -tags=integration ./...
gotestsum -- -timeout 20m -tags=integration ./...
2 changes: 1 addition & 1 deletion Dockerfile
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
FROM golang:1.18.3-alpine3.16 AS build-sources
FROM golang:1.18.10-alpine3.16 AS build-sources

ENV GOPATH=/go \
GOBIN=/go/bin \
Expand Down
38 changes: 0 additions & 38 deletions config/electrum_integration_test.go

This file was deleted.

32 changes: 32 additions & 0 deletions internal/testdata/bitcoin/block.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
package bitcoin

import "github.com/keep-network/keep-core/pkg/bitcoin"

// Blocks holds details of block header data used as test vectors.
var Blocks = map[bitcoin.Network]struct {
BlockHeight uint
BlockHeader *bitcoin.BlockHeader
}{
bitcoin.Testnet: {
BlockHeight: 2135502,
BlockHeader: &bitcoin.BlockHeader{
Version: 536870916,
PreviousBlockHeaderHash: hashFromString("000000000066450030efdf72f233ed2495547a32295deea1e2f3a16b1e50a3a5"),
MerkleRootHash: hashFromString("1251774996b446f85462d5433f7a3e384ac1569072e617ab31e86da31c247de2"),
Time: 1641914003,
Bits: 436256810,
Nonce: 778087099,
},
},
bitcoin.Mainnet: {
BlockHeight: 792379,
BlockHeader: &bitcoin.BlockHeader{
Version: 547356672,
PreviousBlockHeaderHash: hashFromString("000000000000000000035d7345203315d8c73c37da256eebbe58a683331b60f5"),
MerkleRootHash: hashFromString("a406a1495c4c4bed2d458f06f393cb841a545cbf7cc04b1ee3d9ae9e6eccb402"),
Time: 1685622977,
Bits: 386236009,
Nonce: 2812580720,
},
},
}
56 changes: 56 additions & 0 deletions internal/testdata/bitcoin/merkleproof.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
package bitcoin

import "github.com/keep-network/keep-core/pkg/bitcoin"

// TxMerkleProofs holds details of transaction merkle proof data used as test vectors.
var TxMerkleProofs = map[bitcoin.Network]struct {
TxHash bitcoin.Hash
BlockHeight uint
MerkleProof *bitcoin.TransactionMerkleProof
}{
bitcoin.Testnet: {
TxHash: hashFromString(
"72e7fd57c2adb1ed2305c4247486ff79aec363296f02ec65be141904f80d214e",
),
BlockHeight: 1569342,
MerkleProof: &bitcoin.TransactionMerkleProof{
BlockHeight: 1569342,
MerkleNodes: []string{
"8b5bbb5bdf6727bf70fad4f46fe4eaab04c98119ffbd2d95c29adf32d26f8452",
"53637bacb07965e4a8220836861d1b16c6da29f10ea9ab53fc4eca73074f98b9",
"0267e738108d094ceb05217e2942e9c2a4c6389ac47f476f572c9a319ce4dfbc",
"34e00deec50c48d99678ca2b52b82d6d5432326159c69e7233d0dde0924874b4",
"7a53435e6c86a3620cdbae510901f17958f0540314214379197874ed8ed7a913",
"6315dbb7ce350ceaa16cd4c35c5a147005e8b38ca1e9531bd7320629e8d17f5b",
"40380cdadc0206646208871e952af9dcfdff2f104305ce463aed5eeaf7725d2f",
"5d74bae6a71fd1cff2416865460583319a40343650bd4bb89de0a6ae82097037",
"296ddccfc659e0009aad117c8ed15fb6ff81c2bade73fbc89666a22708d233f9",
},
Position: 176,
},
},
bitcoin.Mainnet: {
TxHash: hashFromString(
"4db013214a88ac4bff07a7ef160c6d7cf82dea26f747c035c7aa6f3d7a7f4d4c",
),
BlockHeight: 792384,
MerkleProof: &bitcoin.TransactionMerkleProof{
BlockHeight: 792384,
MerkleNodes: []string{
"dde09ada70242eb53da60ad14966d56a2fb13305e3d6c91d450b345579810c16",
"8bdf3bfac9c4ffc5949b18b2d381a954432bae1ebf419a08dd237b0e70f3c671",
"6fdd8d8b8fd2c248600a4d0da2b3d06449962461a1590443dee6859470c5bb8a",
"59a57e6bbd22a797960c0f690aa66d14ce3491a998c79b48ddd40fa5d183b27e",
"befd298b231c3f957e26b8dcb3b2a8bc011c387d7fb0addbdde5c2fca408f046",
"5738cefbca2c0d0f8042510055f660dca093407413c67033ca10ee4f9768ff91",
"af1937b829566b0e684c22c60c8bc06ba762d914263259a3e37ae66955e9a3a4",
"7a34a70b80fe1db7aa9d94efc3f47fb2a4fbf33185c17da06015e0ccf7e733be",
"a2ca5d291a2c16e14abf9a6d828fb324c744a131434bcb5b15f1d6d7ded6ca0f",
"b3f830dfbfbcda88e1740357cbee20d89e6c258acb740fd3ed6080cd54d4b54d",
"86aab3b304c7612889565a85bc540f1635d6dd810d3d9c985e12c0945cba9f8c",
"f7b94a757adc025ecb47bddbbc655dee3eb0916b4b4d2c5919cc9690f51835db",
pdyraga marked this conversation as resolved.
Show resolved Hide resolved
},
Position: 6,
},
},
}
Loading