port test_missing_requirements to config_install unit test
Signed-off-by: Nico Schottelius <nico@bento.schottelius.org>
This commit is contained in:
		
					parent
					
						
							
								e1d8645415
							
						
					
				
			
			
				commit
				
					
						ef24ec4db8
					
				
			
		
					 2 changed files with 44 additions and 57 deletions
				
			
		| 
						 | 
					@ -113,3 +113,9 @@ class ConfigInstallRunTestCase(test.CdistTestCase):
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        with self.assertRaises(cdist.Error):
 | 
					        with self.assertRaises(cdist.Error):
 | 
				
			||||||
            self.config.iterate_until_finished()
 | 
					            self.config.iterate_until_finished()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    def test_missing_requirements(self):
 | 
				
			||||||
 | 
					        first = self.object_index['__first/man']
 | 
				
			||||||
 | 
					        first.requirements = ['__does/not/exist']
 | 
				
			||||||
 | 
					        with self.assertRaises(cdist.Error):
 | 
				
			||||||
 | 
					            self.config.iterate_until_finished()
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -34,77 +34,58 @@ import cdist.context
 | 
				
			||||||
import os.path as op
 | 
					import os.path as op
 | 
				
			||||||
my_dir = op.abspath(op.dirname(__file__))
 | 
					my_dir = op.abspath(op.dirname(__file__))
 | 
				
			||||||
fixtures = op.join(my_dir, 'fixtures')
 | 
					fixtures = op.join(my_dir, 'fixtures')
 | 
				
			||||||
object_base_path = op.join(fixtures, 'object')
 | 
					 | 
				
			||||||
type_base_path = op.join(fixtures, 'type')
 | 
					 | 
				
			||||||
