2015-05-07 14:49:54 +00:00
|
|
|
import pytest
|
2015-05-07 13:59:48 +00:00
|
|
|
import subprocess
|
2015-05-08 09:10:17 +00:00
|
|
|
import rancherostest.util as u
|
2015-05-07 13:59:48 +00:00
|
|
|
|
|
|
|
|
2015-05-07 14:49:54 +00:00
|
|
|
@pytest.fixture(scope="module")
|
|
|
|
def qemu(request):
|
2015-05-08 09:10:17 +00:00
|
|
|
return u.run_qemu(request)
|
2015-05-07 14:49:54 +00:00
|
|
|
|
|
|
|
|
2015-05-08 07:51:13 +00:00
|
|
|
def rancheros_version():
|
|
|
|
with open('./scripts/version') as f:
|
|
|
|
for ln in iter(f.readline, ''):
|
|
|
|
(k, _, v) = ln.partition('=')
|
|
|
|
if k == 'VERSION' and v.strip() != '':
|
|
|
|
return v.strip()
|
|
|
|
raise RuntimeError("Could not parse RancherOS version")
|
|
|
|
|
|
|
|
|
2015-05-08 06:51:15 +00:00
|
|
|
@pytest.mark.timeout(30)
|
2015-05-07 14:49:54 +00:00
|
|
|
def test_system_boot(qemu):
|
2015-05-08 08:03:50 +00:00
|
|
|
with qemu.stdout as f:
|
|
|
|
for ln in iter(f.readline, ''):
|
|
|
|
ros_booted_substr = str.find(ln, 'RancherOS {v} started'.format(v=rancheros_version()))
|
|
|
|
print(str.strip(ln))
|
|
|
|
if ros_booted_substr > -1:
|
|
|
|
assert True
|
|
|
|
return
|
2015-05-07 16:01:19 +00:00
|
|
|
assert False
|
|
|
|
|
|
|
|
|
2015-05-08 10:15:14 +00:00
|
|
|
@pytest.mark.timeout(60)
|
2015-05-07 16:01:19 +00:00
|
|
|
def test_run_system_container(qemu):
|
|
|
|
assert qemu.returncode is None
|
2015-05-08 09:25:11 +00:00
|
|
|
|
2015-05-08 09:10:17 +00:00
|
|
|
u.wait_for_ssh()
|
2015-05-07 16:01:19 +00:00
|
|
|
ssh = subprocess.Popen(
|
|
|
|
'./scripts/ssh sudo system-docker run --rm busybox /bin/true', shell=True,
|
2015-05-08 05:42:18 +00:00
|
|
|
stdout=subprocess.PIPE, stderr=subprocess.STDOUT, universal_newlines=True)
|
2015-05-07 16:01:19 +00:00
|
|
|
|
2015-05-08 09:25:11 +00:00
|
|
|
with ssh, ssh.stdout as f:
|
|
|
|
for ln in iter(f.readline, ''):
|
|
|
|
print(str.strip(ln))
|
|
|
|
|
|
|
|
assert ssh.returncode == 0
|