forked from ungleich-public/cdist
		
	Merge branch 'preos' into 4.0-pre-not-stable
This commit is contained in:
		
				commit
				
					
						03f99a0e55
					
				
			
		
					 27 changed files with 154 additions and 75 deletions
				
			
		| 
						 | 
					@ -23,22 +23,17 @@ state_is="$(cat "$__object/explorer/state")"
 | 
				
			||||||
owner_is="$(cat "$__object/explorer/owner")"
 | 
					owner_is="$(cat "$__object/explorer/owner")"
 | 
				
			||||||
group_is="$(cat "$__object/explorer/group")"
 | 
					group_is="$(cat "$__object/explorer/group")"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
state_should=present
 | 
					state_should="$(cat "$__object/parameter/state")"
 | 
				
			||||||
[ -f "$__object/parameter/state" ] && state_should="$(cat "$__object/parameter/state")"
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
branch=master
 | 
					branch="$(cat "$__object/parameter/branch")"
 | 
				
			||||||
[ -f "$__object/parameter/branch" ] && branch="$(cat "$__object/parameter/branch")"
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
source="$(cat "$__object/parameter/source")"
 | 
					source="$(cat "$__object/parameter/source")"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
destination="/$__object_id"
 | 
					destination="/$__object_id"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
owner=""
 | 
					owner="$(cat "$__object/parameter/owner")"
 | 
				
			||||||
[ -f "$__object/parameter/owner" ] && owner="$(cat "$__object/parameter/owner")"
 | 
					group="$(cat "$__object/parameter/group")"
 | 
				
			||||||
group=""
 | 
					mode="$(cat "$__object/parameter/mode")"
 | 
				
			||||||
[ -f "$__object/parameter/group" ] && group="$(cat "$__object/parameter/group")"
 | 
					 | 
				
			||||||
mode=""
 | 
					 | 
				
			||||||
