[Merge] lp:~jamesodhunt/upstart/python-upstart-module into lp:upstart
Dmitrijs Ledkovs
launchpad at surgut.co.uk
Mon Aug 5 10:06:25 UTC 2013
To integrate with unittest, it would be nice to do:
$ touch scripts/tests/__init__.py
$ bzr add scripts/tests/__init__.py
After that, i'd expect:
$ cd scripts/
$ python3 -m unittest
to run all tests (skip as appropriate), instead this happens:
.....FF
======================================================================
FAIL: test_chroot_session_reexec (tests.test_pyupstart_system_init.TestSystemInitChrootSession)
----------------------------------------------------------------------
Traceback (most recent call last):
File "/home/xnox/canonical/upstart/upstart/scripts/tests/test_pyupstart_system_init.py", line 46, in setUp
self.assertEqual(os.geteuid(), 0)
AssertionError: 1000 != 0
======================================================================
FAIL: test_pid1_reexec (tests.test_pyupstart_system_init.TestSystemInitReExec)
----------------------------------------------------------------------
Traceback (most recent call last):
File "/home/xnox/canonical/upstart/upstart/scripts/tests/test_pyupstart_system_init.py", line 46, in setUp
self.assertEqual(os.geteuid(), 0)
AssertionError: 1000 != 0
----------------------------------------------------------------------
Ran 7 tests in 5.281s
FAILED (failures=2)
Furthermore, it seems like there is information missing on how to run the system test:
xnox at sochi:~/canonical/upstart/upstart/scripts$ sudo python3 -m unittest -v tests.test_pyupstart_system_init
test_chroot_session_reexec (tests.test_pyupstart_system_init.TestSystemInitChrootSession) ... skipped 'UPSTART_TEST_CHROOT_PATH variable not set'
test_pid1_reexec (tests.test_pyupstart_system_init.TestSystemInitReExec) ... ERROR:dbus.proxies:Introspect error on None:/com/ubuntu/Upstart: dbus.exceptions.DBusException: org.freedesktop.DBus.Error.NoReply: Did not receive a reply. Possible causes include: the remote application did not send a reply, the message bus security policy blocked the reply, the reply timeout expired, or the network connection was broken.
ERROR
======================================================================
ERROR: test_pid1_reexec (tests.test_pyupstart_system_init.TestSystemInitReExec)
----------------------------------------------------------------------
Traceback (most recent call last):
File "./tests/test_pyupstart_system_init.py", line 103, in test_pid1_reexec
job.start()
File "./pyupstart.py", line 553, in start
instance_path = self.interface.Start(dbus.Array(env, 's'), wait)
File "/usr/lib/python3/dist-packages/dbus/proxies.py", line 145, in __call__
**keywords)
File "/usr/lib/python3/dist-packages/dbus/connection.py", line 651, in call_blocking
message, timeout)
dbus.exceptions.DBusException: org.freedesktop.DBus.Error.Disconnected: Connection is closed
----------------------------------------------------------------------
Ran 2 tests in 1.037s
FAILED (errors=1, skipped=1)
So I think, when not root, the system tests should use skip them-self.
I'm still trying to create propoer environment to run the chroot test. Need to reboot.
--
https://code.launchpad.net/~jamesodhunt/upstart/python-upstart-module/+merge/157549
Your team Upstart Reviewers is subscribed to branch lp:upstart.
More information about the upstart-devel
mailing list