Simple working fakessh_test.
This commit is contained in:
parent
76e476dcfa
commit
3a0f03183c
|
@ -1,42 +1,22 @@
|
||||||
|
|
||||||
|
import os
|
||||||
|
import shutil
|
||||||
|
import unittest
|
||||||
|
|
||||||
import mitogen.utils
|
import mitogen.utils
|
||||||
import mitogen.fakessh
|
import mitogen.fakessh
|
||||||
|
|
||||||
|
import testlib
|
||||||
@mitogen.utils.run_with_router
|
|
||||||
def main(router):
|
|
||||||
import logging
|
|
||||||
mitogen.utils.log_to_file(level=logging.INFO)
|
|
||||||
router.enable_debug()
|
|
||||||
#mitogen.fakessh.run_with_fake_ssh(router, ['bash', '-c', 'echo $PATH'])
|
|
||||||
#mitogen.fakessh.run_with_fake_ssh(router, ['bash', '-c', 'ls -Gl $SSH_PATH'])
|
|
||||||
# k3 = router.ssh(hostname='k3')
|
|
||||||
k3 = router.local()
|
|
||||||
print 'GOT HERE'
|
|
||||||
import os
|
|
||||||
k3.call(os.system, 'hostname')
|
|
||||||
return
|
|
||||||
#sud = router.sudo(via=k3, username='root')
|
|
||||||
sud = k3
|
|
||||||
|
|
||||||
mitogen.fakessh.run_with_fake_ssh(sud, router, ['rsync', '--progress', '-vvvr', 'h:/var/lib/docker'])
|
|
||||||
#mitogen.fakessh.run_with_fake_ssh(router, ['bash', '-c', 'ssh h rsync --server . foo'])
|
|
||||||
# mitogen.fakessh.run_with_fake_ssh(router, ['bash', '-c', 'ssh k3.botanicus.net -t screen -dr'])
|
|
||||||
print 'end of t.py'
|
|
||||||
|
|
||||||
|
|
||||||
import logging
|
class RsyncTest(testlib.DockerMixin, unittest.TestCase):
|
||||||
import mitogen.utils
|
def test_rsync_from_master(self):
|
||||||
import mitogen.fakessh
|
context = self.docker_ssh_any()
|
||||||
|
context.call(shutil.rmtree, '/tmp/data', ignore_errors=True)
|
||||||
@mitogen.utils.run_with_router
|
mitogen.fakessh.run(context, self.router, [
|
||||||
def main(router):
|
'rsync', '--progress', '-vvva',
|
||||||
mitogen.utils.log_to_file(level=logging.DEBUG)
|
testlib.data_path('.'), 'target:/tmp/data'
|
||||||
#router.enable_debug()
|
])
|
||||||
#router.enable_debug()
|
assert context.call(os.path.exists, '/tmp/data')
|
||||||
|
assert context.call(os.path.exists, '/tmp/data/simple_pkg/a.py')
|
||||||
k3 = router.ssh(hostname='k3')
|
|
||||||
sudo = router.sudo(via=k3, username='root')
|
|
||||||
|
|
||||||
mitogen.fakessh.run(sudo, router, ['rsync', '--progress', '-r', 'h:/var/lib/docker'])
|
|
||||||
|
|
||||||
|
|
|
@ -26,10 +26,7 @@ class SshTest(testlib.DockerMixin, unittest.TestCase):
|
||||||
|
|
||||||
def test_password_required(self):
|
def test_password_required(self):
|
||||||
try:
|
try:
|
||||||
context = self.router.ssh(
|
context = self.docker_ssh(
|
||||||
hostname=self.dockerized_ssh.host,
|
|
||||||
port=self.dockerized_ssh.port,
|
|
||||||
check_host_keys=False,
|
|
||||||
username='has-sudo',
|
username='has-sudo',
|
||||||
)
|
)
|
||||||
assert 0, 'exception not thrown'
|
assert 0, 'exception not thrown'
|
||||||
|
@ -40,10 +37,7 @@ class SshTest(testlib.DockerMixin, unittest.TestCase):
|
||||||
|
|
||||||
def test_password_incorrect(self):
|
def test_password_incorrect(self):
|
||||||
try:
|
try:
|
||||||
context = self.router.ssh(
|
context = self.docker_ssh(
|
||||||
hostname=self.dockerized_ssh.host,
|
|
||||||
port=self.dockerized_ssh.port,
|
|
||||||
check_host_keys=False,
|
|
||||||
username='has-sudo',
|
username='has-sudo',
|
||||||
password='badpw',
|
password='badpw',
|
||||||
)
|
)
|
||||||
|
@ -54,10 +48,7 @@ class SshTest(testlib.DockerMixin, unittest.TestCase):
|
||||||
assert e[0] == self.stream_class.password_incorrect_msg
|
assert e[0] == self.stream_class.password_incorrect_msg
|
||||||
|
|
||||||
def test_password_specified(self):
|
def test_password_specified(self):
|
||||||
context = self.router.ssh(
|
context = self.docker_ssh(
|
||||||
hostname=self.dockerized_ssh.host,
|
|
||||||
port=self.dockerized_ssh.port,
|
|
||||||
check_host_keys=False,
|
|
||||||
username='has-sudo',
|
username='has-sudo',
|
||||||
password='y',
|
password='y',
|
||||||
)
|
)
|
||||||
|
@ -67,10 +58,7 @@ class SshTest(testlib.DockerMixin, unittest.TestCase):
|
||||||
|
|
||||||
def test_pubkey_required(self):
|
def test_pubkey_required(self):
|
||||||
try:
|
try:
|
||||||
context = self.router.ssh(
|
context = self.docker_ssh(
|
||||||
hostname=self.dockerized_ssh.host,
|
|
||||||
port=self.dockerized_ssh.port,
|
|
||||||
check_host_keys=False,
|
|
||||||
username='has-sudo-pubkey',
|
username='has-sudo-pubkey',
|
||||||
)
|
)
|
||||||
assert 0, 'exception not thrown'
|
assert 0, 'exception not thrown'
|
||||||
|
@ -80,13 +68,9 @@ class SshTest(testlib.DockerMixin, unittest.TestCase):
|
||||||
assert e[0] == self.stream_class.password_required_msg
|
assert e[0] == self.stream_class.password_required_msg
|
||||||
|
|
||||||
def test_pubkey_specified(self):
|
def test_pubkey_specified(self):
|
||||||
context = self.router.ssh(
|
context = self.docker_ssh(
|
||||||
hostname=self.dockerized_ssh.host,
|
|
||||||
port=self.dockerized_ssh.port,
|
|
||||||
check_host_keys=False,
|
|
||||||
username='has-sudo-pubkey',
|
username='has-sudo-pubkey',
|
||||||
identity_file=testlib.data_path('docker/has-sudo-pubkey.key'),
|
identity_file=testlib.data_path('docker/has-sudo-pubkey.key'),
|
||||||
)
|
)
|
||||||
|
|
||||||
sentinel = 'i-am-mitogen-test-docker-image\n'
|
sentinel = 'i-am-mitogen-test-docker-image\n'
|
||||||
assert sentinel == context.call(plain_old_module.get_sentinel_value)
|
assert sentinel == context.call(plain_old_module.get_sentinel_value)
|
||||||
|
|
|
@ -76,3 +76,15 @@ class DockerMixin(RouterMixin):
|
||||||
def tearDownClass(cls):
|
def tearDownClass(cls):
|
||||||
cls.dockerized_ssh.close()
|
cls.dockerized_ssh.close()
|
||||||
super(DockerMixin, cls).tearDownClass()
|
super(DockerMixin, cls).tearDownClass()
|
||||||
|
|
||||||
|
def docker_ssh(self, **kwargs):
|
||||||
|
kwargs.setdefault('hostname', self.dockerized_ssh.host)
|
||||||
|
kwargs.setdefault('port', self.dockerized_ssh.port)
|
||||||
|
kwargs.setdefault('check_host_keys', False)
|
||||||
|
return self.router.ssh(**kwargs)
|
||||||
|
|
||||||
|
def docker_ssh_any(self, **kwargs):
|
||||||
|
return self.docker_ssh(
|
||||||
|
username='has-sudo-nopw',
|
||||||
|
password='y',
|
||||||
|
)
|
||||||
|
|
Loading…
Reference in New Issue