[ -f "$__object/parameter/mode" ] && mode="$(cat "$__object/parameter/mode")"
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
[  "$state_should" = "$state_is" -a \
 | 
					[  "$state_should" = "$state_is" -a \
 | 
				
			||||||
   "$owner" = "$owner_is" -a \
 | 
					   "$owner" = "$owner_is" -a \
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -23,8 +23,7 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
__package git --state present
 | 
					__package git --state present
 | 
				
			||||||
 | 
					
 | 
				
			||||||
state_should=present
 | 
					state_should="$(cat "$__object/parameter/state")"
 | 
				
			||||||
[ -f "$__object/parameter/state" ] && state_should="$(cat "$__object/parameter/state")"
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Let __directory handle removal of git repos
 | 
					# Let __directory handle removal of git repos
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										1
									
								
								cdist/conf/type/__git/parameter/default/branch
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								cdist/conf/type/__git/parameter/default/branch
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					master
 | 
				
			||||||
							
								
								
									
										1
									
								
								cdist/conf/type/__git/parameter/default/group
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								cdist/conf/type/__git/parameter/default/group
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
							
								
								
									
										1
									
								
								cdist/conf/type/__git/parameter/default/mode
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								cdist/conf/type/__git/parameter/default/mode
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
							
								
								
									
										1
									
								
								cdist/conf/type/__git/parameter/default/owner
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								cdist/conf/type/__git/parameter/default/owner
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
							
								
								
									
										1
									
								
								cdist/conf/type/__git/parameter/default/state
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								cdist/conf/type/__git/parameter/default/state
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					present
 | 
				
			||||||
| 
						 | 
					@ -22,17 +22,9 @@
 | 
				
			||||||
#  virtual machines.
 | 
					#  virtual machines.
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if [ -f "$__object/parameter/jaildir" ]; then
 | 
					 | 
				
			||||||
jaildir="$(cat "$__object/parameter/jaildir")"
 | 
					jaildir="$(cat "$__object/parameter/jaildir")"
 | 
				
			||||||
else
 | 
					 | 
				
			||||||
   jaildir="/usr/jail"
 | 
					 | 
				
			||||||
fi
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
if [ -f "$__object/parameter/jailbase" ]; then
 | 
					 | 
				
			||||||
jailbase="$(cat "$__object/parameter/jailbase")"
 | 
					jailbase="$(cat "$__object/parameter/jailbase")"
 | 
				
			||||||
else
 | 
					 | 
				
			||||||
   jailbase=""
 | 
					 | 
				
			||||||
fi
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
state="$(cat "$__object/parameter/state")"
 | 
					state="$(cat "$__object/parameter/state")"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -66,11 +66,7 @@ else
 | 
				
			||||||
   devfsenable="true"
 | 
					   devfsenable="true"
 | 
				
			||||||
fi
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if [ -f "$__object/parameter/devfs-ruleset" ]; then
 | 
					 | 
				
			||||||
devfsruleset="$(cat "$__object/parameter/devfs-ruleset")"
 | 
					devfsruleset="$(cat "$__object/parameter/devfs-ruleset")"
 | 
				
			||||||
else
 | 
					 | 
				
			||||||
   devfsruleset="jailrules"
 | 
					 | 
				
			||||||
fi
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
# devfs_ruleset being defined without devfs_enable being true
 | 
					# devfs_ruleset being defined without devfs_enable being true
 | 
				
			||||||
#     is pointless. Treat this as an error.
 | 
					#     is pointless. Treat this as an error.
 | 
				
			||||||
| 
						 | 
					@ -84,14 +80,11 @@ if [ -f "$__object/parameter/onboot" ]; then
 | 
				
			||||||
   onboot="true"
 | 
					   onboot="true"
 | 
				
			||||||
fi
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if [ -f "$__object/parameter/jaildir" ]; then
 | 
					 | 
				
			||||||
jaildir="$(cat "$__object/parameter/jaildir")"
 | 
					jaildir="$(cat "$__object/parameter/jaildir")"
 | 
				
			||||||
else
 | 
					 | 
				
			||||||
   jaildir="/usr/jail"
 | 
					 | 
				
			||||||
fi
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
present="$(cat "$__object/explorer/present")"
 | 
					present="$(cat "$__object/explorer/present")"
 | 
				
			||||||
status="$(cat "$__object/explorer/status")"
 | 
					status="$(cat "$__object/explorer/status")"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Handle ip="iface|addr, iface|addr" format
 | 
					# Handle ip="iface|addr, iface|addr" format
 | 
				
			||||||
if [ $(expr "${ip}" : ".*|.*") -gt "0" ]; then
 | 
					if [ $(expr "${ip}" : ".*|.*") -gt "0" ]; then
 | 
				
			||||||
   # If we have multiple IPs defined, $interface doesn't make sense because ip="iface|addr, iface|addr" implies it
 | 
					   # If we have multiple IPs defined, $interface doesn't make sense because ip="iface|addr, iface|addr" implies it
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -33,11 +33,7 @@ if [ ! "$os" = "freebsd" ]; then
 | 
				
			||||||
	exit 1
 | 
						exit 1
 | 
				
			||||||
fi
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if [ -f "$__object/parameter/jaildir" ]; then
 | 
					 | 
				
			||||||
jaildir="$(cat "$__object/parameter/jaildir")"
 | 
					jaildir="$(cat "$__object/parameter/jaildir")"
 | 
				
			||||||
else
 | 
					 | 
				
			||||||
   jaildir="/usr/jail"
 | 
					 | 
				
			||||||
fi
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
__directory ${jaildir} --parents
 | 
					__directory ${jaildir} --parents
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										1
									
								
								cdist/conf/type/__jail/parameter/default/devfs-ruleset
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								cdist/conf/type/__jail/parameter/default/devfs-ruleset
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					jailrules
 | 
				
			||||||
							
								
								
									
										1
									
								
								cdist/conf/type/__jail/parameter/default/jailbase
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								cdist/conf/type/__jail/parameter/default/jailbase
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
							
								
								
									
										1
									
								
								cdist/conf/type/__jail/parameter/default/jaildir
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								cdist/conf/type/__jail/parameter/default/jaildir
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					/usr/jail
 | 
				
			||||||
| 
						 | 
					@ -27,11 +27,7 @@ else
 | 
				
			||||||
   name="$__object_id"
 | 
					   name="$__object_id"
 | 
				
			||||||
fi
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if [ -f "$__object/parameter/state" ]; then
 | 
					 | 
				
			||||||
state_should="$(cat "$__object/parameter/state")"
 | 
					state_should="$(cat "$__object/parameter/state")"
 | 
				
			||||||
else
 | 
					 | 
				
			||||||
   state_should="present"
 | 
					 | 
				
			||||||
fi
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
if grep -q -E "(centos|redhat|amazon)" "$__global/explorer/os"; then
 | 
					if grep -q -E "(centos|redhat|amazon)" "$__global/explorer/os"; then
 | 
				
			||||||
    opts="-y --quiet"
 | 
					    opts="-y --quiet"
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										1
									
								
								cdist/conf/type/__package_yum/parameter/default/state
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								cdist/conf/type/__package_yum/parameter/default/state
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					present
 | 
				
			||||||
| 
						 | 
					@ -34,17 +34,8 @@ else
 | 
				
			||||||
    name="$__object_id"
 | 
					    name="$__object_id"
 | 
				
			||||||
fi
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if [ -f "$__object/parameter/state" ]; then
 | 
					 | 
				
			||||||
state_should="$(cat "$__object/parameter/state")"
 | 
					state_should="$(cat "$__object/parameter/state")"
 | 
				
			||||||
else
 | 
					 | 
				
			||||||
    state_should="present"
 | 
					 | 
				
			||||||
fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if [ -f "$__object/parameter/ptype" ]; then
 | 
					 | 
				
			||||||
ptype="$(cat "$__object/parameter/ptype")"
 | 
					ptype="$(cat "$__object/parameter/ptype")"
 | 
				
			||||||
else
 | 
					 | 
				
			||||||
    ptype="package"
 | 
					 | 
				
			||||||
fi
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
if [ -f "$__object/parameter/version" ]; then
 | 
					if [ -f "$__object/parameter/version" ]; then
 | 
				
			||||||
    version_should="$(cat "$__object/parameter/version")"
 | 
					    version_should="$(cat "$__object/parameter/version")"
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										1
									
								
								cdist/conf/type/__package_zypper/parameter/default/state
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								cdist/conf/type/__package_zypper/parameter/default/state
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					present
 | 
				
			||||||
| 
						 | 
					@ -19,7 +19,7 @@
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
 | 
					
 | 
				
			||||||
user="$(cat "$__object/parameter/user" 2>/dev/null || echo "$__object_id")"
 | 
					user="$(cat "$__object/parameter/user" 2>/dev/null || echo "$__object_id")"
 | 
				
			||||||
state_should="$(cat "$__object/parameter/state" 2>/dev/null || echo "present")"
 | 
					state_should="$(cat "$__object/parameter/state")"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
mkdir "$__object/files"
 | 
					mkdir "$__object/files"
 | 
				
			||||||
# file has to be sorted for comparison with `comm`
 | 
					# file has to be sorted for comparison with `comm`
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										1
									
								
								cdist/conf/type/__user_groups/parameter/default/state
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								cdist/conf/type/__user_groups/parameter/default/state
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					present
 | 
				
			||||||
| 
						 | 
					@ -72,6 +72,7 @@ class Emulator(object):
 | 
				
			||||||
            raise MissingRequiredEnvironmentVariableError(e.args[0])
 | 
					            raise MissingRequiredEnvironmentVariableError(e.args[0])
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        self.object_base_path = os.path.join(self.global_path, "object")
 | 
					        self.object_base_path = os.path.join(self.global_path, "object")
 | 
				
			||||||
 | 
					        self.typeorder_path = os.path.join(self.global_path, "typeorder")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        self.type_name      = os.path.basename(argv[0])
 | 
					        self.type_name      = os.path.basename(argv[0])
 | 
				
			||||||
        self.cdist_type     = core.CdistType(self.type_base_path, self.type_name)
 | 
					        self.cdist_type     = core.CdistType(self.type_base_path, self.type_name)
 | 
				
			||||||
| 
						 | 
					@ -129,7 +130,6 @@ class Emulator(object):
 | 
				
			||||||
        self.args = parser.parse_args(self.argv[1:])
 | 
					        self.args = parser.parse_args(self.argv[1:])
 | 
				
			||||||
        self.log.debug('Args: %s' % self.args)
 | 
					        self.log.debug('Args: %s' % self.args)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 | 
				
			||||||
    def setup_object(self):
 | 
					    def setup_object(self):
 | 
				
			||||||
        # Setup object_id - FIXME: unset / do not setup anymore!
 | 
					        # Setup object_id - FIXME: unset / do not setup anymore!
 | 
				
			||||||
        if not self.cdist_type.is_singleton:
 | 
					        if not self.cdist_type.is_singleton:
 | 
				
			||||||
| 
						 | 
					@ -145,18 +145,21 @@ class Emulator(object):
 | 
				
			||||||
            if value is not None:
 | 
					            if value is not None:
 | 
				
			||||||
                self.parameters[key] = value
 | 
					                self.parameters[key] = value
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if self.cdist_object.exists and not 'CDIST_ALLOW_OVERRIDE' in os.environ:
 | 
					        if self.cdist_object.exists and not 'CDIST_OVERRIDE' in self.env:
 | 
				
			||||||
            if self.cdist_object.parameters != self.parameters:
 | 
					            if self.cdist_object.parameters != self.parameters:
 | 
				
			||||||
                raise cdist.Error("Object %s already exists with conflicting parameters:\n%s: %s\n%s: %s"
 | 
					                raise cdist.Error("Object %s already exists with conflicting parameters:\n%s: %s\n%s: %s"
 | 
				
			||||||
                    % (self.cdist_object.name, " ".join(self.cdist_object.source), self.cdist_object.parameters, self.object_source, self.parameters)
 | 
					                    % (self.cdist_object.name, " ".join(self.cdist_object.source), self.cdist_object.parameters, self.object_source, self.parameters)
 | 
				
			||||||
            )
 | 
					            )
 | 
				
			||||||
        else:
 | 
					        else:
 | 
				
			||||||
            if self.cdist_object.exists:
 | 
					            if self.cdist_object.exists:
 | 
				
			||||||
                self.log.debug('Object %s override forced with CDIST_ALLOW_OVERRIDE',self.cdist_object.name)
 | 
					                self.log.debug('Object %s override forced with CDIST_OVERRIDE',self.cdist_object.name)
 | 
				
			||||||
                self.cdist_object.create(True)
 | 
					                self.cdist_object.create(True)
 | 
				
			||||||
            else:
 | 
					            else:
 | 
				
			||||||
                self.cdist_object.create()
 | 
					                self.cdist_object.create()
 | 
				
			||||||
            self.cdist_object.parameters = self.parameters
 | 
					            self.cdist_object.parameters = self.parameters
 | 
				
			||||||
 | 
					            # record the created object in typeorder file
 | 
				
			||||||
 | 
					            with open(self.typeorder_path, 'a') as typeorderfile:
 | 
				
			||||||
 | 
					                print(self.cdist_object.name, file=typeorderfile)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        # Record / Append source
 | 
					        # Record / Append source
 | 
				
			||||||
        self.cdist_object.source.append(self.object_source)
 | 
					        self.cdist_object.source.append(self.object_source)
 | 
				
			||||||
| 
						 | 
					@ -186,6 +189,23 @@ class Emulator(object):
 | 
				
			||||||
    def record_requirements(self):
 | 
					    def record_requirements(self):
 | 
				
			||||||
        """record requirements"""
 | 
					        """record requirements"""
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if "CDIST_ORDER_DEPENDENCY" in self.env:
 | 
				
			||||||
 | 
					            # load object name created bevor this one from typeorder file ...
 | 
				
			||||||
 | 
					            with open(self.typeorder_path, 'r') as typecreationfile:
 | 
				
			||||||
 | 
					                typecreationorder = typecreationfile.readlines()
 | 
				
			||||||
 | 
					                # get the type created bevore this one ...
 | 
				
			||||||
 | 
					                try:
 | 
				
			||||||
 | 
					                    lastcreatedtype = typecreationorder[-2].strip()
 | 
				
			||||||
 | 
					                    if 'require' in self.env:
 | 
				
			||||||
 | 
					                        self.env['require'] += " " + lastcreatedtype
 | 
				
			||||||
 | 
					                    else:
 | 
				
			||||||
 | 
					                        self.env['require'] = lastcreatedtype
 | 
				
			||||||
 | 
					                    self.log.debug("Injecting require for CDIST_ORDER_DEPENDENCY: %s for %s", lastcreatedtype, self.cdist_object.name)
 | 
				
			||||||
 | 
					                except IndexError:
 | 
				
			||||||
 | 
					                    # if no second last line, we are on the first type, so do not set a requirement
 | 
				
			||||||
 | 
					                    pass
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if "require" in self.env:
 | 
					        if "require" in self.env:
 | 
				
			||||||
            requirements = self.env['require']
 | 
					            requirements = self.env['require']
 | 
				
			||||||
            self.log.debug("reqs = " + requirements)
 | 
					            self.log.debug("reqs = " + requirements)
 | 
				
			||||||
| 
						 | 
					@ -203,7 +223,7 @@ class Emulator(object):
 | 
				
			||||||
                    self.log.error("%s requires object %s without object id. Defined at %s"  % (self.cdist_object.name, requirement, self.object_source))
 | 
					                    self.log.error("%s requires object %s without object id. Defined at %s"  % (self.cdist_object.name, requirement, self.object_source))
 | 
				
			||||||
                    raise
 | 
					                    raise
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                self.log.debug("Recording requirement: " + requirement)
 | 
					                self.log.debug("Recording requirement: %s", requirement)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                # Save the sanitised version, not the user supplied one
 | 
					                # Save the sanitised version, not the user supplied one
 | 
				
			||||||
                # (__file//bar => __file/bar)
 | 
					                # (__file//bar => __file/bar)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -58,10 +58,10 @@ class ObjectClassTestCase(test.CdistTestCase):
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def test_list_type_names(self):
 | 
					    def test_list_type_names(self):
 | 
				
			||||||
        type_names = list(cdist.core.CdistObject.list_type_names(object_base_path))
 | 
					        type_names = list(cdist.core.CdistObject.list_type_names(object_base_path))
 | 
				
			||||||
        self.assertEqual(type_names, ['__first', '__second', '__third'])
 | 
					        self.assertEqual(sorted(type_names), ['__first', '__second', '__third'])
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def test_list_objects(self):
 | 
					    def test_list_objects(self):
 | 
				
			||||||
        found_objects = list(core.CdistObject.list_objects(object_base_path, type_base_path))
 | 
					        found_objects = sorted(list(core.CdistObject.list_objects(object_base_path, type_base_path)))
 | 
				
			||||||
        self.assertEqual(found_objects, self.expected_objects)
 | 
					        self.assertEqual(found_objects, self.expected_objects)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def test_create_singleton(self):
 | 
					    def test_create_singleton(self):
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -34,7 +34,7 @@ class TypeTestCase(test.CdistTestCase):
 | 
				
			||||||
    def test_list_type_names(self):
 | 
					    def test_list_type_names(self):
 | 
				
			||||||
        base_path = op.join(fixtures, 'list_types')
 | 
					        base_path = op.join(fixtures, 'list_types')
 | 
				
			||||||
        type_names = core.CdistType.list_type_names(base_path)
 | 
					        type_names = core.CdistType.list_type_names(base_path)
 | 
				
			||||||
        self.assertEqual(type_names, ['__first', '__second', '__third'])
 | 
					        self.assertEqual(sorted(type_names), ['__first', '__second', '__third'])
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def test_list_types(self):
 | 
					    def test_list_types(self):
 | 
				
			||||||
        base_path = op.join(fixtures, 'list_types')
 | 
					        base_path = op.join(fixtures, 'list_types')
 | 
				
			||||||
| 
						 | 
					@ -44,7 +44,7 @@ class TypeTestCase(test.CdistTestCase):
 | 
				
			||||||
            core.CdistType(base_path, '__second'),
 | 
					            core.CdistType(base_path, '__second'),
 | 
				
			||||||
            core.CdistType(base_path, '__third'),
 | 
					            core.CdistType(base_path, '__third'),
 | 
				
			||||||
        ]
 | 
					        ]
 | 
				
			||||||
        self.assertEqual(types, types_expected)
 | 
					        self.assertEqual(sorted(types), types_expected)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def test_only_one_instance(self):
 | 
					    def test_only_one_instance(self):
 | 
				
			||||||
        base_path = fixtures
 | 
					        base_path = fixtures
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -2,6 +2,7 @@
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# 2010-2011 Steven Armstrong (steven-cdist at armstrong.cc)
 | 
					# 2010-2011 Steven Armstrong (steven-cdist at armstrong.cc)
 | 
				
			||||||
