Robustness improvements to the package generator

* Abort if running the zip tool fails
 * Abort if multiple file path rules match a given file
 * Remove part of the special updater binary handling - this needs to be reworked
 * Sort the file paths before feeding them to the zip tool, so that multiple runs with
   with the same set of files will generate the same packages
This commit is contained in:
Robert Knight 2011-09-01 15:56:26 +01:00
parent b39c71638a
commit 9d088dff86

View file

@ -82,6 +82,10 @@ def strip_prefix(string,prefix)
return string.sub(prefix,"") return string.sub(prefix,"")
end end
def file_sha1(path)
return `sha1sum "#{path}"`.split(' ')[0]
end
class UpdateScriptGenerator class UpdateScriptGenerator
# target_version - The version string for the build in this update # target_version - The version string for the build in this update
@ -152,6 +156,7 @@ class UpdateScriptGenerator
platform_elem = REXML::Element.new("platform") platform_elem = REXML::Element.new("platform")
platform_elem.text = @platform platform_elem.text = @platform
update_elem.add_attribute("version","3")
update_elem.add_element version_elem update_elem.add_element version_elem
update_elem.add_element platform_elem update_elem.add_element platform_elem
update_elem.add_element deps_to_xml() update_elem.add_element deps_to_xml()
@ -213,10 +218,6 @@ class UpdateScriptGenerator
return install_elem return install_elem
end end
def file_sha1(path)
return `sha1sum "#{path}"`.split(' ')[0]
end
# Unix permission flags # Unix permission flags
# from <sys/stat.h> # from <sys/stat.h>
S_IRUSR = 0400 S_IRUSR = 0400
@ -289,12 +290,16 @@ class PackageConfig
end end
def package_for_file(file) def package_for_file(file)
match = nil
@rule_map.each do |rule,package| @rule_map.each do |rule,package|
if (file =~ rule) if (file =~ rule)
return package if match && match != package
raise "Multiple packages match file #{file} - found '#{match}' and '#{package}'"
end
match = package
end end
end end
return nil return match
end end
end end
@ -346,15 +351,6 @@ package_file_map = {}
input_file_list.each do |file| input_file_list.each do |file|
next if File.symlink?(file) next if File.symlink?(file)
# do not package the updater binary - leave
# it as a separate standalone tool
if package_config.is_updater(file)
# unless an updater binary has been explicitly specified, use
# the one included with the application
updater_binary_input_path = file if !updater_binary_input_path
next
end
package = package_config.package_for_file(file) package = package_config.package_for_file(file)
if (!package) if (!package)
raise "Unable to find package for file #{file}" raise "Unable to find package for file #{file}"
@ -371,6 +367,24 @@ package_file_map.each do |package,files|
files.each do |file| files.each do |file|
quoted_files << "\"#{strip_prefix(file,input_dir)}\"" quoted_files << "\"#{strip_prefix(file,input_dir)}\""
end end
if (quoted_files.empty?)
puts "Skipping generation of empty package #{package}"
next
end
# sort the files in alphabetical order to ensure
# that if the input files for a package have the same
# name and content, the resulting package will have the
# same SHA-1
#
# This means that repeated runs of the package creation tool
# on the same set of files should generated packages with the
# same SHA-1
quoted_files.sort! do |a,b|
a <=> b
end
quoted_file_list = quoted_files.join(" ") quoted_file_list = quoted_files.join(" ")
output_path = File.expand_path(output_dir) output_path = File.expand_path(output_dir)
@ -379,8 +393,10 @@ package_file_map.each do |package,files|
File.unlink(output_file) if File.exist?(output_file) File.unlink(output_file) if File.exist?(output_file)
Dir.chdir(input_dir) do Dir.chdir(input_dir) do
if (!system("zip #{output_path}/#{package}.zip #{quoted_file_list}")) if (!system("zip #{output_file} #{quoted_file_list}"))
raise "Failed to generate package #{package}" raise "Failed to generate package #{package}"
else
puts "Generated package #{package} : #{file_sha1(output_file)}"
end end
end end
end end