forked from ungleich-public/cdist
		
	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