#!/usr/bin/env python
+import errno
import datetime
import pkg_resources
import os
def call(args, logger):
logger.write('%s\n' % ' '.join(args))
logger.flush()
- p = subprocess.Popen(args, stdout=logger, stderr=logger)
- p.wait()
+ try:
+ p = subprocess.Popen(args, stdout=logger, stderr=logger)
+ p.wait()
+ except OSError as ex:
+ if ex.errno == errno.ENOEXEC:
+ logger.write('Userdata empty or not executable: %s\n' % str(ex))
+ return os.EX_OK
+ else:
+ logger.write('OS error running userdata: %s\n' % str(ex))
+ return os.EX_OSERR
+ except Exception as ex:
+ logger.write('Unknown error running userdata: %s\n' % str(ex))
+ return os.EX_SOFTWARE
return p.returncode
# License for the specific language governing permissions and limitations
# under the License.
-
+import errno
import mox
import os
import pkg_resources
from nose.plugins.attrib import attr
-import heat.cloudinit.loguserdata as loguserdata
+from heat.cloudinit import loguserdata
class FakeCiVersion():
loguserdata.main(log)
self.m.VerifyAll()
- def test_main_fails(self):
+ def test_main_script_empty(self):
log = StringIO.StringIO()
+ pkg_resources.get_distribution('cloud-init').AndReturn(
+ FakeCiVersion('0.7.0'))
+
+ os.chmod('/var/lib/heat-cfntools/cfn-userdata', 0700).AndReturn(None)
+ subprocess.Popen(
+ ['/var/lib/heat-cfntools/cfn-userdata'],
+ stderr=log,
+ stdout=log).AndRaise(OSError(errno.ENOEXEC, "empty script"))
+
+ self.m.ReplayAll()
+ self.assertEqual(None, loguserdata.main(log))
+
+ self.m.VerifyAll()
+
+ def test_main_os_error(self):
+
+ log = StringIO.StringIO()
+
+ pkg_resources.get_distribution('cloud-init').AndReturn(
+ FakeCiVersion('0.7.0'))
+
+ os.chmod('/var/lib/heat-cfntools/cfn-userdata', 0700).AndReturn(None)
+ subprocess.Popen(
+ ['/var/lib/heat-cfntools/cfn-userdata'],
+ stderr=log,
+ stdout=log).AndRaise(OSError(errno.ENOENT, "no such file"))
+
+ self.m.ReplayAll()
+ self.assertEqual(os.EX_OSERR, loguserdata.main(log))
+
+ self.m.VerifyAll()
+
+ def test_main_error_other(self):
+ log = StringIO.StringIO()
+ pkg_resources.get_distribution('cloud-init').AndReturn(
+ FakeCiVersion('0.7.0'))
+ os.chmod('/var/lib/heat-cfntools/cfn-userdata', 0700).AndReturn(None)
+ subprocess.Popen(
+ ['/var/lib/heat-cfntools/cfn-userdata'],
+ stderr=log,
+ stdout=log).AndRaise(IOError("read failed"))
+
+ self.m.ReplayAll()
+ self.assertEqual(os.EX_SOFTWARE, loguserdata.main(log))
+ self.m.VerifyAll()
+
+ def test_main_fails(self):
+ log = StringIO.StringIO()
+
#fail on ci version
pkg_resources.get_distribution('cloud-init').AndReturn(
FakeCiVersion('0.5.0'))
-
#fail on execute cfn-userdata
pkg_resources.get_distribution('cloud-init').AndReturn(
FakeCiVersion('0.7.0'))
self.m.ReplayAll()
self.assertEqual(-1, loguserdata.main(log))
self.assertEqual(-2, loguserdata.main(log))
-
self.m.VerifyAll()