# 2012-2013 Nico Schottelius (nico-cdist at schottelius.org)
 | 
					# 2012-2013 Nico Schottelius (nico-cdist at schottelius.org)
 | 
				
			||||||
 | 
					# 2014      Daniel Heule     (hda at sfs.biz)
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# This file is part of cdist.
 | 
					# This file is part of cdist.
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
| 
						 | 
					@ -129,6 +130,44 @@ class AutoRequireEmulatorTestCase(test.CdistTestCase):
 | 
				
			||||||
        expected = ['__planet/Saturn', '__moon/Prometheus']
 | 
					        expected = ['__planet/Saturn', '__moon/Prometheus']
 | 
				
			||||||
        self.assertEqual(sorted(cdist_object.autorequire), sorted(expected))
 | 
					        self.assertEqual(sorted(cdist_object.autorequire), sorted(expected))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class OverrideTestCase(test.CdistTestCase):
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    def setUp(self):
 | 
				
			||||||
 | 
					        self.temp_dir = self.mkdtemp()
 | 
				
			||||||
 | 
					        handle, self.script = self.mkstemp(dir=self.temp_dir)
 | 
				
			||||||
 | 
					        os.close(handle)
 | 
				
			||||||
 | 
					        base_path = self.temp_dir
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        self.local = local.Local(
 | 
				
			||||||
 | 
					            target_host=self.target_host,
 | 
				
			||||||
 | 
					            base_path=base_path,
 | 
				
			||||||
 | 
					            exec_path=test.cdist_exec_path,
 | 
				
			||||||
 | 
					            add_conf_dirs=[conf_dir])
 | 
				
			||||||
 | 
					        self.local.create_files_dirs()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        self.manifest = core.Manifest(self.target_host, self.local)
 | 
				
			||||||
 | 
					        self.env = self.manifest.env_initial_manifest(self.script)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    def tearDown(self):
 | 
				
			||||||
 | 
					        shutil.rmtree(self.temp_dir)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    def test_override_negative(self):
 | 
				
			||||||
 | 
					        argv = ['__file', '/tmp/foobar']
 | 
				
			||||||
 | 
					        emu = emulator.Emulator(argv, env=self.env)
 | 
				
			||||||
 | 
					        emu.run()
 | 
				
			||||||
 | 
					        argv = ['__file', '/tmp/foobar','--mode','404']
 | 
				
			||||||
 | 
					        emu = emulator.Emulator(argv, env=self.env)
 | 
				
			||||||
 | 
					        self.assertRaises(cdist.Error, emu.run)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    def test_override_feature(self):
 | 
				
			||||||
 | 
					        argv = ['__file', '/tmp/foobar']
 | 
				
			||||||
 | 
					        emu = emulator.Emulator(argv, env=self.env)
 | 
				
			||||||
 | 
					        emu.run()
 | 
				
			||||||
 | 
					        argv = ['__file', '/tmp/foobar','--mode','404']
 | 
				
			||||||
 | 
					        self.env['CDIST_OVERRIDE'] = 'on'
 | 
				
			||||||
 | 
					        emu = emulator.Emulator(argv, env=self.env)
 | 
				
			||||||
 | 
					        emu.run()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class ArgumentsTestCase(test.CdistTestCase):
 | 
					class ArgumentsTestCase(test.CdistTestCase):
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -182,7 +221,7 @@ class ArgumentsTestCase(test.CdistTestCase):
 | 
				
			||||||
        object_id = 'some-id'
 | 
					        object_id = 'some-id'
 | 
				
			||||||
        value = 'some value'
 | 
					        value = 'some value'
 | 
				
			||||||
        argv = [type_name, object_id, '--required1', value, '--required2', value]
 | 
					        argv = [type_name, object_id, '--required1', value, '--required2', value]
 | 
				
			||||||
        print(self.env)
 | 
					#        print(self.env)
 | 
				
			||||||
        os.environ.update(self.env)
 | 
					        os.environ.update(self.env)
 | 
				
			||||||
        emu = emulator.Emulator(argv)
 | 
					        emu = emulator.Emulator(argv)
 | 
				
			||||||
        emu.run()
 | 
					        emu.run()
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -9,19 +9,27 @@ Changelog
 | 
				
			||||||
	* Core: Integrate initial preos support
 | 
						* Core: Integrate initial preos support
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
3.0.6:
 | 
					3.0.7: 2014-02-08
 | 
				
			||||||
 | 
						* Core: Allow dependencies to be created based execution order (Daniel Heule)
 | 
				
			||||||
 | 
						* Core: Add tests for override (Daniel Heule)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					3.0.6: 2014-02-06
 | 
				
			||||||
	* New Type: __apt_key (Steven Armstrong)
 | 
						* New Type: __apt_key (Steven Armstrong)
 | 
				
			||||||
	* New Type: __apt_key_uri (Steven Armstrong)
 | 
						* New Type: __apt_key_uri (Steven Armstrong)
 | 
				
			||||||
	* New Type: __apt_norecommends (Steven Armstrong)
 | 
						* New Type: __apt_norecommends (Steven Armstrong)
 | 
				
			||||||
	* New Type: __apt_source (Steven Armstrong)
 | 
						* New Type: __apt_source (Steven Armstrong)
 | 
				
			||||||
 | 
						* New Type: __ccollect_source
 | 
				
			||||||
 | 
						* Type __git: Use default parameters (Daniel Heule)
 | 
				
			||||||
 | 
						* Type __jail: Use default parameters (Daniel Heule)
 | 
				
			||||||
 | 
						* Type __package_yum: Use default parameters (Daniel Heule)
 | 
				
			||||||
 | 
						* Type __package_zypper: Use default parameters (Daniel Heule)
 | 
				
			||||||
 | 
						* Type __user_groups: Use default parameters (Daniel Heule)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
