forked from ungleich-public/cdist
almost finish correct requirement loading, but need sleep
Signed-off-by: Nico Schottelius <nico@kr.ethz.ch>
This commit is contained in:
parent
0dd38f75c2
commit
ee1c568c7b
2 changed files with 5 additions and 81 deletions
|
@ -148,8 +148,12 @@ class Emulator(object):
|
||||||
if "require" in os.environ:
|
if "require" in os.environ:
|
||||||
requirements = os.environ['require']
|
requirements = os.environ['require']
|
||||||
for requirement in requirements.split(" "):
|
for requirement in requirements.split(" "):
|
||||||
|
self.log.debug("Recording requirement: " + requirement)
|
||||||
requirement_parts = requirement.split(os.sep, 1)
|
requirement_parts = requirement.split(os.sep, 1)
|
||||||
requirement_parts.reverse()
|
# FIXME: continue here
|
||||||
|
FAILHERE,PLEASE()[]!
|
||||||
|
print(requirement)
|
||||||
|
print(requirement_parts)
|
||||||
requirement_type_name = requirement_parts.pop()
|
requirement_type_name = requirement_parts.pop()
|
||||||
try:
|
try:
|
||||||
requirement_object_id = requirement_parts.pop()
|
requirement_object_id = requirement_parts.pop()
|
||||||
|
@ -158,7 +162,6 @@ class Emulator(object):
|
||||||
requirement_object_id = 'singleton'
|
requirement_object_id = 'singleton'
|
||||||
|
|
||||||
requirement_object_id = requirement_object_id.lstrip('/')
|
requirement_object_id = requirement_object_id.lstrip('/')
|
||||||
self.log.debug("Recording requirement: %s -> %s" % (self.cdist_object.path, requirement))
|
|
||||||
self.cdist_object.requirements.append(requirement)
|
self.cdist_object.requirements.append(requirement)
|
||||||
|
|
||||||
# Record / Append source
|
# Record / Append source
|
||||||
|
|
|
@ -1,79 +0,0 @@
|
||||||
#!/usr/bin/env python3
|
|
||||||
# -*- coding: utf-8 -*-
|
|
||||||
#
|
|
||||||
# 2011 Nico Schottelius (nico-cdist at schottelius.org)
|
|
||||||
#
|
|
||||||
# This file is part of cdist.
|
|
||||||
#
|
|
||||||
# cdist is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# cdist is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
#
|
|
||||||
#
|
|
||||||
|
|
||||||
|
|
||||||
import os
|
|
||||||
import shutil
|
|
||||||
import tempfile
|
|
||||||
import unittest
|
|
||||||
|
|
||||||
import cdist.exec
|
|
||||||
|
|
||||||
|
|
||||||
class ExecTestCase(unittest.TestCase):
|
|
||||||
def setUp(self):
|
|
||||||
"""Create shell code and co."""
|
|
||||||
|
|
||||||
self.temp_dir = tempfile.mkdtemp()
|
|
||||||
self.shell_false = os.path.join(self.temp_dir, "shell_false")
|
|
||||||
self.shell_true = os.path.join(self.temp_dir, "shell_true")
|
|
||||||
|
|
||||||
true_fd = open(self.shell_true, "w")
|
|
||||||
true_fd.writelines(["#!/bin/sh\n", "/bin/true"])
|
|
||||||
true_fd.close()
|
|
||||||
|
|
||||||
false_fd = open(self.shell_false, "w")
|
|
||||||
false_fd.writelines(["#!/bin/sh\n", "/bin/false"])
|
|
||||||
false_fd.close()
|
|
||||||
|
|
||||||
target_host = "does.not.exist"
|
|
||||||
remote_exec = "ssh -o User=root -q"
|
|
||||||
remote_copy = "scp -o User=root -q"
|
|
||||||
self.wrapper = cdist.exec.Wrapper(target_host, remote_exec, remote_copy)
|
|
||||||
|
|
||||||
def tearDown(self):
|
|
||||||
shutil.rmtree(self.temp_dir)
|
|
||||||
|
|
||||||
def test_local_success_shell(self):
|
|
||||||
try:
|
|
||||||
self.wrapper.shell_run_or_debug_fail(self.shell_true, [self.shell_true])
|
|
||||||
except cdist.Error:
|
|
||||||
failed = True
|
|
||||||
else:
|
|
||||||
failed = False
|
|
||||||
self.assertFalse(failed)
|
|
||||||
|
|
||||||
def test_local_fail_shell(self):
|
|
||||||
self.assertRaises(cdist.Error, self.wrapper.shell_run_or_debug_fail,
|
|
||||||
self.shell_false, [self.shell_false])
|
|
||||||
|
|
||||||
def test_local_success(self):
|
|
||||||
try:
|
|
||||||
self.wrapper.run_or_fail(["/bin/true"])
|
|
||||||
except cdist.Error:
|
|
||||||
failed = True
|
|
||||||
else:
|
|
||||||
failed = False
|
|
||||||
self.assertFalse(failed)
|
|
||||||
|
|
||||||
def test_local_fail(self):
|
|
||||||
self.assertRaises(cdist.Error, self.wrapper.run_or_fail, ["/bin/false"])
|
|
Loading…
Reference in a new issue