summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Watkins <daniel.watkins@canonical.com>2015-03-25 15:54:19 +0000
committerDaniel Watkins <daniel.watkins@canonical.com>2015-03-25 15:54:19 +0000
commitd52feae7ad38670964edebb0eea5db2c8c80f760 (patch)
tree103bb23c3dbe8f71486406daf4438a37048b94d7
parent1828ac3fa151ec7ff761b34305ed5fb85a9020d1 (diff)
downloadvyos-cloud-init-d52feae7ad38670964edebb0eea5db2c8c80f760.tar.gz
vyos-cloud-init-d52feae7ad38670964edebb0eea5db2c8c80f760.zip
Ensure that the serial console is always closed.
-rw-r--r--cloudinit/sources/DataSourceSmartOS.py9
-rw-r--r--tests/unittests/test_datasource/test_smartos.py12
2 files changed, 17 insertions, 4 deletions
diff --git a/cloudinit/sources/DataSourceSmartOS.py b/cloudinit/sources/DataSourceSmartOS.py
index 61dd044f..237fc140 100644
--- a/cloudinit/sources/DataSourceSmartOS.py
+++ b/cloudinit/sources/DataSourceSmartOS.py
@@ -30,9 +30,11 @@
# Comments with "@datadictionary" are snippets of the definition
import binascii
+import contextlib
import os
import random
import re
+
import serial
from cloudinit import log as logging
@@ -371,11 +373,10 @@ def query_data(noun, seed_device, seed_timeout, strip=False, default=None,
if not noun:
return False
- ser = get_serial(seed_device, seed_timeout)
+ with contextlib.closing(get_serial(seed_device, seed_timeout)) as ser:
+ client = JoyentMetadataClient(ser)
+ response = client.get_metadata(noun)
- client = JoyentMetadataClient(ser)
- response = client.get_metadata(noun)
- ser.close()
if response is None:
return default
diff --git a/tests/unittests/test_datasource/test_smartos.py b/tests/unittests/test_datasource/test_smartos.py
index 39991cc2..28b41eaf 100644
--- a/tests/unittests/test_datasource/test_smartos.py
+++ b/tests/unittests/test_datasource/test_smartos.py
@@ -409,6 +409,18 @@ class TestSmartOSDataSource(helpers.FilesystemMockingTestCase):
self.assertEqual(dsrc.device_name_to_device('FOO'),
mydscfg['disk_aliases']['FOO'])
+ @mock.patch('cloudinit.sources.DataSourceSmartOS.JoyentMetadataClient')
+ @mock.patch('cloudinit.sources.DataSourceSmartOS.get_serial')
+ def test_serial_console_closed_on_error(self, get_serial, metadata_client):
+ class OurException(Exception):
+ pass
+ metadata_client.side_effect = OurException
+ try:
+ DataSourceSmartOS.query_data('noun', 'device', 0)
+ except OurException:
+ pass
+ self.assertEqual(1, get_serial.return_value.close.call_count)
+
def apply_patches(patches):
ret = []