2026-02-25 15:39:14 +00:00

110 lines
18 KiB
Plaintext

2026-02-25 15:28:30.811 DEBUG [tests.conftest] Running fixture setup: test_id
2026-02-25 15:28:30.812 DEBUG [tests.conftest] Running test: test_sync_flags_node2_start_later with id: 2026-02-25_15-28-30__c66a8d81-6b8d-4321-aa6c-979e4712e496
2026-02-25 15:28:30.812 DEBUG [src.steps.common] Running fixture setup: common_setup
2026-02-25 15:28:30.820 DEBUG [src.node.docker_mananger] Docker client initialized with image wakuorg/nwaku:latest
2026-02-25 15:28:30.820 DEBUG [src.node.waku_node] WakuNode instance initialized with log path ./log/docker/node1_2026-02-25_15-28-30__c66a8d81-6b8d-4321-aa6c-979e4712e496__wakuorg_nwaku:latest.log
2026-02-25 15:28:30.827 DEBUG [src.node.docker_mananger] Docker client initialized with image wakuorg/nwaku:latest
2026-02-25 15:28:30.827 DEBUG [src.node.waku_node] WakuNode instance initialized with log path ./log/docker/node2_2026-02-25_15-28-30__c66a8d81-6b8d-4321-aa6c-979e4712e496__wakuorg_nwaku:latest.log
2026-02-25 15:28:30.834 DEBUG [src.node.docker_mananger] Docker client initialized with image wakuorg/nwaku:latest
2026-02-25 15:28:30.834 DEBUG [src.node.waku_node] WakuNode instance initialized with log path ./log/docker/node3_2026-02-25_15-28-30__c66a8d81-6b8d-4321-aa6c-979e4712e496__wakuorg_nwaku:latest.log
2026-02-25 15:28:30.835 DEBUG [src.steps.store] Running fixture setup: store_setup
2026-02-25 15:28:30.835 DEBUG [src.node.waku_node] Starting Node...
2026-02-25 15:28:30.836 DEBUG [src.node.docker_mananger] Attempting to create or retrieve network waku
2026-02-25 15:28:30.837 DEBUG [src.node.docker_mananger] Network waku already exists
2026-02-25 15:28:30.837 DEBUG [src.node.docker_mananger] Generated random external IP 172.18.120.119
2026-02-25 15:28:30.837 DEBUG [src.node.docker_mananger] Generated ports ['51615', '51616', '51617', '51618', '51619']
2026-02-25 15:28:30.837 DEBUG [src.node.waku_node] RLN credentials were not set
2026-02-25 15:28:30.838 INFO [src.node.waku_node] RLN credentials not set or credential store not available, starting without RLN
2026-02-25 15:28:30.838 DEBUG [src.node.waku_node] Using volumes []
2026-02-25 15:28:30.838 DEBUG [src.node.docker_mananger] docker run -i -t -p 51615:51615 -p 51616:51616 -p 51617:51617 -p 51618:51618 -p 51619:51619 wakuorg/nwaku:latest --listen-address=0.0.0.0 --rest=true --rest-admin=true --websocket-support=true --log-level=TRACE --rest-relay-cache-capacity=100 --websocket-port=51617 --rest-port=51615 --tcp-port=51616 --discv5-udp-port=51618 --rest-address=0.0.0.0 --nat=extip:172.18.120.119 --peer-exchange=true --discv5-discovery=true --cluster-id=3 --nodekey=fdbeb0153fee6fbca1bf64d2f3ad949b95c797b71cc883be989a27320acc141d --store-sync=true --store=true --store-sync-range=45 --store-sync-interval=10 --shard=0 --metrics-server=true --metrics-server-address=0.0.0.0 --metrics-server-port=51619 --metrics-logging=true --store-sync-relay-jitter=0 --relay=true
2026-02-25 15:28:31.010 ERROR [src.node.docker_mananger] Max retries reached for container c0d0189ea5ef. Exiting log stream.
2026-02-25 15:28:31.045 DEBUG [src.node.docker_mananger] docker network connect --ip 172.18.120.119 waku 795467d5a6284ca8faa9e56c65aace1618ab6b257108d5f7a9ea1a92a90a31f8
2026-02-25 15:28:31.076 DEBUG [src.node.docker_mananger] Container started with ID 795467d5a628. Setting up logs at ./log/docker/node1_2026-02-25_15-28-30__c66a8d81-6b8d-4321-aa6c-979e4712e496__wakuorg_nwaku:latest.log
2026-02-25 15:28:31.078 DEBUG [src.node.waku_node] Started container from image wakuorg/nwaku:latest. REST: 51615
2026-02-25 15:28:31.078 DEBUG [src.libs.common] Sleeping for 1 seconds
2026-02-25 15:28:31.594 ERROR [src.node.docker_mananger] Max retries reached for container cd00104f7c56. Exiting log stream.
2026-02-25 15:28:32.079 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:51615/health" -H "Content-Type: application/json" -d 'None'
2026-02-25 15:28:32.082 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'{"nodeHealth":"READY","connectionStatus":"Disconnected","protocolsHealth":[{"Relay":"NOT_READY","desc":"No connected peers"},{"Lightpush":"NOT_MOUNTED"},{"Legacy Lightpush":"NOT_MOUNTED"},{"Filter":"NOT_MOUNTED"},{"Store":"READY"},{"Legacy Store":"NOT_MOUNTED"},{"Peer Exchange":"READY"},{"Rendezvous":"NOT_READY","desc":"No Rendezvous peers are available yet"},{"Mix":"NOT_MOUNTED"},{"Lightpush Client":"NOT_READY","desc":"No Lightpush service peer available yet"},{"Legacy Lightpush Client":"NOT_READY","desc":"No Lightpush service peer available yet"},{"Store Client":"READY"},{"Legacy Store Client":"NOT_READY","desc":"No Legacy Store service peers are available yet, neither Store service set up for the node"},{"Filter Client":"NOT_READY","desc":"No Filter service peer available yet"},{"Rln Relay":"NOT_MOUNTED"}]}'
2026-02-25 15:28:32.082 INFO [src.node.waku_node] Node protocols are initialized !!
2026-02-25 15:28:32.083 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:51615/debug/v1/info" -H "Content-Type: application/json" -d 'None'
2026-02-25 15:28:32.085 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'{"listenAddresses":["/ip4/172.18.120.119/tcp/51616/p2p/16Uiu2HAmUz51dfwduCsVvCVAN1BMipur59tBByVqAehZELzWVCGR","/ip4/172.18.120.119/tcp/51617/ws/p2p/16Uiu2HAmUz51dfwduCsVvCVAN1BMipur59tBByVqAehZELzWVCGR"],"enrUri":"enr:-L24QMDNxY4Z6q1DIPGnfWtT3Cv2w8oXYhatIWG-38Lg_qRPL-_QOm-g1_0EdCLoGltkruiNjkolXTIzSA27j2RUg80CgmlkgnY0gmlwhKwSeHeKbXVsdGlhZGRyc5YACASsEnh3BsmgAAoErBJ4dwbJod0DgnJzhQADAQAAiXNlY3AyNTZrMaED8p5L58FnwbFTYMNISPcH7hNWaDPEYD95_Anuxwy1xxqDdGNwgsmgg3VkcILJooV3YWt1MhM"}'
2026-02-25 15:28:32.085 INFO [src.node.waku_node] REST service is ready !!
2026-02-25 15:28:32.085 INFO [src.node.api_clients.base_client] curl -v -X POST "http://127.0.0.1:51615/relay/v1/subscriptions" -H "Content-Type: application/json" -d '["/waku/2/rs/3/0"]'
2026-02-25 15:28:32.103 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'OK'
2026-02-25 15:28:32.104 DEBUG [src.steps.store] Relaying message
2026-02-25 15:28:32.104 INFO [src.node.api_clients.base_client] curl -v -X POST "http://127.0.0.1:51615/relay/v1/messages/%2Fwaku%2F2%2Frs%2F3%2F0" -H "Content-Type: application/json" -d '{"payload": "U3RvcmUgd29ya3MhIQ==", "contentTopic": "/myapp/1/latest/proto", "timestamp": '$(date +%s%N)'}'
2026-02-25 15:28:32.108 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'OK'
2026-02-25 15:28:32.108 DEBUG [src.libs.common] Sleeping for 0.2 seconds
2026-02-25 15:28:32.309 DEBUG [src.steps.store] Relaying message
2026-02-25 15:28:32.309 INFO [src.node.api_clients.base_client] curl -v -X POST "http://127.0.0.1:51615/relay/v1/messages/%2Fwaku%2F2%2Frs%2F3%2F0" -H "Content-Type: application/json" -d '{"payload": "U3RvcmUgd29ya3MhIQ==", "contentTopic": "/myapp/1/latest/proto", "timestamp": '$(date +%s%N)'}'
2026-02-25 15:28:32.313 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'OK'
2026-02-25 15:28:32.313 DEBUG [src.libs.common] Sleeping for 0.2 seconds
2026-02-25 15:28:32.514 DEBUG [src.steps.store] Relaying message
2026-02-25 15:28:32.514 INFO [src.node.api_clients.base_client] curl -v -X POST "http://127.0.0.1:51615/relay/v1/messages/%2Fwaku%2F2%2Frs%2F3%2F0" -H "Content-Type: application/json" -d '{"payload": "U3RvcmUgd29ya3MhIQ==", "contentTopic": "/myapp/1/latest/proto", "timestamp": '$(date +%s%N)'}'
2026-02-25 15:28:32.518 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'OK'
2026-02-25 15:28:32.519 DEBUG [src.libs.common] Sleeping for 0.2 seconds
2026-02-25 15:28:32.719 DEBUG [src.steps.store] Relaying message
2026-02-25 15:28:32.720 INFO [src.node.api_clients.base_client] curl -v -X POST "http://127.0.0.1:51615/relay/v1/messages/%2Fwaku%2F2%2Frs%2F3%2F0" -H "Content-Type: application/json" -d '{"payload": "U3RvcmUgd29ya3MhIQ==", "contentTopic": "/myapp/1/latest/proto", "timestamp": '$(date +%s%N)'}'
2026-02-25 15:28:32.724 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'OK'
2026-02-25 15:28:32.724 DEBUG [src.libs.common] Sleeping for 0.2 seconds
2026-02-25 15:28:32.924 DEBUG [src.steps.store] Relaying message
2026-02-25 15:28:32.925 INFO [src.node.api_clients.base_client] curl -v -X POST "http://127.0.0.1:51615/relay/v1/messages/%2Fwaku%2F2%2Frs%2F3%2F0" -H "Content-Type: application/json" -d '{"payload": "U3RvcmUgd29ya3MhIQ==", "contentTopic": "/myapp/1/latest/proto", "timestamp": '$(date +%s%N)'}'
2026-02-25 15:28:32.929 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'OK'
2026-02-25 15:28:32.929 DEBUG [src.libs.common] Sleeping for 0.2 seconds
2026-02-25 15:28:33.130 DEBUG [src.steps.store] Relaying message
2026-02-25 15:28:33.130 INFO [src.node.api_clients.base_client] curl -v -X POST "http://127.0.0.1:51615/relay/v1/messages/%2Fwaku%2F2%2Frs%2F3%2F0" -H "Content-Type: application/json" -d '{"payload": "U3RvcmUgd29ya3MhIQ==", "contentTopic": "/myapp/1/latest/proto", "timestamp": '$(date +%s%N)'}'
2026-02-25 15:28:33.134 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'OK'
2026-02-25 15:28:33.135 DEBUG [src.libs.common] Sleeping for 0.2 seconds
2026-02-25 15:28:33.335 DEBUG [src.steps.store] Relaying message
2026-02-25 15:28:33.336 INFO [src.node.api_clients.base_client] curl -v -X POST "http://127.0.0.1:51615/relay/v1/messages/%2Fwaku%2F2%2Frs%2F3%2F0" -H "Content-Type: application/json" -d '{"payload": "U3RvcmUgd29ya3MhIQ==", "contentTopic": "/myapp/1/latest/proto", "timestamp": '$(date +%s%N)'}'
2026-02-25 15:28:33.340 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'OK'
2026-02-25 15:28:33.340 DEBUG [src.libs.common] Sleeping for 0.2 seconds
2026-02-25 15:28:33.541 DEBUG [src.steps.store] Relaying message
2026-02-25 15:28:33.541 INFO [src.node.api_clients.base_client] curl -v -X POST "http://127.0.0.1:51615/relay/v1/messages/%2Fwaku%2F2%2Frs%2F3%2F0" -H "Content-Type: application/json" -d '{"payload": "U3RvcmUgd29ya3MhIQ==", "contentTopic": "/myapp/1/latest/proto", "timestamp": '$(date +%s%N)'}'
2026-02-25 15:28:33.545 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'OK'
2026-02-25 15:28:33.546 DEBUG [src.libs.common] Sleeping for 0.2 seconds
2026-02-25 15:28:33.746 DEBUG [src.steps.store] Relaying message
2026-02-25 15:28:33.747 INFO [src.node.api_clients.base_client] curl -v -X POST "http://127.0.0.1:51615/relay/v1/messages/%2Fwaku%2F2%2Frs%2F3%2F0" -H "Content-Type: application/json" -d '{"payload": "U3RvcmUgd29ya3MhIQ==", "contentTopic": "/myapp/1/latest/proto", "timestamp": '$(date +%s%N)'}'
2026-02-25 15:28:33.751 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'OK'
2026-02-25 15:28:33.751 DEBUG [src.libs.common] Sleeping for 0.2 seconds
2026-02-25 15:28:33.952 DEBUG [src.steps.store] Relaying message
2026-02-25 15:28:33.952 INFO [src.node.api_clients.base_client] curl -v -X POST "http://127.0.0.1:51615/relay/v1/messages/%2Fwaku%2F2%2Frs%2F3%2F0" -H "Content-Type: application/json" -d '{"payload": "U3RvcmUgd29ya3MhIQ==", "contentTopic": "/myapp/1/latest/proto", "timestamp": '$(date +%s%N)'}'
2026-02-25 15:28:33.956 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'OK'
2026-02-25 15:28:33.957 DEBUG [src.libs.common] Sleeping for 0.2 seconds
2026-02-25 15:28:34.157 DEBUG [src.libs.common] Sleeping for 1 seconds
2026-02-25 15:28:35.157 DEBUG [src.node.waku_node] Starting Node...
2026-02-25 15:28:35.158 DEBUG [src.node.docker_mananger] Attempting to create or retrieve network waku
2026-02-25 15:28:35.160 DEBUG [src.node.docker_mananger] Network waku already exists
2026-02-25 15:28:35.160 DEBUG [src.node.docker_mananger] Generated random external IP 172.18.248.241
2026-02-25 15:28:35.160 DEBUG [src.node.docker_mananger] Generated ports ['51993', '51994', '51995', '51996', '51997']
2026-02-25 15:28:35.160 DEBUG [src.node.waku_node] RLN credentials were not set
2026-02-25 15:28:35.160 INFO [src.node.waku_node] RLN credentials not set or credential store not available, starting without RLN
2026-02-25 15:28:35.160 DEBUG [src.node.waku_node] Using volumes []
2026-02-25 15:28:35.160 DEBUG [src.node.docker_mananger] docker run -i -t -p 51993:51993 -p 51994:51994 -p 51995:51995 -p 51996:51996 -p 51997:51997 wakuorg/nwaku:latest --listen-address=0.0.0.0 --rest=true --rest-admin=true --websocket-support=true --log-level=TRACE --rest-relay-cache-capacity=100 --websocket-port=51995 --rest-port=51993 --tcp-port=51994 --discv5-udp-port=51996 --rest-address=0.0.0.0 --nat=extip:172.18.248.241 --peer-exchange=true --discv5-discovery=true --cluster-id=3 --nodekey=fcaba1c4c35c7567efbec69a88caab88efcfec8afdb61be52dd4ad0a9b70995a --store-sync=true --store=true --store-sync-range=45 --store-sync-interval=10 --shard=0 --metrics-server=true --metrics-server-address=0.0.0.0 --metrics-server-port=51997 --metrics-logging=true --store-sync-relay-jitter=0 --relay=false --discv5-bootstrap-node=enr:-L24QMDNxY4Z6q1DIPGnfWtT3Cv2w8oXYhatIWG-38Lg_qRPL-_QOm-g1_0EdCLoGltkruiNjkolXTIzSA27j2RUg80CgmlkgnY0gmlwhKwSeHeKbXVsdGlhZGRyc5YACASsEnh3BsmgAAoErBJ4dwbJod0DgnJzhQADAQAAiXNlY3AyNTZrMaED8p5L58FnwbFTYMNISPcH7hNWaDPEYD95_Anuxwy1xxqDdGNwgsmgg3VkcILJooV3YWt1MhM
2026-02-25 15:28:35.363 DEBUG [src.node.docker_mananger] docker network connect --ip 172.18.248.241 waku 945d97e4bdce5a8ec5a59c7915a42ab4ca009efbb76ec745f5caad1be94e84dd
2026-02-25 15:28:35.395 DEBUG [src.node.docker_mananger] Container started with ID 945d97e4bdce. Setting up logs at ./log/docker/node2_2026-02-25_15-28-30__c66a8d81-6b8d-4321-aa6c-979e4712e496__wakuorg_nwaku:latest.log
2026-02-25 15:28:35.395 DEBUG [src.node.waku_node] Started container from image wakuorg/nwaku:latest. REST: 51993
2026-02-25 15:28:35.395 DEBUG [src.libs.common] Sleeping for 1 seconds
2026-02-25 15:28:36.396 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:51993/health" -H "Content-Type: application/json" -d 'None'
2026-02-25 15:28:36.399 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'{"nodeHealth":"READY","connectionStatus":"Disconnected","protocolsHealth":[{"Relay":"NOT_MOUNTED"},{"Lightpush":"NOT_MOUNTED"},{"Legacy Lightpush":"NOT_MOUNTED"},{"Filter":"NOT_MOUNTED"},{"Store":"READY"},{"Legacy Store":"NOT_MOUNTED"},{"Peer Exchange":"READY"},{"Rendezvous":"NOT_READY","desc":"No Rendezvous peers are available yet"},{"Mix":"NOT_MOUNTED"},{"Lightpush Client":"NOT_READY","desc":"No Lightpush service peer available yet"},{"Legacy Lightpush Client":"NOT_READY","desc":"No Lightpush service peer available yet"},{"Store Client":"READY"},{"Legacy Store Client":"NOT_READY","desc":"No Legacy Store service peers are available yet, neither Store service set up for the node"},{"Filter Client":"NOT_READY","desc":"No Filter service peer available yet"},{"Rln Relay":"NOT_MOUNTED"}]}'
2026-02-25 15:28:36.399 INFO [src.node.waku_node] Node protocols are initialized !!
2026-02-25 15:28:36.399 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:51993/debug/v1/info" -H "Content-Type: application/json" -d 'None'
2026-02-25 15:28:36.402 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'{"listenAddresses":["/ip4/172.18.248.241/tcp/51994/p2p/16Uiu2HAkzKyNxMLJ2atENRbTBYrqrysVGuEEGEf44BwER2dSSvnn","/ip4/172.18.248.241/tcp/51995/ws/p2p/16Uiu2HAkzKyNxMLJ2atENRbTBYrqrysVGuEEGEf44BwER2dSSvnn"],"enrUri":"enr:-L24QAcLjNA9Bh4nxekmV5bmpjs_RYSt3ttYd9kzyGLdZPtdHc0VIFW0yMoxqxSOZcDNKeaJYkoSgCzGGAErFL1PY3MCgmlkgnY0gmlwhKwS-PGKbXVsdGlhZGRyc5YACASsEvjxBssaAAoErBL48QbLG90DgnJzhQADAQAAiXNlY3AyNTZrMaECSNSfjr3EPAyOlp7Ynp_faO_iloQvJKrgowj9RB6WPQuDdGNwgssag3VkcILLHIV3YWt1MhI"}'
2026-02-25 15:28:36.402 INFO [src.node.waku_node] REST service is ready !!
2026-02-25 15:28:36.402 INFO [src.node.api_clients.base_client] curl -v -X POST "http://127.0.0.1:51993/admin/v1/peers" -H "Content-Type: application/json" -d '["/ip4/172.18.120.119/tcp/51616/p2p/16Uiu2HAmUz51dfwduCsVvCVAN1BMipur59tBByVqAehZELzWVCGR"]'
2026-02-25 15:28:36.405 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'OK'
2026-02-25 15:28:36.405 DEBUG [src.libs.common] Sleeping for 65 seconds
2026-02-25 15:29:41.406 DEBUG [src.steps.store] Checking that peer wakuorg/nwaku:latest can find the stored messages
2026-02-25 15:29:41.406 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:51993/store/v3/messages?pubsubTopic=%2Fwaku%2F2%2Frs%2F3%2F0&pageSize=100&ascending=true" -H "Content-Type: application/json" -d 'None'
2026-02-25 15:29:41.410 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'{"requestId":"","statusCode":200,"statusDesc":"OK","messages":[{"messageHash":"0xb3d0bcfec0de9fdad58743560bc54acd869c661c28c86c43acc1b6c9149f64ea"},{"messageHash":"0x0b6059d92de719e74e35ca9e2efc12659fd2667dee5c2d2d8fe0070823b533f2"},{"messageHash":"0x99c687839ef4ba98e44039fdacfcc113ac95c54231985e1698e11ba7ed8454f3"},{"messageHash":"0x2e1fe760a4b7f00080db7c5334996e7d90d732112c631dbc9ae0e24f691b87b5"},{"messageHash":"0x2e1ac187ef64fc1f4d11b95801871ebdefd7d6e2da2f51043ddf3006d4795005"},{"messageHash":"0x4515e5ee5c4f1a9ed89926fa4df53bfbbd8d56117c627062fc034dd7b0706854"},{"messageHash":"0x655083de6c72b17443f4bec87a0e683c572b02ce50072c997e23fef8879ef888"},{"messageHash":"0x60f75dcc80f217baa4b2edf1c26eb1abb6ae6e129c08e2258221a2d8fc5aea41"},{"messageHash":"0x2df259a633bd4a609b8357f9fe5c5194e5661f1a5826ebe52694f0029c955f17"},{"messageHash":"0xe3820b5786ffa800e5af6065f838740fd878ce099329d3571e95667012483c31"}]}'
2026-02-25 15:29:41.411 DEBUG [src.steps.store] messages length is 10
2026-02-25 15:29:41.413 DEBUG [tests.conftest] Running fixture teardown: test_setup
2026-02-25 15:29:41.414 DEBUG [tests.conftest] Running fixture teardown: close_open_nodes
2026-02-25 15:29:41.415 DEBUG [src.node.waku_node] Stopping container with id 795467d5a628
2026-02-25 15:29:42.023 DEBUG [src.node.waku_node] Container stopped.
2026-02-25 15:29:42.023 DEBUG [src.node.waku_node] Stopping container with id 945d97e4bdce
2026-02-25 15:29:42.653 DEBUG [src.node.waku_node] Container stopped.
2026-02-25 15:29:42.656 DEBUG [tests.conftest] Running fixture teardown: check_waku_log_errors
2026-02-25 15:29:42.718 DEBUG [src.node.docker_mananger] No errors found in the waku logs.
2026-02-25 15:29:42.744 DEBUG [src.node.docker_mananger] No errors found in the waku logs.