3.0.5: 2014-02-05
 | 
					3.0.5: 2014-02-05
 | 
				
			||||||
	* Core: Introduce override concept (Daniel Heule)
 | 
						* Core: Introduce override concept (Daniel Heule)
 | 
				
			||||||
	* Type __process: Make --state absent work (Steven Armstrong)
 | 
						* Type __process: Make --state absent work (Steven Armstrong)
 | 
				
			||||||
	* Documentation: Update documentation for environment variables
 | 
						* Documentation: Update documentation for environment variables
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 | 
				
			||||||
3.0.4: 2014-01-29
 | 
					3.0.4: 2014-01-29
 | 
				
			||||||
	* Core: Ignore install types in config mode
 | 
						* Core: Ignore install types in config mode
 | 
				
			||||||
	* Documentation: Update reference (files path in object space)
 | 
						* Documentation: Update reference (files path in object space)
 | 
				
			||||||
| 
						 | 
					@ -31,7 +39,6 @@ Changelog
 | 
				
			||||||
	* Type __debconf_set_selections: Support --file - to read from stdin
 | 
						* Type __debconf_set_selections: Support --file - to read from stdin
 | 
				
			||||||
	* Type __jail: Fix jaildir parameter handling (Jake Guffey)
 | 
						* Type __jail: Fix jaildir parameter handling (Jake Guffey)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 | 
				
			||||||
