-
Notifications
You must be signed in to change notification settings - Fork 502
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
services/horizon: Move integration tests away from stellar/quickstart. #3143
Changes from 34 commits
b8bda97
2ba097b
ede737e
068b06a
11800e6
104de46
0cd8f9a
c0399b6
843c346
d38381d
86b0453
246e625
22197a8
52a5a23
0833a95
71b9a0a
6c2e103
7d59244
22bd660
87a6a03
94cc6b9
9d90135
dcbd30e
1991398
1c4aca5
cb5b186
daaf14b
2c99d4f
fa5a658
3cfa97b
1a7039c
a80c521
ed67c5f
016c91e
2545834
0c0d0b7
a5096f4
1223613
34c5830
027a48c
44370a3
854d694
c6623f0
7332b14
1d00fe3
8deece7
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
version: '3' | ||
tamirms marked this conversation as resolved.
Show resolved
Hide resolved
|
||
services: | ||
core-postgres: | ||
image: postgres:9.6.17-alpine | ||
restart: on-failure | ||
environment: | ||
- POSTGRES_PASSWORD=mysecretpassword | ||
- POSTGRES_DB=stellar | ||
ports: | ||
- "5641:5641" | ||
command: ["-p", "5641"] | ||
core: | ||
image: stellar/stellar-core | ||
depends_on: | ||
- core-postgres | ||
restart: on-failure | ||
ports: | ||
- "11625:11625" | ||
- "11626:11626" | ||
# add extra port for history archive server | ||
- "1570:1570" | ||
command: /start standalone | ||
volumes: | ||
- ./stellar-core-integration-tests.cfg:/stellar-core.cfg | ||
- ./core-start.sh:/start |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -14,10 +14,10 @@ services: | |
environment: | ||
- HISTORY_ARCHIVE_URLS=http://host.docker.internal:1570 | ||
- NETWORK_PASSPHRASE=Standalone Network ; February 2017 | ||
# this container will invoke a request to upgrade stellar core to protocol 13 | ||
# this container will invoke a request to upgrade stellar core to protocol 14 (by default) | ||
tamirms marked this conversation as resolved.
Show resolved
Hide resolved
|
||
core-upgrade: | ||
restart: on-failure | ||
image: curlimages/curl:7.69.1 | ||
command: ["-v", "-f", "http://host.docker.internal:11626/upgrades?mode=set&upgradetime=1970-01-01T00:00:00Z&protocolversion=13"] | ||
command: ["-v", "-f", "http://host.docker.internal:11626/upgrades?mode=set&upgradetime=1970-01-01T00:00:00Z&protocolversion=${PROTOCOL_VERSION:-14}"] | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Maybe we can upgrade to the latest version available if it's not set? |
||
network_mode: '${NETWORK_MODE:-bridge}' | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
# simple configuration for a standalone test "network" | ||
# see stellar-core_example.cfg for a description of the configuration parameters | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Did you consider using a template instead of having multiple configuration files? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. could you elaborate on how we could use a template here (e.g. what templating engine would we use, how would we invoke the template to generate the actual configuration we need) ? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. e.g. https://golang.org/pkg/text/template/ would probably be enough , you would need to use Go (e.g. from the integration tests) to fill it in. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ok, I think we'll definitely take this approach if we need to generate several stellar core configurations for the different integration test cases. for now it seems that this stellar core configuration will work for all the integration test cases |
||
|
||
RUN_STANDALONE=false | ||
MANUAL_CLOSE=true | ||
|
||
NETWORK_PASSPHRASE="Standalone Network ; February 2017" | ||
|
||
PEER_PORT=11625 | ||
HTTP_PORT=11626 | ||
PUBLIC_HTTP_PORT=true | ||
|
||
NODE_SEED="SACJC372QBSSKJYTV5A7LWT4NXWHTQO6GHG4QDAVC2XDPX6CNNXFZ4JK" | ||
|
||
NODE_IS_VALIDATOR=true | ||
UNSAFE_QUORUM=true | ||
FAILURE_SAFETY=0 | ||
|
||
DATABASE="postgresql://user=postgres password=mysecretpassword host=core-postgres port=5641 dbname=stellar" | ||
|
||
[QUORUM_SET] | ||
THRESHOLD_PERCENT=100 | ||
VALIDATORS=["GD5KD2KEZJIGTC63IGW6UMUSMVUVG5IHG64HUTFWCHVZH2N2IBOQN7PS"] | ||
|
||
[HISTORY.vs] | ||
get="cp history/vs/{0} {1}" | ||
put="cp {0} history/vs/{1}" | ||
mkdir="mkdir -p history/vs/{0}" |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -106,7 +106,7 @@ func TestProtocol14StateVerifier(t *testing.T) { | |
|
||
// Reach the first checkpoint ledger | ||
// Core will push to history archives *after* checkpoint ledger | ||
itest.CloseCoreLedgersUntilSequence(firstCheckpoint + 1) | ||
err = itest.CloseCoreLedgersUntilSequence(firstCheckpoint + 1) | ||
assert.NoError(t, err) | ||
for !itest.LedgerIngested(firstCheckpoint) { | ||
time.Sleep(time.Second) | ||
|
@@ -118,16 +118,17 @@ func TestProtocol14StateVerifier(t *testing.T) { | |
} | ||
|
||
// Trigger state rebuild to check if ingesting from history archive works | ||
itest.RunHorizonCLICommand("expingest", "trigger-state-rebuild") | ||
err = itest.Horizon().HistoryQ().UpdateExpIngestVersion(0) | ||
assert.NoError(t, err) | ||
|
||
// Wait for the second checkpoint ledger and state rebuild | ||
// Core will push to history archives *after* checkpoint ledger | ||
itest.CloseCoreLedgersUntilSequence(secondCheckpoint + 1) | ||
err = itest.CloseCoreLedgersUntilSequence(secondCheckpoint + 1) | ||
assert.NoError(t, err) | ||
|
||
// Wait for the third checkpoint ledger and state verification trigger | ||
// Core will push to history archives *after* checkpoint ledger | ||
itest.CloseCoreLedgersUntilSequence(thirdCheckpoint + 1) | ||
err = itest.CloseCoreLedgersUntilSequence(thirdCheckpoint + 1) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Thanks! There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. +1 |
||
assert.NoError(t, err) | ||
for !itest.LedgerIngested(thirdCheckpoint) { | ||
time.Sleep(time.Second) | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think I would pin this to a specific version
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's worth checking the latest version to confirm it tests work with the latest core version.