summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorSam Eiderman <sameid@google.com>2019-10-29 23:00:36 +0000
committerServer Team CI Bot <josh.powers+server-team-bot@canonical.com>2019-10-29 23:00:36 +0000
commite1b4b8c903fed3b69e57ec08c17ce94097d55901 (patch)
tree9bc11d884f1e9d4ccacf95705dc7d29651c2b886 /tests
parentf1c788e2bb7c86069d43a015267facfb8aefcdf0 (diff)
downloadvyos-cloud-init-e1b4b8c903fed3b69e57ec08c17ce94097d55901.tar.gz
vyos-cloud-init-e1b4b8c903fed3b69e57ec08c17ce94097d55901.zip
azure: Do not lock user on instance id change
After initial boot ovf-env.xml is copied to agent dir (/var/lib/waagent/) with REDACTED password. On subsequent boots DataSourceAzure loads with a configuration where the user specified in /var/lib/waagent/ovf-env.xml is locked. If instance id changes, cc_users_groups action will lock the user. Fix this behavior by not locking the user if its password is REDACTED. LP: #1849677
Diffstat (limited to 'tests')
-rw-r--r--tests/unittests/test_datasource/test_azure.py16
1 files changed, 16 insertions, 0 deletions
diff --git a/tests/unittests/test_datasource/test_azure.py b/tests/unittests/test_datasource/test_azure.py
index 3547dd94..80c6f019 100644
--- a/tests/unittests/test_datasource/test_azure.py
+++ b/tests/unittests/test_datasource/test_azure.py
@@ -769,6 +769,22 @@ scbus-1 on xpt0 bus 0
crypt.crypt(odata['UserPassword'],
defuser['passwd'][0:pos]))
+ def test_user_not_locked_if_password_redacted(self):
+ odata = {'HostName': "myhost", 'UserName': "myuser",
+ 'UserPassword': dsaz.DEF_PASSWD_REDACTION}
+ data = {'ovfcontent': construct_valid_ovf_env(data=odata)}
+
+ dsrc = self._get_ds(data)
+ ret = dsrc.get_data()
+ self.assertTrue(ret)
+ self.assertTrue('default_user' in dsrc.cfg['system_info'])
+ defuser = dsrc.cfg['system_info']['default_user']
+
+ # default user should be updated username and should not be locked.
+ self.assertEqual(defuser['name'], odata['UserName'])
+ self.assertIn('lock_passwd', defuser)
+ self.assertFalse(defuser['lock_passwd'])
+
def test_userdata_plain(self):
mydata = "FOOBAR"
odata = {'UserData': {'text': mydata, 'encoding': 'plain'}}