3.0.3: 2014-01-22
 | 
					3.0.3: 2014-01-22
 | 
				
			||||||
	* Core: Enhance error message when requirement is missing object id
 | 
						* Core: Enhance error message when requirement is missing object id
 | 
				
			||||||
	* Core: Add environment variable to select shell for executing scripts (Daniel Heule)
 | 
						* Core: Add environment variable to select shell for executing scripts (Daniel Heule)
 | 
				
			||||||
| 
						 | 
					@ -44,7 +51,6 @@ Changelog
 | 
				
			||||||
	* Type __zypper_repo: Use default paremeters (Daniel Heule)
 | 
						* Type __zypper_repo: Use default paremeters (Daniel Heule)
 | 
				
			||||||
	* Type __zypper_service: Use default paremeters (Daniel Heule)
 | 
						* Type __zypper_service: Use default paremeters (Daniel Heule)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 | 
				
			||||||
3.0.2: 2014-01-19
 | 
					3.0.2: 2014-01-19
 | 
				
			||||||
	* Documentation: Document all messages sent by types (Daniel Heule)
 | 
						* Documentation: Document all messages sent by types (Daniel Heule)
 | 
				
			||||||
	* New Type: __block (Steven Armstrong)
 | 
						* New Type: __block (Steven Armstrong)
 | 
				
			||||||
| 
						 | 
					@ -52,7 +58,6 @@ Changelog
 | 
				
			||||||
	* Type __cron: Replace existing entry when changing it (Daniel Heule)
 | 
						* Type __cron: Replace existing entry when changing it (Daniel Heule)
 | 
				
			||||||
	* Type __ssh_authorized_keys: Use new type __block (Steven Armstrong)
 | 
						* Type __ssh_authorized_keys: Use new type __block (Steven Armstrong)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 | 
				
			||||||
3.0.1: 2014-01-14
 | 
					3.0.1: 2014-01-14
 | 
				
			||||||
	* Core: Copy only files, not directories (Steven Armstrong)
 | 
						* Core: Copy only files, not directories (Steven Armstrong)
 | 
				
			||||||
	* Core: Allow hostnames to start with /
 | 
						* Core: Allow hostnames to start with /
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -239,6 +239,9 @@ require::
 | 
				
			||||||
CDIST_ALLOW_OVERRIDE::
 | 
					CDIST_ALLOW_OVERRIDE::
 | 
				
			||||||
    Allow overwriting type parameters (see cdist-manifest(7))
 | 
					    Allow overwriting type parameters (see cdist-manifest(7))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					CDIST_ORDER_DEPENDENCY::
 | 
				
			||||||
 | 
					    Create dependencies based on the execution order (see cdist-manifest(7))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