add_conf_dir = op.join(fixtures, 'conf')
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					object_base_path = op.join(fixtures, 'object')
 | 
				
			||||||
 | 
					add_conf_dir = op.join(fixtures, 'conf')
 | 
				
			||||||
 | 
					type_base_path = op.join(add_conf_dir, 'type')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class MockContext(object):
 | 
				
			||||||
 | 
					    """A context object that has the required attributes"""
 | 
				
			||||||
 | 
					    def __init__(self, target_host):
 | 
				
			||||||
 | 
					        self.target_host = target_host
 | 
				
			||||||
 | 
					        self.local = False
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class MockLocal(object):
 | 
				
			||||||
 | 
					    def __init__(self, temp_dir, type_path):
 | 
				
			||||||
 | 
					        self.temp_dir = temp_dir
 | 
				
			||||||
 | 
					        self.object_path = op.join(self.temp_dir, "object")
 | 
				
			||||||
 | 
					        self.type_path = type_path
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class ExecutionOrderTestCase(test.CdistTestCase):
 | 
					class ExecutionOrderTestCase(test.CdistTestCase):
 | 
				
			||||||
    def setUp(self):
 | 
					    def setUp(self):
 | 
				
			||||||
        self.orig_environ = os.environ
 | 
					        # self.orig_environ = os.environ
 | 
				
			||||||
        os.environ = os.environ.copy()
 | 
					        # os.environ = os.environ.copy()
 | 
				
			||||||
 | 
					        # os.environ['__cdist_out_dir'] = self.out_dir
 | 
				
			||||||
 | 
					        # os.environ['__cdist_remote_out_dir'] = self.remote_out_dir
 | 
				
			||||||
 | 
					        # self.out_dir = os.path.join(self.temp_dir, "out")
 | 
				
			||||||
 | 
					        # self.remote_out_dir = os.path.join(self.temp_dir, "remote")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        self.temp_dir = self.mkdtemp()
 | 
					        self.temp_dir = self.mkdtemp()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        self.out_dir = os.path.join(self.temp_dir, "out")
 | 
					        self.context = MockContext(self.target_host)
 | 
				
			||||||
        self.remote_out_dir = os.path.join(self.temp_dir, "remote")
 | 
					        self.context.local = MockLocal(self.temp_dir, type_base_path)
 | 
				
			||||||
 | 
					 | 
				
			||||||
        os.environ['__cdist_out_dir'] = self.out_dir
 | 
					 | 
				
			||||||
        os.environ['__cdist_remote_out_dir'] = self.remote_out_dir
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        self.context = cdist.context.Context(
 | 
					 | 
				
			||||||
            target_host=self.target_host,
 | 
					 | 
				
			||||||
            remote_copy=self.remote_copy,
 | 
					 | 
				
			||||||
            remote_exec=self.remote_exec,
 | 
					 | 
				
			||||||
            add_conf_dirs=[add_conf_dir],
 | 
					 | 
				
			||||||
            exec_path=test.cdist_exec_path,
 | 
					 | 
				
			||||||
            debug=False)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        self.config = config.Config(self.context)
 | 
					        self.config = config.Config(self.context)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        self.objects = list(core.CdistObject.list_objects(object_base_path, type_base_path))
 | 
					        self._init_objects()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    def _init_objects(self):
 | 
				
			||||||
 | 
					        """copy base objects to context directory"""
 | 
				
			||||||
 | 
					        shutil.copytree(object_base_path, self.context.local.object_path)
 | 
				
			||||||
 | 
					        self.objects = list(core.CdistObject.list_objects(self.context.local.object_path, self.context.local.type_path))
 | 
				
			||||||
        self.object_index = dict((o.name, o) for o in self.objects)
 | 
					        self.object_index = dict((o.name, o) for o in self.objects)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        for cdist_object in self.objects:
 | 
				
			||||||
 | 
					            cdist_object.state = core.CdistObject.STATE_UNDEF
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def tearDown(self):
 | 
					    def tearDown(self):
 | 
				
			||||||
        os.environ = self.orig_environ
 | 
					        # os.environ = self.orig_environ
 | 
				
			||||||
        shutil.rmtree(self.temp_dir)
 | 
					        shutil.rmtree(self.temp_dir)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        for o in self.objects:
 | 
					    def test_objects_changed(self):
 | 
				
			||||||
            o.requirements = []
 | 
					        pass
 | 
				
			||||||
 | 
					        # self.assert_True(self.config.iterate_once())
 | 
				
			||||||
    def test_dependency_resolution(self):
 | 
					 | 
				
			||||||
        """Check that the runtime respects the right order"""
 | 
					 | 
				
			||||||
        first_man = self.object_index['__first/man']
 | 
					 | 
				
			||||||
        second_on_the = self.object_index['__second/on-the']
 | 
					 | 
				
			||||||
        third_moon = self.object_index['__third/moon']
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        first_man.requirements = [second_on_the.name]
 | 
					 | 
				
			||||||
        second_on_the.requirements = [third_moon.name]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        self.config.iterate_once()
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        self.assertEqual(
 | 
					 | 
				
			||||||
            self.dependency_resolver.dependencies['__first/man'],
 | 
					 | 
				
			||||||
            [third_moon, second_on_the, first_man]
 | 
					 | 
				
			||||||
        )
 | 
					 | 
				
			||||||
        self.assertTrue(False)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    def test_circular_reference(self):
 | 
					 | 
				
			||||||
        first_man = self.object_index['__first/man']
 | 
					 | 
				
			||||||
        first_woman = self.object_index['__first/woman']
 | 
					 | 
				
			||||||
        first_man.requirements = [first_woman.name]
 | 
					 | 
				
			||||||
        first_woman.requirements = [first_man.name]
 | 
					 | 
				
			||||||
        with self.assertRaises(resolver.CircularReferenceError):
 | 
					 | 
				
			||||||
            self.dependency_resolver.dependencies
 | 
					 | 
				
			||||||
        self.assertTrue(False)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    def test_requirement_not_found(self):
 | 
					 | 
				
			||||||
        first_man = self.object_index['__first/man']
 | 
					 | 
				
			||||||
        first_man.requirements = ['__does/not/exist']
 | 
					 | 
				
			||||||
        with self.assertRaises(cdist.Error):
 | 
					 | 
				
			||||||
            self.dependency_resolver.dependencies
 | 
					 | 
				
			||||||
        self.assertTrue(False)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class NotTheExecutionOrderTestCase(test.CdistTestCase):
 | 
				
			||||||
    def test_implicit_dependencies(self):
 | 
					    def test_implicit_dependencies(self):
 | 
				
			||||||
        self.context.initial_manifest = os.path.join(self.context.local.manifest_path, 'implicit_dependencies')
 | 
					        self.context.initial_manifest = os.path.join(self.context.local.manifest_path, 'implicit_dependencies')
 | 
				
			||||||
        self.config.stage_prepare()
 | 
					        self.config.stage_prepare()
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue