diff options
author | Jason Zions <jasonzio@microsoft.com> | 2019-01-15 21:37:17 +0000 |
---|---|---|
committer | Server Team CI Bot <josh.powers+server-team-bot@canonical.com> | 2019-01-15 21:37:17 +0000 |
commit | fdadcb5fae51f4e6799314ab98e3aec56c79b17c (patch) | |
tree | 318df8c54326032f8be340633b1642c642b202be /tests/unittests | |
parent | f19dc8fa62d4fd8de33311c3c75c5b6da440bebe (diff) | |
download | vyos-cloud-init-fdadcb5fae51f4e6799314ab98e3aec56c79b17c.tar.gz vyos-cloud-init-fdadcb5fae51f4e6799314ab98e3aec56c79b17c.zip |
net: Wait for dhclient to daemonize before reading lease file
cloud-init uses dhclient to fetch the DHCP lease so it can extract
DHCP options. dhclient creates the leasefile, then writes to it;
simply waiting for the leasefile to appear creates a race between
dhclient and cloud-init. Instead, wait for dhclient to be parented by
init. At that point, we know it has written to the leasefile, so it's
safe to copy the file and kill the process.
cloud-init creates a temporary directory in which to execute dhclient,
and deletes that directory after it has killed the process. If
cloud-init abandons waiting for dhclient to daemonize, it will still
attempt to delete the temporary directory, but will not report an
exception should that attempt fail.
LP: #1794399
Diffstat (limited to 'tests/unittests')
-rw-r--r-- | tests/unittests/test_util.py | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/tests/unittests/test_util.py b/tests/unittests/test_util.py index 5a14479a..0e71db82 100644 --- a/tests/unittests/test_util.py +++ b/tests/unittests/test_util.py @@ -1171,4 +1171,10 @@ class TestGetProcEnv(helpers.TestCase): self.assertEqual({}, util.get_proc_env(1)) self.assertEqual(1, m_load_file.call_count) + def test_get_proc_ppid(self): + """get_proc_ppid returns correct parent pid value.""" + my_pid = os.getpid() + my_ppid = os.getppid() + self.assertEqual(my_ppid, util.get_proc_ppid(my_pid)) + # vi: ts=4 expandtab |