SEE ALSO
 | 
					SEE ALSO
 | 
				
			||||||
--------
 | 
					--------
 | 
				
			||||||
- cdist(1)
 | 
					- cdist(1)
 | 
				
			||||||
| 
						 | 
					@ -246,6 +249,6 @@ SEE ALSO
 | 
				
			||||||
 | 
					
 | 
				
			||||||
COPYING
 | 
					COPYING
 | 
				
			||||||
-------
 | 
					-------
 | 
				
			||||||
Copyright \(C) 2011-2013 Nico Schottelius. Free use of this software is
 | 
					Copyright \(C) 2011-2014 Nico Schottelius. Free use of this software is
 | 
				
			||||||
granted under the terms of the GNU General Public License version 3 (GPLv3).
 | 
					granted under the terms of the GNU General Public License version 3 (GPLv3).
 | 
				
			||||||
eof
 | 
					eof
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -128,19 +128,34 @@ All objects that are created in a type manifest are automatically required
 | 
				
			||||||
from the type that is calling them. This is called "autorequirement" in
 | 
					from the type that is calling them. This is called "autorequirement" in
 | 
				
			||||||
cdist jargon.
 | 
					cdist jargon.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					CREATE DEPENDENCIES FROM EXECUTION ORDER
 | 
				
			||||||
 | 
					-----------------------------------------
 | 
				
			||||||
 | 
					You can tell cdist to execute all types in the order in which they are created 
 | 
				
			||||||
 | 
					in the manifest by setting up the variable CDIST_ORDER_DEPENDENCY.
 | 
				
			||||||
 | 
					When cdist sees that this variable is setup, the current created object
 | 
				
			||||||
 | 
					automatically depends on the previously created object.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					It essentially helps you to build up blocks of code that build upon each other
 | 
				
			||||||
 | 
					(like first creating the directory xyz than the file below the directory).
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					THIS IS A BETA FEATURE AND MAY BE REMOVED OR CHANGED AT ANY TIME.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
OVERRIDES
 | 
					OVERRIDES
 | 
				
			||||||
---------
 | 
					---------
 | 
				
			||||||
In some special cases, you would like to create an already defined object 
 | 
					In some special cases, you would like to create an already defined object 
 | 
				
			||||||
with different parameters. In normal situations this leads to an error in cdist.
 | 
					with different parameters. In normal situations this leads to an error in cdist.
 | 
				
			||||||
