mirror of
https://github.com/tahoe-lafs/tahoe-lafs.git
synced 2025-01-21 12:05:03 +00:00
test_runner: fix to use new conventions
create-node needs --hostname=, and we can't expect the node to write client.port at startup (because tahoe.cfg now has tub.port= set properly)
This commit is contained in:
parent
38ebdfac20
commit
229e306e9d
@ -262,14 +262,14 @@ class CreateNode(unittest.TestCase):
|
|||||||
command)
|
command)
|
||||||
|
|
||||||
def test_node(self):
|
def test_node(self):
|
||||||
self.do_create("node")
|
self.do_create("node", "--hostname=127.0.0.1")
|
||||||
|
|
||||||
def test_client(self):
|
def test_client(self):
|
||||||
# create-client should behave like create-node --no-storage.
|
# create-client should behave like create-node --no-storage.
|
||||||
self.do_create("client")
|
self.do_create("client")
|
||||||
|
|
||||||
def test_introducer(self):
|
def test_introducer(self):
|
||||||
self.do_create("introducer")
|
self.do_create("introducer", "--hostname=127.0.0.1")
|
||||||
|
|
||||||
def test_stats_gatherer(self):
|
def test_stats_gatherer(self):
|
||||||
self.do_create("stats-gatherer", "--hostname=127.0.0.1")
|
self.do_create("stats-gatherer", "--hostname=127.0.0.1")
|
||||||
@ -340,7 +340,6 @@ class RunNode(common_util.SignalMixin, unittest.TestCase, pollmixin.PollMixin,
|
|||||||
exit_trigger_file = os.path.join(c1, Client.EXIT_TRIGGER_FILE)
|
exit_trigger_file = os.path.join(c1, Client.EXIT_TRIGGER_FILE)
|
||||||
twistd_pid_file = os.path.join(c1, "twistd.pid")
|
twistd_pid_file = os.path.join(c1, "twistd.pid")
|
||||||
introducer_furl_file = os.path.join(c1, "private", "introducer.furl")
|
introducer_furl_file = os.path.join(c1, "private", "introducer.furl")
|
||||||
portnum_file = os.path.join(c1, "introducer.port")
|
|
||||||
node_url_file = os.path.join(c1, "node.url")
|
node_url_file = os.path.join(c1, "node.url")
|
||||||
config_file = os.path.join(c1, "tahoe.cfg")
|
config_file = os.path.join(c1, "tahoe.cfg")
|
||||||
|
|
||||||
@ -390,11 +389,9 @@ class RunNode(common_util.SignalMixin, unittest.TestCase, pollmixin.PollMixin,
|
|||||||
d.addCallback(lambda res: self.poll(_node_has_started))
|
d.addCallback(lambda res: self.poll(_node_has_started))
|
||||||
|
|
||||||
def _started(res):
|
def _started(res):
|
||||||
# read the introducer.furl and introducer.port files so we can
|
# read the introducer.furl file so we can check that the contents
|
||||||
# check that their contents don't change on restart
|
# don't change on restart
|
||||||
self.furl = fileutil.read(introducer_furl_file)
|
self.furl = fileutil.read(introducer_furl_file)
|
||||||
self.failUnless(os.path.exists(portnum_file))
|
|
||||||
self.portnum = fileutil.read(portnum_file)
|
|
||||||
|
|
||||||
fileutil.write(exit_trigger_file, "")
|
fileutil.write(exit_trigger_file, "")
|
||||||
self.failUnless(os.path.exists(twistd_pid_file))
|
self.failUnless(os.path.exists(twistd_pid_file))
|
||||||
@ -418,14 +415,13 @@ class RunNode(common_util.SignalMixin, unittest.TestCase, pollmixin.PollMixin,
|
|||||||
# so poll until it is. This time introducer_furl_file already
|
# so poll until it is. This time introducer_furl_file already
|
||||||
# exists, so we check for the existence of node_url_file instead.
|
# exists, so we check for the existence of node_url_file instead.
|
||||||
def _node_has_restarted():
|
def _node_has_restarted():
|
||||||
return os.path.exists(node_url_file) and os.path.exists(portnum_file)
|
return os.path.exists(node_url_file)
|
||||||
d.addCallback(lambda res: self.poll(_node_has_restarted))
|
d.addCallback(lambda res: self.poll(_node_has_restarted))
|
||||||
|
|
||||||
def _check_same_furl_and_port(res):
|
def _check_same_furl(res):
|
||||||
self.failUnless(os.path.exists(introducer_furl_file))
|
self.failUnless(os.path.exists(introducer_furl_file))
|
||||||
self.failUnlessEqual(self.furl, fileutil.read(introducer_furl_file))
|
self.failUnlessEqual(self.furl, fileutil.read(introducer_furl_file))
|
||||||
self.failUnlessEqual(self.portnum, fileutil.read(portnum_file))
|
d.addCallback(_check_same_furl)
|
||||||
d.addCallback(_check_same_furl_and_port)
|
|
||||||
|
|
||||||
# Now we can kill it. TODO: On a slow machine, the node might kill
|
# Now we can kill it. TODO: On a slow machine, the node might kill
|
||||||
# itself before we get a chance to, especially if spawning the
|
# itself before we get a chance to, especially if spawning the
|
||||||
@ -463,7 +459,7 @@ class RunNode(common_util.SignalMixin, unittest.TestCase, pollmixin.PollMixin,
|
|||||||
c1 = os.path.join(basedir, "c1")
|
c1 = os.path.join(basedir, "c1")
|
||||||
exit_trigger_file = os.path.join(c1, Client.EXIT_TRIGGER_FILE)
|
exit_trigger_file = os.path.join(c1, Client.EXIT_TRIGGER_FILE)
|
||||||
twistd_pid_file = os.path.join(c1, "twistd.pid")
|
twistd_pid_file = os.path.join(c1, "twistd.pid")
|
||||||
portnum_file = os.path.join(c1, "client.port")
|
node_url_file = os.path.join(c1, "node.url")
|
||||||
|
|
||||||
d = self.run_bintahoe(["--quiet", "create-client", "--basedir", c1, "--webport", "0"])
|
d = self.run_bintahoe(["--quiet", "create-client", "--basedir", c1, "--webport", "0"])
|
||||||
def _cb(res):
|
def _cb(res):
|
||||||
@ -506,7 +502,7 @@ class RunNode(common_util.SignalMixin, unittest.TestCase, pollmixin.PollMixin,
|
|||||||
d.addCallback(_cb2)
|
d.addCallback(_cb2)
|
||||||
|
|
||||||
def _node_has_started():
|
def _node_has_started():
|
||||||
return os.path.exists(portnum_file)
|
return os.path.exists(node_url_file)
|
||||||
d.addCallback(lambda res: self.poll(_node_has_started))
|
d.addCallback(lambda res: self.poll(_node_has_started))
|
||||||
|
|
||||||
# now we can kill it. TODO: On a slow machine, the node might kill
|
# now we can kill it. TODO: On a slow machine, the node might kill
|
||||||
@ -527,11 +523,13 @@ class RunNode(common_util.SignalMixin, unittest.TestCase, pollmixin.PollMixin,
|
|||||||
c1 = os.path.join(basedir, "c1")
|
c1 = os.path.join(basedir, "c1")
|
||||||
exit_trigger_file = os.path.join(c1, Client.EXIT_TRIGGER_FILE)
|
exit_trigger_file = os.path.join(c1, Client.EXIT_TRIGGER_FILE)
|
||||||
twistd_pid_file = os.path.join(c1, "twistd.pid")
|
twistd_pid_file = os.path.join(c1, "twistd.pid")
|
||||||
portnum_file = os.path.join(c1, "client.port")
|
|
||||||
node_url_file = os.path.join(c1, "node.url")
|
node_url_file = os.path.join(c1, "node.url")
|
||||||
|
storage_furl_file = os.path.join(c1, "private", "storage.furl")
|
||||||
config_file = os.path.join(c1, "tahoe.cfg")
|
config_file = os.path.join(c1, "tahoe.cfg")
|
||||||
|
|
||||||
d = self.run_bintahoe(["--quiet", "create-node", "--basedir", c1, "--webport", "0", "--hostname", "localhost"])
|
d = self.run_bintahoe(["--quiet", "create-node", "--basedir", c1,
|
||||||
|
"--webport", "0",
|
||||||
|
"--hostname", "localhost"])
|
||||||
def _cb(res):
|
def _cb(res):
|
||||||
out, err, rc_or_sig = res
|
out, err, rc_or_sig = res
|
||||||
self.failUnlessEqual(rc_or_sig, 0)
|
self.failUnlessEqual(rc_or_sig, 0)
|
||||||
@ -540,9 +538,9 @@ class RunNode(common_util.SignalMixin, unittest.TestCase, pollmixin.PollMixin,
|
|||||||
config = fileutil.read(config_file)
|
config = fileutil.read(config_file)
|
||||||
self.failUnlessIn('\nweb.port = 0\n', config)
|
self.failUnlessIn('\nweb.port = 0\n', config)
|
||||||
|
|
||||||
# By writing this file, we get two minutes before the client will exit. This ensures
|
# By writing this file, we get two minutes before the client will
|
||||||
# that even if the 'stop' command doesn't work (and the test fails), the client should
|
# exit. This ensures that even if the 'stop' command doesn't work
|
||||||
# still terminate.
|
# (and the test fails), the client should still terminate.
|
||||||
fileutil.write(exit_trigger_file, "")
|
fileutil.write(exit_trigger_file, "")
|
||||||
# now it's safe to start the node
|
# now it's safe to start the node
|
||||||
d.addCallback(_cb)
|
d.addCallback(_cb)
|
||||||
@ -570,14 +568,13 @@ class RunNode(common_util.SignalMixin, unittest.TestCase, pollmixin.PollMixin,
|
|||||||
d.addCallback(_cb2)
|
d.addCallback(_cb2)
|
||||||
|
|
||||||
def _node_has_started():
|
def _node_has_started():
|
||||||
# this depends upon both files being created atomically
|
return os.path.exists(node_url_file)
|
||||||
return os.path.exists(node_url_file) and os.path.exists(portnum_file)
|
|
||||||
d.addCallback(lambda res: self.poll(_node_has_started))
|
d.addCallback(lambda res: self.poll(_node_has_started))
|
||||||
|
|
||||||
def _started(res):
|
def _started(res):
|
||||||
# read the client.port file so we can check that its contents
|
# read the storage.furl file so we can check that its contents
|
||||||
# don't change on restart
|
# don't change on restart
|
||||||
self.portnum = fileutil.read(portnum_file)
|
self.storage_furl = fileutil.read(storage_furl_file)
|
||||||
|
|
||||||
fileutil.write(exit_trigger_file, "")
|
fileutil.write(exit_trigger_file, "")
|
||||||
self.failUnless(os.path.exists(twistd_pid_file))
|
self.failUnless(os.path.exists(twistd_pid_file))
|
||||||
@ -601,9 +598,10 @@ class RunNode(common_util.SignalMixin, unittest.TestCase, pollmixin.PollMixin,
|
|||||||
# so poll until it is
|
# so poll until it is
|
||||||
d.addCallback(lambda res: self.poll(_node_has_started))
|
d.addCallback(lambda res: self.poll(_node_has_started))
|
||||||
|
|
||||||
def _check_same_port(res):
|
def _check_same_furl(res):
|
||||||
self.failUnlessEqual(self.portnum, fileutil.read(portnum_file))
|
self.failUnlessEqual(self.storage_furl,
|
||||||
d.addCallback(_check_same_port)
|
fileutil.read(storage_furl_file))
|
||||||
|
d.addCallback(_check_same_furl)
|
||||||
|
|
||||||
# now we can kill it. TODO: On a slow machine, the node might kill
|
# now we can kill it. TODO: On a slow machine, the node might kill
|
||||||
# itself before we get a chance to, especially if spawning the
|
# itself before we get a chance to, especially if spawning the
|
||||||
|
Loading…
Reference in New Issue
Block a user