Skip to content

Commit

Permalink
Add basic tests
Browse files Browse the repository at this point in the history
Signed-off-by: Saibato <saibato.naga@pm.me>
  • Loading branch information
Saibato committed Nov 17, 2019
1 parent e478a5d commit 1cb6281
Showing 1 changed file with 69 additions and 0 deletions.
69 changes: 69 additions & 0 deletions tests/test_gossip.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
import subprocess
import time
import unittest
import socket


with open('config.vars') as configfile:
Expand Down Expand Up @@ -1587,3 +1588,71 @@ def test_gossip_ratelimit(node_factory):
check=True, timeout=TIMEOUT)

wait_for(lambda: [c['fee_per_millionth'] for c in l3.rpc.listchannels()['channels']] == [1006])


def check_socket(ip_addr, port):

sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# let's also check for fatal and try it ;-)
try:
result = sock.connect_ex((ip_addr, port))
sock.close()
except Exception:
return False

return not result


@unittest.skipIf(not DEVELOPER, "needs a running Tor service instance at port 9151 or 9051")
def test_statictor_onions(node_factory):
"""First basic tests ;-)
Assume that tor is configured and just test
if we see the right onion address for our blob
you can test with your local branch by comment the
with PYTHONPATH=contrib/pylightning py.test -v tests/test_gossip.py -k test_statictor_onions
"""
# please define your values
torip = '127.0.0.1'
toripps = '127.0.0.1:9051'
torport = 9050
torserviceport = 9051

if not check_socket(format(torip), torserviceport):
return

if not check_socket(format(torip), torport):
return

l1 = node_factory.get_node(may_fail=True, options={'addr': ['statictor:'.format(toripps)]})
l2 = node_factory.get_node(may_fail=True, options={'addr': ['statictor:'.format(toripps, '/torblob=11234567890123456789012345678901')]})

assert l1.daemon.is_in_log('127.0.0.1:'.format(l1.port))
assert l2.daemon.is_in_log('x2y4zvh4fn5q3eouuh7nxnc7zeawrqoutljrup2xjtiyxgx3emgkemad.onion:9735,127.0.0.1:'.format(l2.port))


@unittest.skipIf(not DEVELOPER, "needs a running Tor service instance at port 9151 or 9051")
def test_torport_onions(node_factory):
"""First basic tests for torport ;-)
Assume that tor is configured and just test
if we see the right onion address for our blob
with PYTHONPATH=contrib/pylightning py.test -v tests/test_gossip.py -k test_torport_onions
"""
# please define your values
torip = '127.0.0.1'
toripps = '127.0.0.1:9051'
torport = 9050
torserviceport = 9051

if not check_socket(format(torip), torserviceport):
return

if not check_socket(format(torip), torport):
return

l1 = node_factory.get_node(may_fail=True, options={'addr': ['statictor:'.format(toripps, '/torport=45321')]})
l2 = node_factory.get_node(may_fail=True, options={'addr': ['statictor:'.format(toripps, '/torport=45321:torblob=11234567890123456789012345678901')]})

assert l1.daemon.is_in_log('45321,127.0.0.1:'.format(l1.port))
assert l2.daemon.is_in_log('x2y4zvh4fn5q3eouuh7nxnc7zeawrqoutljrup2xjtiyxgx3emgkemad.onion:45321,127.0.0.1:'.format(l2.port))

0 comments on commit 1cb6281

Please sign in to comment.