If you whish, you can setup the environment variable CDIST_ALLOW_OVERRIDE
 | 
					If you whish, you can setup the environment variable CDIST_OVERRIDE
 | 
				
			||||||
(any value or even empty is ok) to tell cdist, that this object override is 
 | 
					(any value or even empty is ok) to tell cdist, that this object override is 
 | 
				
			||||||
wanted and should be accepted.
 | 
					wanted and should be accepted.
 | 
				
			||||||
ATTENTION: Only use this feature if you are 100% sure in which order 
 | 
					ATTENTION: Only use this feature if you are 100% sure in which order 
 | 
				
			||||||
cdist encounter the affected objects, otherwhise this results 
 | 
					cdist encounter the affected objects, otherwhise this results 
 | 
				
			||||||
into an undefined situation. 
 | 
					into an undefined situation. 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
THIS IS A BETA FEATURE AND MAY BE REMOVED AT ANY TIME.
 | 
					THIS IS A BETA FEATURE AND MAY BE REMOVED OR CHANGED AT ANY TIME.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
EXAMPLES
 | 
					EXAMPLES
 | 
				
			||||||
--------
 | 
					--------
 | 
				
			||||||
| 
						 | 
					@ -190,11 +205,35 @@ __user foobar --password 'some_fancy_hash' --home /home/foobarexample
 | 
				
			||||||
__user foobar --password 'some_other_hash' 
 | 
					__user foobar --password 'some_other_hash' 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# this tells cdist, that you know that this is an override and should be accepted
 | 
					# this tells cdist, that you know that this is an override and should be accepted
 | 
				
			||||||
CDIST_ALLOW_OVERRIDE=yes __user foobar --password 'some_other_hash'
 | 
					CDIST_OVERRIDE=yes __user foobar --password 'some_other_hash'
 | 
				
			||||||
# its only an override, means the parameter --home is not touched 
 | 
					# its only an override, means the parameter --home is not touched 
 | 
				
			||||||
# and stay at the original value of /home/foobarexample
 | 
					# and stay at the original value of /home/foobarexample
 | 
				
			||||||
--------------------------------------------------------------------------------
 | 
					--------------------------------------------------------------------------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Dependencies defined by execution order work as following:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					--------------------------------------------------------------------------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Tells cdist to execute all types in the order in which they are created ...
 | 
				
			||||||
 | 
					export CDIST_ORDER_DEPENDENCY=on
 | 
				
			||||||
 | 
					__sample_type 1
 | 
				
			||||||
 | 
					require="__some_type_somewhere/id" __sample_type 2
 | 
				
			||||||
 | 
					__example_type 23
 | 
				
			||||||
 | 
					# Now this types are executed in the creation order until the variable is unset
 | 
				
			||||||
 | 
					unset CDIST_ORDER_DEPENDENCY
 | 
				
			||||||
 | 
					# all now following types cdist makes the order ..
 | 
				
			||||||
 | 
					__not_in_order_type 42
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# how it works :
 | 
				
			||||||
 | 
					# this lines above are translated to:
 | 
				
			||||||
 | 
					__sample_type 1
 | 
				
			||||||
 | 
					require="__some_type_somewhere/id __sample_type/1" __sample_type 2
 | 
				
			||||||
 | 
					require="__sample_type/2" __example_type 23
 | 
				
			||||||
 | 
					__not_in_order_type 42
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					--------------------------------------------------------------------------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
SEE ALSO
 | 
					SEE ALSO
 | 
				
			||||||
--------
 | 
					--------
 | 
				
			||||||
| 
						 | 
					@ -204,5 +243,5 @@ SEE ALSO
 | 
				
			||||||
 | 
					
 | 
				
			||||||
COPYING
 | 
					COPYING
 | 
				
			||||||
-------
 | 
					-------
 | 
				
			||||||
Copyright \(C) 2010-2012 Nico Schottelius. Free use of this software is
 | 
					Copyright \(C) 2010-2014 Nico Schottelius. Free use of this software is
 | 
				
			||||||
granted under the terms of the GNU General Public License version 3 (GPLv3).
 | 
					granted under the terms of the GNU General Public License version 3 (GPLv3).
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -20,6 +20,6 @@ you can join the
 | 
				
			||||||
### Commercial support
 | 
					### Commercial support
 | 
				
			||||||
 | 
					
 | 
				
			||||||
You can request commercial support for cdist from
 | 
					You can request commercial support for cdist from
 | 
				
			||||||
[my company](http://firma.schottelius.org/english/).
 | 
					[my company](http://www.ungleich.ch/english/).
 | 
				
			||||||
 | 
					
 | 
				
			||||||
[[!tag cdist unix]]
 | 
					[[!tag cdist unix]]
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue