107 lines
19 KiB
Plaintext

2026-03-19 04:39:31.578 DEBUG [tests.conftest] Running fixture setup: test_id
2026-03-19 04:39:31.579 DEBUG [tests.conftest] Running test: test_subscribe_via_api_to_new_content_topics[content_topic_list1] with id: 2026-03-19_04-39-31__fb0f99da-59c5-4ff0-9128-9b4deddb2024
2026-03-19 04:39:31.579 DEBUG [src.steps.common] Running fixture setup: common_setup
2026-03-19 04:39:31.579 DEBUG [src.steps.relay] Running fixture setup: relay_setup
2026-03-19 04:39:31.579 DEBUG [src.steps.sharding] Running fixture setup: sharding_setup
2026-03-19 04:39:31.587 DEBUG [src.node.docker_mananger] Docker client initialized with image wakuorg/nwaku:latest
2026-03-19 04:39:31.587 DEBUG [src.node.waku_node] WakuNode instance initialized with log path ./log/docker/node1_2026-03-19_04-39-31__fb0f99da-59c5-4ff0-9128-9b4deddb2024__wakuorg_nwaku:latest.log
2026-03-19 04:39:31.587 DEBUG [src.node.waku_node] Starting Node...
2026-03-19 04:39:31.588 DEBUG [src.node.docker_mananger] Attempting to create or retrieve network waku
2026-03-19 04:39:31.589 DEBUG [src.node.docker_mananger] Network waku already exists
2026-03-19 04:39:31.589 DEBUG [src.node.docker_mananger] Generated random external IP 172.18.139.130
2026-03-19 04:39:31.589 DEBUG [src.node.docker_mananger] Generated ports ['53741', '53742', '53743', '53744', '53745']
2026-03-19 04:39:31.590 DEBUG [src.node.waku_node] RLN credentials were not set
2026-03-19 04:39:31.590 INFO [src.node.waku_node] RLN credentials not set or credential store not available, starting without RLN
2026-03-19 04:39:31.590 DEBUG [src.node.waku_node] Using volumes []
2026-03-19 04:39:31.590 DEBUG [src.node.docker_mananger] docker run -i -t -p 53741:53741 -p 53742:53742 -p 53743:53743 -p 53744:53744 -p 53745:53745 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=53743 --rest-port=53741 --tcp-port=53742 --discv5-udp-port=53744 --rest-address=0.0.0.0 --nat=extip:172.18.139.130 --peer-exchange=true --discv5-discovery=true --cluster-id=2 --nodekey=daefdad79c4fdd388a792e8dcdbcda36e1ad7a0fbad05ddabfecb53d3c7a339f --shard=0 --metrics-server=true --metrics-server-address=0.0.0.0 --metrics-server-port=53745 --metrics-logging=true --relay=true --filter=true --content-topic=/myapp/1/latest/proto
2026-03-19 04:39:31.779 ERROR [src.node.docker_mananger] Max retries reached for container 97cb571125c7. Exiting log stream.
2026-03-19 04:39:31.782 DEBUG [src.node.docker_mananger] docker network connect --ip 172.18.139.130 waku 7d2964a610f6e9db1e8d7f06ea509d2951089ef5c535a5a950160a14534b0ed5
2026-03-19 04:39:31.817 DEBUG [src.node.docker_mananger] Container started with ID 7d2964a610f6. Setting up logs at ./log/docker/node1_2026-03-19_04-39-31__fb0f99da-59c5-4ff0-9128-9b4deddb2024__wakuorg_nwaku:latest.log
2026-03-19 04:39:31.818 DEBUG [src.node.waku_node] Started container from image wakuorg/nwaku:latest. REST: 53741
2026-03-19 04:39:31.819 DEBUG [src.libs.common] Sleeping for 1 seconds
2026-03-19 04:39:32.335 ERROR [src.node.docker_mananger] Max retries reached for container 887765bb86b0. Exiting log stream.
2026-03-19 04:39:32.819 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:53741/health" -H "Content-Type: application/json" -d 'None'
2026-03-19 04:39:32.822 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'{"nodeHealth":"INITIALIZING","connectionStatus":"Disconnected","protocolsHealth":[]}'
2026-03-19 04:39:32.922 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:53741/health" -H "Content-Type: application/json" -d 'None'
2026-03-19 04:39:32.925 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'{"nodeHealth":"INITIALIZING","connectionStatus":"Disconnected","protocolsHealth":[]}'
2026-03-19 04:39:33.025 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:53741/health" -H "Content-Type: application/json" -d 'None'
2026-03-19 04:39:33.028 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'{"nodeHealth":"INITIALIZING","connectionStatus":"Disconnected","protocolsHealth":[]}'
2026-03-19 04:39:33.128 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:53741/health" -H "Content-Type: application/json" -d 'None'
2026-03-19 04:39:33.131 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'{"nodeHealth":"INITIALIZING","connectionStatus":"Disconnected","protocolsHealth":[]}'
2026-03-19 04:39:33.231 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:53741/health" -H "Content-Type: application/json" -d 'None'
2026-03-19 04:39:33.234 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'{"nodeHealth":"INITIALIZING","connectionStatus":"Disconnected","protocolsHealth":[]}'
2026-03-19 04:39:33.334 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:53741/health" -H "Content-Type: application/json" -d 'None'
2026-03-19 04:39:33.337 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'{"nodeHealth":"READY","connectionStatus":"Connected","protocolsHealth":[{"Relay":"READY"},{"Lightpush":"NOT_MOUNTED"},{"Legacy Lightpush":"NOT_MOUNTED"},{"Filter":"READY"},{"Store":"NOT_MOUNTED"},{"Legacy Store":"NOT_MOUNTED"},{"Peer Exchange":"READY"},{"Rendezvous":"NOT_READY","desc":"No Rendezvous peers are available yet"},{"Mix":"NOT_MOUNTED"},{"Lightpush Client":"READY"},{"Legacy Lightpush Client":"READY"},{"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":"READY"},{"Rln Relay":"NOT_MOUNTED"}]}'
2026-03-19 04:39:33.337 INFO [src.node.waku_node] Node protocols are initialized !!
2026-03-19 04:39:33.337 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:53741/debug/v1/info" -H "Content-Type: application/json" -d 'None'
2026-03-19 04:39:33.340 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'{"listenAddresses":["/ip4/172.18.139.130/tcp/53742/p2p/16Uiu2HAm6bjZnDnaeQfM6GRNRZ9UnFatXMn2vSdHdZTt2S66UTyP","/ip4/172.18.139.130/tcp/53743/ws/p2p/16Uiu2HAm6bjZnDnaeQfM6GRNRZ9UnFatXMn2vSdHdZTt2S66UTyP"],"enrUri":"enr:-L24QMisB6mmHXbgKIjuhDmW4OZhSRLBXIpldPQ1CydFZncyCS6mKHjnIfr6YdVzPeFd6yYL97DLRgcTF97PIckUIbICgmlkgnY0gmlwhKwSi4KKbXVsdGlhZGRyc5YACASsEouCBtHuAAoErBKLggbR790DgnJzhQACAQAAiXNlY3AyNTZrMaECpgRrQTGBMuLBeAxQTWn-c9KxAYDCq0HmCE4tp08Lb9aDdGNwgtHug3VkcILR8IV3YWt1MgU"}'
2026-03-19 04:39:33.340 INFO [src.node.waku_node] REST service is ready !!
2026-03-19 04:39:33.346 DEBUG [src.node.docker_mananger] Docker client initialized with image wakuorg/nwaku:latest
2026-03-19 04:39:33.347 DEBUG [src.node.waku_node] WakuNode instance initialized with log path ./log/docker/node2_2026-03-19_04-39-31__fb0f99da-59c5-4ff0-9128-9b4deddb2024__wakuorg_nwaku:latest.log
2026-03-19 04:39:33.347 DEBUG [src.node.waku_node] Starting Node...
2026-03-19 04:39:33.347 DEBUG [src.node.docker_mananger] Attempting to create or retrieve network waku
2026-03-19 04:39:33.348 DEBUG [src.node.docker_mananger] Network waku already exists
2026-03-19 04:39:33.348 DEBUG [src.node.docker_mananger] Generated random external IP 172.18.152.150
2026-03-19 04:39:33.348 DEBUG [src.node.docker_mananger] Generated ports ['59530', '59531', '59532', '59533', '59534']
2026-03-19 04:39:33.349 DEBUG [src.node.waku_node] RLN credentials were not set
2026-03-19 04:39:33.349 INFO [src.node.waku_node] RLN credentials not set or credential store not available, starting without RLN
2026-03-19 04:39:33.349 DEBUG [src.node.waku_node] Using volumes []
2026-03-19 04:39:33.349 DEBUG [src.node.docker_mananger] docker run -i -t -p 59530:59530 -p 59531:59531 -p 59532:59532 -p 59533:59533 -p 59534:59534 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=59532 --rest-port=59530 --tcp-port=59531 --discv5-udp-port=59533 --rest-address=0.0.0.0 --nat=extip:172.18.152.150 --peer-exchange=true --discv5-discovery=true --cluster-id=2 --nodekey=901aec1031dabeecbaaf19bcfa89dfbd3b9e0e2b0c9e5456eb6f0bb26bcc5616 --shard=0 --metrics-server=true --metrics-server-address=0.0.0.0 --metrics-server-port=59534 --metrics-logging=true --relay=true --discv5-bootstrap-node=enr:-L24QMisB6mmHXbgKIjuhDmW4OZhSRLBXIpldPQ1CydFZncyCS6mKHjnIfr6YdVzPeFd6yYL97DLRgcTF97PIckUIbICgmlkgnY0gmlwhKwSi4KKbXVsdGlhZGRyc5YACASsEouCBtHuAAoErBKLggbR790DgnJzhQACAQAAiXNlY3AyNTZrMaECpgRrQTGBMuLBeAxQTWn-c9KxAYDCq0HmCE4tp08Lb9aDdGNwgtHug3VkcILR8IV3YWt1MgU --content-topic=/myapp/1/latest/proto
2026-03-19 04:39:33.548 DEBUG [src.node.docker_mananger] docker network connect --ip 172.18.152.150 waku e02b4f1a6abc3bc6cb01a231214ff568ecdf8ecf41dda4360ca8c78dac1a8d02
2026-03-19 04:39:33.586 DEBUG [src.node.docker_mananger] Container started with ID e02b4f1a6abc. Setting up logs at ./log/docker/node2_2026-03-19_04-39-31__fb0f99da-59c5-4ff0-9128-9b4deddb2024__wakuorg_nwaku:latest.log
2026-03-19 04:39:33.586 DEBUG [src.node.waku_node] Started container from image wakuorg/nwaku:latest. REST: 59530
2026-03-19 04:39:33.587 DEBUG [src.libs.common] Sleeping for 1 seconds
2026-03-19 04:39:34.588 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:59530/health" -H "Content-Type: application/json" -d 'None'
2026-03-19 04:39:34.591 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'{"nodeHealth":"INITIALIZING","connectionStatus":"Disconnected","protocolsHealth":[]}'
2026-03-19 04:39:34.691 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:59530/health" -H "Content-Type: application/json" -d 'None'
2026-03-19 04:39:34.711 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'{"nodeHealth":"INITIALIZING","connectionStatus":"Disconnected","protocolsHealth":[]}'
2026-03-19 04:39:34.812 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:59530/health" -H "Content-Type: application/json" -d 'None'
2026-03-19 04:39:34.815 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'{"nodeHealth":"READY","connectionStatus":"Connected","protocolsHealth":[{"Relay":"READY"},{"Lightpush":"NOT_MOUNTED"},{"Legacy Lightpush":"NOT_MOUNTED"},{"Filter":"NOT_MOUNTED"},{"Store":"NOT_MOUNTED"},{"Legacy Store":"NOT_MOUNTED"},{"Peer Exchange":"READY"},{"Rendezvous":"NOT_READY","desc":"No Rendezvous peers are available yet"},{"Mix":"NOT_MOUNTED"},{"Lightpush Client":"READY"},{"Legacy Lightpush Client":"READY"},{"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":"READY"},{"Rln Relay":"NOT_MOUNTED"}]}'
2026-03-19 04:39:34.815 INFO [src.node.waku_node] Node protocols are initialized !!
2026-03-19 04:39:34.815 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:59530/debug/v1/info" -H "Content-Type: application/json" -d 'None'
2026-03-19 04:39:34.817 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'{"listenAddresses":["/ip4/172.18.152.150/tcp/59531/p2p/16Uiu2HAmHK24BxRuxikQ5bS3o7BmqeW5wSXGEtDN4XK6dEGqcj8V","/ip4/172.18.152.150/tcp/59532/ws/p2p/16Uiu2HAmHK24BxRuxikQ5bS3o7BmqeW5wSXGEtDN4XK6dEGqcj8V"],"enrUri":"enr:-L24QBpZHMMlWomjrwcHa4dx8p_B4hSaheNaxaOW8DUjap9xQgQRMTIOP7kDjWIwp6sbJo0QUhn_hoNh-dfQzg7S57ICgmlkgnY0gmlwhKwSmJaKbXVsdGlhZGRyc5YACASsEpiWBuiLAAoErBKYlgbojN0DgnJzhQACAQAAiXNlY3AyNTZrMaEDRSy_GhJOSoe9VGnKVQAnXdIPHLTT1n7SkYQeKNMxWLKDdGNwguiLg3VkcILojYV3YWt1MgE"}'
2026-03-19 04:39:34.818 INFO [src.node.waku_node] REST service is ready !!
2026-03-19 04:39:34.818 INFO [src.node.api_clients.base_client] curl -v -X POST "http://127.0.0.1:59530/admin/v1/peers" -H "Content-Type: application/json" -d '["/ip4/172.18.139.130/tcp/53742/p2p/16Uiu2HAm6bjZnDnaeQfM6GRNRZ9UnFatXMn2vSdHdZTt2S66UTyP"]'
2026-03-19 04:39:34.840 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'OK'
2026-03-19 04:39:34.844 INFO [src.node.api_clients.base_client] curl -v -X POST "http://127.0.0.1:53741/relay/v1/auto/subscriptions" -H "Content-Type: application/json" -d '["/waku/2/content/test.js", "/app/22/sometopic/someencoding", "/toychat/2/huilong/proto", "/statusim/1/community/cbor", "/app/27/sometopic/someencoding", "/app/29/sometopic/someencoding", "/app/20/sometopic/someencoding"]'
2026-03-19 04:39:34.858 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'OK'
2026-03-19 04:39:34.858 INFO [src.node.api_clients.base_client] curl -v -X POST "http://127.0.0.1:59530/relay/v1/auto/subscriptions" -H "Content-Type: application/json" -d '["/waku/2/content/test.js", "/app/22/sometopic/someencoding", "/toychat/2/huilong/proto", "/statusim/1/community/cbor", "/app/27/sometopic/someencoding", "/app/29/sometopic/someencoding", "/app/20/sometopic/someencoding"]'
2026-03-19 04:39:34.862 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'OK'
2026-03-19 04:39:34.863 INFO [src.node.api_clients.base_client] curl -v -X POST "http://127.0.0.1:53741/relay/v1/auto/messages" -H "Content-Type: application/json" -d '{"payload": "U2hhcmRpbmcgd29ya3MhIQ==", "contentTopic": "/waku/2/content/test.js", "timestamp": '$(date +%s%N)'}'
2026-03-19 04:39:34.874 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'OK'
2026-03-19 04:39:34.874 DEBUG [src.libs.common] Sleeping for 0.1 seconds
2026-03-19 04:39:34.975 DEBUG [src.steps.sharding] Checking that peer NODE_1:wakuorg/nwaku:latest can find the published message
2026-03-19 04:39:34.975 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:53741/relay/v1/auto/messages/%2Fwaku%2F2%2Fcontent%2Ftest.js" -H "Content-Type: application/json" -d 'None'
2026-03-19 04:39:34.979 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'[{"payload":"U2hhcmRpbmcgd29ya3MhIQ==","contentTopic":"/waku/2/content/test.js","version":0,"timestamp":1773895174863623480,"ephemeral":false,"proof":""}]'
2026-03-19 04:39:34.980 DEBUG [src.steps.sharding] Checking that peer NODE_2:wakuorg/nwaku:latest can find the published message
2026-03-19 04:39:34.981 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:59530/relay/v1/auto/messages/%2Fwaku%2F2%2Fcontent%2Ftest.js" -H "Content-Type: application/json" -d 'None'
2026-03-19 04:39:34.983 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'[{"payload":"U2hhcmRpbmcgd29ya3MhIQ==","contentTopic":"/waku/2/content/test.js","version":0,"timestamp":1773895174863623480,"ephemeral":false,"proof":""}]'
2026-03-19 04:39:34.984 INFO [src.node.api_clients.base_client] curl -v -X POST "http://127.0.0.1:53741/relay/v1/auto/messages" -H "Content-Type: application/json" -d '{"payload": "U2hhcmRpbmcgd29ya3MhIQ==", "contentTopic": "/app/22/sometopic/someencoding", "timestamp": '$(date +%s%N)'}'
2026-03-19 04:39:34.993 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'OK'
2026-03-19 04:39:34.994 DEBUG [src.libs.common] Sleeping for 0.1 seconds
2026-03-19 04:39:35.094 DEBUG [src.steps.sharding] Checking that peer NODE_1:wakuorg/nwaku:latest can find the published message
2026-03-19 04:39:35.095 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:53741/relay/v1/auto/messages/%2Fapp%2F22%2Fsometopic%2Fsomeencoding" -H "Content-Type: application/json" -d 'None'
2026-03-19 04:39:35.098 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'[{"payload":"U2hhcmRpbmcgd29ya3MhIQ==","contentTopic":"/app/22/sometopic/someencoding","version":0,"timestamp":1773895174984750023,"ephemeral":false,"proof":""}]'
2026-03-19 04:39:35.099 DEBUG [src.steps.sharding] Checking that peer NODE_2:wakuorg/nwaku:latest can find the published message
2026-03-19 04:39:35.100 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:59530/relay/v1/auto/messages/%2Fapp%2F22%2Fsometopic%2Fsomeencoding" -H "Content-Type: application/json" -d 'None'
2026-03-19 04:39:35.102 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'[{"payload":"U2hhcmRpbmcgd29ya3MhIQ==","contentTopic":"/app/22/sometopic/someencoding","version":0,"timestamp":1773895174984750023,"ephemeral":false,"proof":""}]'
2026-03-19 04:39:35.104 INFO [src.node.api_clients.base_client] curl -v -X POST "http://127.0.0.1:53741/relay/v1/auto/messages" -H "Content-Type: application/json" -d '{"payload": "U2hhcmRpbmcgd29ya3MhIQ==", "contentTopic": "/toychat/2/huilong/proto", "timestamp": '$(date +%s%N)'}'
2026-03-19 04:39:35.113 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'OK'
2026-03-19 04:39:35.114 DEBUG [src.libs.common] Sleeping for 0.1 seconds
2026-03-19 04:39:35.215 DEBUG [src.steps.sharding] Checking that peer NODE_1:wakuorg/nwaku:latest can find the published message
2026-03-19 04:39:35.215 INFO [src.node.api_clients.base_client] curl -v -X GET "http://127.0.0.1:53741/relay/v1/auto/messages/%2Ftoychat%2F2%2Fhuilong%2Fproto" -H "Content-Type: application/json" -d 'None'
2026-03-19 04:39:35.218 INFO [src.node.api_clients.base_client] Response status code: 200. Response content: b'[{"payload":"U2hhcmRpbmcgd29ya3MhIQ==","contentTopic":"/toychat/2/huilong/proto","version":0,"timestamp":1773895174845125461,"ephemeral":false,"proof":""},{"payload":"U2hhcmRpbmcgd29ya3MhIQ==","contentTopic":"/toychat/2/huilong/proto","version":0,"timestamp":1773895175104411343,"ephemeral":false,"proof":""}]'
2026-03-19 04:39:35.227 DEBUG [tests.conftest] Running fixture teardown: test_setup
2026-03-19 04:39:35.228 DEBUG [tests.conftest] Running fixture teardown: close_open_nodes
2026-03-19 04:39:35.229 DEBUG [src.node.waku_node] Stopping container with id 7d2964a610f6
2026-03-19 04:39:35.801 DEBUG [src.node.waku_node] Container stopped.
2026-03-19 04:39:35.803 DEBUG [src.node.waku_node] Stopping container with id e02b4f1a6abc
2026-03-19 04:39:36.360 DEBUG [src.node.waku_node] Container stopped.
2026-03-19 04:39:36.363 DEBUG [tests.conftest] Running fixture teardown: check_waku_log_errors
2026-03-19 04:39:36.436 DEBUG [src.node.docker_mananger] No errors found in the waku logs.
2026-03-19 04:39:36.470 DEBUG [src.node.docker_mananger] No errors found in the waku logs.
2026-03-19 04:39:36.470 DEBUG [tests.conftest] Running fixture teardown: attach_logs_on_fail
2026-03-19 04:39:36.470 DEBUG [tests.conftest] Test failed, attempting to attach logs to the allure reports
2026-03-19 04:39:36.471 DEBUG [src.libs.common] Attaching file ./log/docker/node2_2026-03-19_04-39-31__fb0f99da-59c5-4ff0-9128-9b4deddb2024__wakuorg_nwaku:latest.log
2026-03-19 04:39:36.472 DEBUG [src.libs.common] Attaching file ./log/docker/node1_2026-03-19_04-39-31__fb0f99da-59c5-4ff0-9128-9b4deddb2024__wakuorg_nwaku:latest.log