omnibus 3.2.2 → 4.0.0.beta.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +140 -10
- data/CHANGELOG.md +181 -8
- data/README.md +63 -35
- data/Rakefile +1 -1
- data/docs/omnibus-build-cache.md b/data/docs/Build → Cache.md +0 -0
- data/docs/Building on Debian.md +59 -0
- data/docs/Building on OSX.md +61 -35
- data/docs/Building on RHEL.md +74 -0
- data/docs/Building on Windows.md +40 -81
- data/features/commands/build.feature +1 -2
- data/features/commands/clean.feature +1 -1
- data/lib/omnibus.rb +111 -204
- data/lib/omnibus/build_version.rb +3 -20
- data/lib/omnibus/build_version_dsl.rb +2 -3
- data/lib/omnibus/builder.rb +103 -211
- data/lib/omnibus/cleaner.rb +5 -7
- data/lib/omnibus/cli.rb +1 -4
- data/lib/omnibus/cli/base.rb +9 -16
- data/lib/omnibus/compressor.rb +60 -0
- data/{spec/data/complicated/config/software/version-manifest.rb → lib/omnibus/compressors/base.rb} +17 -12
- data/lib/omnibus/compressors/dmg.rb +312 -0
- data/lib/omnibus/{null_builder.rb → compressors/null.rb} +10 -4
- data/lib/omnibus/compressors/tgz.rb +141 -0
- data/lib/omnibus/config.rb +89 -83
- data/lib/omnibus/core_extensions.rb +1 -0
- data/lib/omnibus/core_extensions/open_uri.rb +58 -0
- data/lib/omnibus/digestable.rb +9 -3
- data/lib/omnibus/exceptions.rb +116 -175
- data/lib/omnibus/fetcher.rb +97 -138
- data/lib/omnibus/fetchers/git_fetcher.rb +130 -165
- data/lib/omnibus/fetchers/net_fetcher.rb +205 -164
- data/lib/omnibus/fetchers/{s3_cache_fetcher.rb → null_fetcher.rb} +27 -17
- data/lib/omnibus/fetchers/path_fetcher.rb +74 -32
- data/lib/omnibus/file_syncer.rb +149 -0
- data/lib/omnibus/generator.rb +103 -32
- data/lib/omnibus/generator_files/.kitchen.yml.erb +5 -1
- data/lib/omnibus/generator_files/Gemfile.erb +13 -7
- data/lib/omnibus/generator_files/config/projects/project.rb.erb +28 -0
- data/lib/omnibus/generator_files/config/software/zlib.rb.erb +55 -0
- data/lib/omnibus/generator_files/omnibus.rb.erb +5 -7
- data/lib/omnibus/git_cache.rb +11 -13
- data/lib/omnibus/logger.rb +76 -22
- data/lib/omnibus/logging.rb +1 -1
- data/lib/omnibus/metadata.rb +264 -0
- data/lib/omnibus/ohai.rb +0 -51
- data/lib/omnibus/package.rb +4 -228
- data/lib/omnibus/packager.rb +71 -0
- data/lib/omnibus/packagers/base.rb +118 -176
- data/lib/omnibus/packagers/bff.rb +136 -0
- data/lib/omnibus/packagers/deb.rb +389 -0
- data/lib/omnibus/packagers/makeself.rb +114 -0
- data/lib/omnibus/packagers/msi.rb +346 -0
- data/lib/omnibus/packagers/pkg.rb +278 -0
- data/lib/omnibus/packagers/rpm.rb +438 -0
- data/lib/omnibus/packagers/solaris.rb +110 -0
- data/lib/omnibus/project.rb +263 -666
- data/lib/omnibus/publisher.rb +3 -3
- data/lib/omnibus/s3_cache.rb +21 -30
- data/lib/omnibus/software.rb +132 -271
- data/lib/omnibus/templating.rb +66 -0
- data/lib/omnibus/thread_pool.rb +109 -0
- data/lib/omnibus/util.rb +137 -15
- data/lib/omnibus/version.rb +1 -1
- data/omnibus.gemspec +2 -2
- data/resources/bff/gen.template.erb +22 -0
- data/resources/bff/postinstall.sh +0 -0
- data/resources/bff/unpostinstall.sh +0 -0
- data/resources/deb/conffiles.erb +3 -0
- data/resources/deb/control.erb +25 -0
- data/resources/deb/md5sums.erb +3 -0
- data/{lib/omnibus/generator_files/mac_dmg → resources/dmg}/background.png +0 -0
- data/resources/dmg/create_dmg.osascript.erb +17 -0
- data/{lib/omnibus/generator_files/mac_dmg → resources/dmg}/icon.png +0 -0
- data/{bin → resources/makeself}/makeself-header.sh +0 -0
- data/{bin → resources/makeself}/makeself.sh +0 -0
- data/{lib/omnibus/generator_files/package_scripts/makeselfinst.erb → resources/makeself/post_extract.sh.erb} +4 -4
- data/{lib/omnibus/generator_files/windows_msi → resources/msi}/assets/LICENSE.rtf +0 -0
- data/{lib/omnibus/generator_files/windows_msi → resources/msi}/assets/banner_background.bmp +0 -0
- data/{lib/omnibus/generator_files/windows_msi → resources/msi}/assets/dialog_background.bmp +0 -0
- data/{lib/omnibus/generator_files/windows_msi → resources/msi}/assets/project.ico +0 -0
- data/{lib/omnibus/generator_files/windows_msi → resources/msi}/assets/project_16x16.ico +0 -0
- data/{lib/omnibus/generator_files/windows_msi → resources/msi}/assets/project_32x32.ico +0 -0
- data/{spec/fixtures/sample/files/windows_msi/Resources/localization-en-us.wxl → resources/msi/localization-en-us.wxl.erb} +3 -4
- data/resources/msi/parameters.wxi.erb +9 -0
- data/{lib/omnibus/generator_files/windows_msi → resources/msi}/source.wxs.erb +14 -15
- data/{lib/omnibus/generator_files/mac_pkg → resources/pkg}/background.png +0 -0
- data/resources/pkg/distribution.xml.erb +21 -0
- data/resources/pkg/license.html.erb +3 -0
- data/resources/pkg/welcome.html.erb +7 -0
- data/resources/rpm/rpmmacros.erb +3 -0
- data/resources/rpm/signing.erb +40 -0
- data/resources/rpm/spec.erb +70 -0
- data/spec/functional/builder_spec.rb +90 -111
- data/spec/functional/fetchers/git_fetcher_spec.rb +130 -0
- data/spec/functional/fetchers/net_fetcher_spec.rb +110 -0
- data/spec/functional/fetchers/path_fetcher_spec.rb +97 -0
- data/spec/functional/file_syncer_spec.rb +206 -0
- data/spec/functional/templating_spec.rb +73 -0
- data/spec/spec_helper.rb +31 -94
- data/spec/support/env_helpers.rb +20 -0
- data/spec/support/examples.rb +56 -0
- data/spec/support/file_helpers.rb +46 -0
- data/spec/support/git_helpers.rb +107 -0
- data/spec/support/logging_helpers.rb +33 -0
- data/spec/support/matchers.rb +36 -0
- data/spec/support/ohai_helpers.rb +22 -0
- data/spec/support/path_helpers.rb +19 -0
- data/spec/support/shell_helpers.rb +14 -0
- data/spec/unit/build_version_dsl_spec.rb +0 -17
- data/spec/unit/build_version_spec.rb +1 -19
- data/spec/unit/builder_spec.rb +158 -46
- data/spec/unit/compressor_spec.rb +45 -0
- data/spec/unit/compressors/base_spec.rb +26 -0
- data/spec/unit/compressors/dmg_spec.rb +291 -0
- data/spec/unit/compressors/null_spec.rb +23 -0
- data/spec/unit/compressors/tgz_spec.rb +67 -0
- data/spec/unit/config_spec.rb +27 -34
- data/spec/unit/digestable_spec.rb +4 -4
- data/spec/unit/fetchers/git_fetcher_spec.rb +110 -39
- data/spec/unit/fetchers/net_fetcher_spec.rb +182 -72
- data/spec/unit/fetchers/path_fetcher_spec.rb +111 -0
- data/spec/unit/generator_spec.rb +137 -0
- data/spec/unit/git_cache_spec.rb +24 -34
- data/spec/unit/library_spec.rb +21 -82
- data/spec/unit/metadata_spec.rb +207 -0
- data/spec/unit/ohai_spec.rb +0 -7
- data/spec/unit/omnibus_spec.rb +41 -36
- data/spec/unit/package_spec.rb +1 -216
- data/spec/unit/packagers/base_spec.rb +76 -190
- data/spec/unit/packagers/bff_spec.rb +160 -0
- data/spec/unit/packagers/deb_spec.rb +324 -0
- data/spec/unit/packagers/makeself_spec.rb +80 -0
- data/spec/unit/packagers/msi_spec.rb +267 -0
- data/spec/unit/packagers/pkg_spec.rb +219 -0
- data/spec/unit/packagers/rpm_spec.rb +328 -0
- data/spec/unit/project_spec.rb +217 -80
- data/spec/unit/publisher_spec.rb +6 -2
- data/spec/unit/publishers/artifactory_publisher_spec.rb +1 -1
- data/spec/unit/publishers/s3_publisher_spec.rb +1 -1
- data/spec/unit/s3_cacher_spec.rb +22 -5
- data/spec/unit/software_spec.rb +89 -232
- data/spec/unit/util_spec.rb +188 -0
- metadata +159 -402
- data/features/commands/_deprecated.feature +0 -84
- data/lib/omnibus/cleanroom.rb +0 -141
- data/lib/omnibus/cli/deprecated.rb +0 -132
- data/lib/omnibus/generator_files/mac_pkg/license.html.erb +0 -1
- data/lib/omnibus/generator_files/mac_pkg/welcome.html.erb +0 -9
- data/lib/omnibus/generator_files/project.rb.erb +0 -20
- data/lib/omnibus/generator_files/software/c-example.rb.erb +0 -42
- data/lib/omnibus/generator_files/software/erlang-example.rb.erb +0 -38
- data/lib/omnibus/generator_files/software/ruby-example.rb.erb +0 -24
- data/lib/omnibus/generator_files/windows_msi/localization-en-us.wxl.erb +0 -20
- data/lib/omnibus/generator_files/windows_msi/parameters.wxi.erb +0 -9
- data/lib/omnibus/packagers/mac_dmg.rb +0 -235
- data/lib/omnibus/packagers/mac_pkg.rb +0 -176
- data/lib/omnibus/packagers/windows_msi.rb +0 -109
- data/spec/data/complicated/config/patches/bzip2/makefile_take_env_vars.patch +0 -15
- data/spec/data/complicated/config/patches/couchdb/patch_for_couchjs_stack.patch +0 -19
- data/spec/data/complicated/config/patches/gd/gd-2.0.33-configure-libpng.patch +0 -100
- data/spec/data/complicated/config/patches/keepalived/keepalived-1.2.9_opscode_centos_5.patch +0 -15
- data/spec/data/complicated/config/patches/libedit/freebsd-vi-fix.patch +0 -24
- data/spec/data/complicated/config/patches/libiconv/libiconv-1.14_srclib_stdio.in.h-remove-gets-declarations.patch +0 -29
- data/spec/data/complicated/config/patches/libwrap/tcp_wrappers-7.6-makefile-dest-fix.patch +0 -35
- data/spec/data/complicated/config/patches/libwrap/tcp_wrappers-7.6-malloc-fix.patch +0 -13
- data/spec/data/complicated/config/patches/libwrap/tcp_wrappers-7.6-shared_lib_plus_plus-1.patch +0 -1035
- data/spec/data/complicated/config/patches/logrotate/logrotate_basedir_override.patch +0 -12
- data/spec/data/complicated/config/patches/ncurses/ncurses-5.9-solaris-xopen_source_extended-detection.patch +0 -11
- data/spec/data/complicated/config/patches/ncurses/ncurses-clang.patch +0 -42
- data/spec/data/complicated/config/patches/ncurses/patch-aa +0 -23
- data/spec/data/complicated/config/patches/ncurses/patch-ab +0 -44
- data/spec/data/complicated/config/patches/ncurses/patch-ac +0 -40
- data/spec/data/complicated/config/patches/ncurses/patch-ad +0 -12
- data/spec/data/complicated/config/patches/ncurses/patch-aix-configure +0 -23
- data/spec/data/complicated/config/patches/ncurses/patch-cxx_cursesf.h +0 -22
- data/spec/data/complicated/config/patches/ncurses/patch-cxx_cursesm.h +0 -22
- data/spec/data/complicated/config/patches/nrpe/fix_for_runit.patch +0 -64
- data/spec/data/complicated/config/patches/openssl/openssl-1.0.1f-do-not-build-docs.patch +0 -101
- data/spec/data/complicated/config/patches/postgresql/postgresql-9.1.2-configure-ncurses-fix.patch +0 -12
- data/spec/data/complicated/config/patches/ruby/patch-configure +0 -103
- data/spec/data/complicated/config/patches/ruby/ruby-aix-configure.patch +0 -10
- data/spec/data/complicated/config/patches/ruby/ruby-openssl-1.0.1c.patch +0 -42
- data/spec/data/complicated/config/patches/ruby/ruby_aix_1_9_3_448_ssl_EAGAIN.patch +0 -57
- data/spec/data/complicated/config/patches/ruby/rvm-cflags.patch +0 -27
- data/spec/data/complicated/config/projects/angrychef.rb +0 -32
- data/spec/data/complicated/config/projects/chef-windows.rb +0 -32
- data/spec/data/complicated/config/projects/chef.rb +0 -32
- data/spec/data/complicated/config/projects/chefdk-windows.rb +0 -41
- data/spec/data/complicated/config/projects/chefdk.rb +0 -44
- data/spec/data/complicated/config/software/appbundler.rb +0 -25
- data/spec/data/complicated/config/software/autoconf.rb +0 -35
- data/spec/data/complicated/config/software/automake.rb +0 -39
- data/spec/data/complicated/config/software/berkshelf.rb +0 -44
- data/spec/data/complicated/config/software/bundler.rb +0 -25
- data/spec/data/complicated/config/software/bzip2.rb +0 -46
- data/spec/data/complicated/config/software/cacerts.rb +0 -44
- data/spec/data/complicated/config/software/chef-client-msi.rb +0 -87
- data/spec/data/complicated/config/software/chef-gem.rb +0 -26
- data/spec/data/complicated/config/software/chef-vault.rb +0 -43
- data/spec/data/complicated/config/software/chef-windows.rb +0 -158
- data/spec/data/complicated/config/software/chef.rb +0 -170
- data/spec/data/complicated/config/software/chefdk.rb +0 -103
- data/spec/data/complicated/config/software/couchdb.rb +0 -53
- data/spec/data/complicated/config/software/curl.rb +0 -48
- data/spec/data/complicated/config/software/erlang.rb +0 -65
- data/spec/data/complicated/config/software/expat.rb +0 -21
- data/spec/data/complicated/config/software/fcgi.rb +0 -56
- data/spec/data/complicated/config/software/fcgiwrap.rb +0 -41
- data/spec/data/complicated/config/software/gd.rb +0 -56
- data/spec/data/complicated/config/software/gdbm.rb +0 -40
- data/spec/data/complicated/config/software/gecode.rb +0 -48
- data/spec/data/complicated/config/software/git.rb +0 -40
- data/spec/data/complicated/config/software/help2man.rb +0 -30
- data/spec/data/complicated/config/software/icu.rb +0 -40
- data/spec/data/complicated/config/software/jre.rb +0 -48
- data/spec/data/complicated/config/software/keepalived.rb +0 -43
- data/spec/data/complicated/config/software/libarchive.rb +0 -50
- data/spec/data/complicated/config/software/libedit.rb +0 -69
- data/spec/data/complicated/config/software/libffi.rb +0 -71
- data/spec/data/complicated/config/software/libgcc.rb +0 -39
- data/spec/data/complicated/config/software/libiconv.rb +0 -55
- data/spec/data/complicated/config/software/libjpeg.rb +0 -39
- data/spec/data/complicated/config/software/libpng.rb +0 -38
- data/spec/data/complicated/config/software/libtool.rb +0 -52
- data/spec/data/complicated/config/software/libwrap.rb +0 -50
- data/spec/data/complicated/config/software/libxml2.rb +0 -51
- data/spec/data/complicated/config/software/libxslt.rb +0 -52
- data/spec/data/complicated/config/software/libyaml-windows.rb +0 -43
- data/spec/data/complicated/config/software/libyaml.rb +0 -62
- data/spec/data/complicated/config/software/logrotate.rb +0 -41
- data/spec/data/complicated/config/software/makedepend.rb +0 -73
- data/spec/data/complicated/config/software/mysql2.rb +0 -42
- data/spec/data/complicated/config/software/nagios-plugins.rb +0 -53
- data/spec/data/complicated/config/software/nagios.rb +0 -66
- data/spec/data/complicated/config/software/ncurses.rb +0 -149
- data/spec/data/complicated/config/software/nginx.rb +0 -40
- data/spec/data/complicated/config/software/nodejs.rb +0 -44
- data/spec/data/complicated/config/software/nokogiri.rb +0 -55
- data/spec/data/complicated/config/software/nrpe.rb +0 -61
- data/spec/data/complicated/config/software/ohai.rb +0 -64
- data/spec/data/complicated/config/software/omnibus-ctl.rb +0 -34
- data/spec/data/complicated/config/software/openresty.rb +0 -67
- data/spec/data/complicated/config/software/openssl.rb +0 -158
- data/spec/data/complicated/config/software/pcre.rb +0 -42
- data/spec/data/complicated/config/software/perl-extutils-embed.rb +0 -15
- data/spec/data/complicated/config/software/perl-extutils-makemaker.rb +0 -15
- data/spec/data/complicated/config/software/perl.rb +0 -48
- data/spec/data/complicated/config/software/perl_pg_driver.rb +0 -12
- data/spec/data/complicated/config/software/php.rb +0 -41
- data/spec/data/complicated/config/software/pip.rb +0 -30
- data/spec/data/complicated/config/software/pkg-config.rb +0 -66
- data/spec/data/complicated/config/software/popt.rb +0 -47
- data/spec/data/complicated/config/software/postgresql.rb +0 -51
- data/spec/data/complicated/config/software/preparation.rb +0 -30
- data/spec/data/complicated/config/software/pygments.rb +0 -25
- data/spec/data/complicated/config/software/python.rb +0 -49
- data/spec/data/complicated/config/software/rabbitmq.rb +0 -36
- data/spec/data/complicated/config/software/rebar.rb +0 -36
- data/spec/data/complicated/config/software/redis.rb +0 -33
- data/spec/data/complicated/config/software/rsync.rb +0 -48
- data/spec/data/complicated/config/software/ruby-windows-devkit.rb +0 -30
- data/spec/data/complicated/config/software/ruby-windows.rb +0 -30
- data/spec/data/complicated/config/software/ruby.rb +0 -162
- data/spec/data/complicated/config/software/rubygems-customization.rb +0 -57
- data/spec/data/complicated/config/software/rubygems.rb +0 -37
- data/spec/data/complicated/config/software/runit.rb +0 -118
- data/spec/data/complicated/config/software/server-jre.rb +0 -46
- data/spec/data/complicated/config/software/setuptools.rb +0 -30
- data/spec/data/complicated/config/software/spawn-fcgi.rb +0 -40
- data/spec/data/complicated/config/software/sphinx.rb +0 -26
- data/spec/data/complicated/config/software/spidermonkey.rb +0 -60
- data/spec/data/complicated/config/software/sqitch.rb +0 -24
- data/spec/data/complicated/config/software/test-kitchen.rb +0 -39
- data/spec/data/complicated/config/software/unicorn.rb +0 -27
- data/spec/data/complicated/config/software/util-macros.rb +0 -46
- data/spec/data/complicated/config/software/xproto.rb +0 -46
- data/spec/data/complicated/config/software/yajl.rb +0 -30
- data/spec/data/complicated/config/software/zlib.rb +0 -67
- data/spec/data/overrides/bad_line.overrides +0 -3
- data/spec/data/overrides/good.overrides +0 -5
- data/spec/data/overrides/with_dupes.overrides +0 -4
- data/spec/data/projects/chefdk.rb +0 -41
- data/spec/data/projects/sample.rb +0 -13
- data/spec/data/software/erchef.rb +0 -42
- data/spec/data/software/zlib.rb +0 -67
- data/spec/fixtures/sample/files/mac_dmg/Resources/background.png +0 -0
- data/spec/fixtures/sample/files/mac_dmg/Resources/icon.png +0 -0
- data/spec/fixtures/sample/files/mac_pkg/Resources/background.png +0 -0
- data/spec/fixtures/sample/files/mac_pkg/Resources/license.html +0 -1
- data/spec/fixtures/sample/files/mac_pkg/Resources/welcome.html +0 -9
- data/spec/fixtures/sample/files/windows_msi/Resources/assets/LICENSE.rtf +0 -8
- data/spec/fixtures/sample/files/windows_msi/Resources/assets/banner_background.bmp +0 -0
- data/spec/fixtures/sample/files/windows_msi/Resources/assets/dialog_background.bmp +0 -0
- data/spec/fixtures/sample/files/windows_msi/Resources/assets/project.ico +0 -0
- data/spec/fixtures/sample/files/windows_msi/Resources/assets/project_16x16.ico +0 -0
- data/spec/fixtures/sample/files/windows_msi/Resources/assets/project_32x32.ico +0 -0
- data/spec/fixtures/sample/files/windows_msi/Resources/parameters.wxi.erb +0 -9
- data/spec/fixtures/sample/files/windows_msi/Resources/source.wxs +0 -74
- data/spec/integration/packagers/mac_spec.rb +0 -58
- data/spec/integration/packagers/windows_spec.rb +0 -70
- data/spec/unit/packagers/mac_pkg_spec.rb +0 -151
data/lib/omnibus/cleaner.rb
CHANGED
@@ -35,27 +35,25 @@ module Omnibus
|
|
35
35
|
|
36
36
|
def initialize(*)
|
37
37
|
super
|
38
|
-
|
39
|
-
@project = Omnibus.project(name)
|
40
|
-
raise ProjectNotFound.new(name) unless @project
|
38
|
+
@project = Project.load(name)
|
41
39
|
end
|
42
40
|
|
43
41
|
def clean_source_dir
|
44
|
-
|
42
|
+
FileSyncer.glob("#{Config.source_dir}/**/*").each(&method(:remove_file))
|
45
43
|
end
|
46
44
|
|
47
45
|
def clean_build_dir
|
48
|
-
|
46
|
+
FileSyncer.glob("#{Config.build_dir}/**/*").each(&method(:remove_file))
|
49
47
|
end
|
50
48
|
|
51
49
|
def clean_package_dir
|
52
50
|
return unless purge?
|
53
|
-
|
51
|
+
FileSyncer.glob("#{Config.package_dir}/**/*").each(&method(:remove_file))
|
54
52
|
end
|
55
53
|
|
56
54
|
def clean_cache_dir
|
57
55
|
return unless purge?
|
58
|
-
|
56
|
+
FileSyncer.glob("#{Config.cache_dir}/**/*").each(&method(:remove_file))
|
59
57
|
end
|
60
58
|
|
61
59
|
def clean_install_dir
|
data/lib/omnibus/cli.rb
CHANGED
@@ -61,12 +61,9 @@ module Omnibus
|
|
61
61
|
#
|
62
62
|
# $ omnibus build chefdk
|
63
63
|
#
|
64
|
-
# @todo Support regular expressions (+$ omnibus build chef*+)
|
65
|
-
#
|
66
64
|
desc 'build PROJECT', 'Build the given Omnibus project'
|
67
65
|
def build(name)
|
68
|
-
project =
|
69
|
-
raise ProjectNotFound.new(name) unless project
|
66
|
+
project = Project.load(name)
|
70
67
|
|
71
68
|
say("Building #{project.name} #{project.build_version}...")
|
72
69
|
project.build_me
|
data/lib/omnibus/cli/base.rb
CHANGED
@@ -46,16 +46,16 @@ module Omnibus
|
|
46
46
|
|
47
47
|
# Do not load the Omnibus config if we are asking for help or the version
|
48
48
|
if %w(help version).include?(config[:current_command].name)
|
49
|
-
log.debug { 'Skipping Omnibus loading (detected help or version)' }
|
49
|
+
log.debug(log_key) { 'Skipping Omnibus loading (detected help or version)' }
|
50
50
|
return
|
51
51
|
end
|
52
52
|
|
53
53
|
if File.exist?(@options[:config])
|
54
|
-
log.info { "Using config from '#{@options[:config]}'" }
|
54
|
+
log.info(log_key) { "Using config from '#{@options[:config]}'" }
|
55
55
|
Omnibus.load_configuration(@options[:config])
|
56
56
|
else
|
57
57
|
if @options[:config] == Omnibus::DEFAULT_CONFIG
|
58
|
-
log.debug { 'Config file not given - using defaults' }
|
58
|
+
log.debug(log_key) { 'Config file not given - using defaults' }
|
59
59
|
else
|
60
60
|
raise "The given config file '#{@options[:config]}' does not exist!"
|
61
61
|
end
|
@@ -63,25 +63,22 @@ module Omnibus
|
|
63
63
|
|
64
64
|
@options[:override].each do |key, value|
|
65
65
|
if %w(true false nil).include?(value)
|
66
|
-
log.debug { "Detected #{value.inspect} should be an object" }
|
66
|
+
log.debug(log_key) { "Detected #{value.inspect} should be an object" }
|
67
67
|
value = { 'true' => true, 'false' => false, 'nil' => nil }[value]
|
68
68
|
end
|
69
69
|
|
70
70
|
if value =~ /\A[[:digit:]]+\Z/
|
71
|
-
log.debug { "Detected #{value.inspect} should be an integer" }
|
71
|
+
log.debug(log_key) { "Detected #{value.inspect} should be an integer" }
|
72
72
|
value = value.to_i
|
73
73
|
end
|
74
74
|
|
75
75
|
if Config.respond_to?(key)
|
76
|
-
log.debug { "Setting Config.#{key} = #{value.inspect}" }
|
76
|
+
log.debug(log_key) { "Setting Config.#{key} = #{value.inspect}" }
|
77
77
|
Config.send(key, value)
|
78
78
|
else
|
79
|
-
log.debug { "Skipping option '#{key}' - not a config option" }
|
79
|
+
log.debug (log_key){ "Skipping option '#{key}' - not a config option" }
|
80
80
|
end
|
81
81
|
end
|
82
|
-
|
83
|
-
log.debug { 'Processing Omnibus configuration...' }
|
84
|
-
Omnibus.process_configuration
|
85
82
|
end
|
86
83
|
|
87
84
|
class_option :config,
|
@@ -93,8 +90,8 @@ module Omnibus
|
|
93
90
|
desc: 'The log level',
|
94
91
|
aliases: '-l',
|
95
92
|
type: :string,
|
96
|
-
enum:
|
97
|
-
|
93
|
+
enum: Logger::LEVELS.map(&:downcase),
|
94
|
+
default: 'info'
|
98
95
|
class_option :override,
|
99
96
|
desc: 'Override one or more Omnibus config options',
|
100
97
|
aliases: '-o',
|
@@ -111,7 +108,3 @@ module Omnibus
|
|
111
108
|
end
|
112
109
|
end
|
113
110
|
end
|
114
|
-
|
115
|
-
# Include the deprecations from previous versions of Omnibus. This should be
|
116
|
-
# removed in the next major version of Omnibus.
|
117
|
-
require_relative 'deprecated'
|
@@ -0,0 +1,60 @@
|
|
1
|
+
#
|
2
|
+
# Copyright 2014 Chef Software, Inc.
|
3
|
+
#
|
4
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
5
|
+
# you may not use this file except in compliance with the License.
|
6
|
+
# You may obtain a copy of the License at
|
7
|
+
#
|
8
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
9
|
+
#
|
10
|
+
# Unless required by applicable law or agreed to in writing, software
|
11
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
12
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
13
|
+
# See the License for the specific language governing permissions and
|
14
|
+
# limitations under the License.
|
15
|
+
#
|
16
|
+
|
17
|
+
module Omnibus
|
18
|
+
module Compressor
|
19
|
+
include Logging
|
20
|
+
|
21
|
+
autoload :Base, 'omnibus/compressors/base'
|
22
|
+
autoload :DMG, 'omnibus/compressors/dmg'
|
23
|
+
autoload :Null, 'omnibus/compressors/null'
|
24
|
+
autoload :TGZ, 'omnibus/compressors/tgz'
|
25
|
+
|
26
|
+
#
|
27
|
+
# Determine the best compressor for the current system. This method returns
|
28
|
+
# the class, not an instance of the class.
|
29
|
+
#
|
30
|
+
# @example
|
31
|
+
# Compressor.for_current_system([:dmg, :tgz]) #=> Packager::DMG
|
32
|
+
#
|
33
|
+
# @param [Array<Symbol>] compressors
|
34
|
+
# the list of configured compressors
|
35
|
+
#
|
36
|
+
# @return [~Compressor::Base]
|
37
|
+
#
|
38
|
+
def for_current_system(compressors)
|
39
|
+
family = Ohai['platform_family']
|
40
|
+
|
41
|
+
if family == 'mac_os_x'
|
42
|
+
if compressors.include?(:dmg)
|
43
|
+
return DMG
|
44
|
+
end
|
45
|
+
|
46
|
+
if compressors.include?(:tgz)
|
47
|
+
return TGZ
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
if compressors.include?(:tgz)
|
52
|
+
return TGZ
|
53
|
+
else
|
54
|
+
log.info(log_key) { "No compressor defined for `#{family}'." }
|
55
|
+
return Null
|
56
|
+
end
|
57
|
+
end
|
58
|
+
module_function :for_current_system
|
59
|
+
end
|
60
|
+
end
|
data/{spec/data/complicated/config/software/version-manifest.rb → lib/omnibus/compressors/base.rb}
RENAMED
@@ -1,6 +1,5 @@
|
|
1
1
|
#
|
2
|
-
# Copyright
|
3
|
-
# License:: Apache License, Version 2.0
|
2
|
+
# Copyright 2014 Chef Software, Inc.
|
4
3
|
#
|
5
4
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
6
5
|
# you may not use this file except in compliance with the License.
|
@@ -15,18 +14,24 @@
|
|
15
14
|
# limitations under the License.
|
16
15
|
#
|
17
16
|
|
18
|
-
|
19
|
-
description "generates a version manifest file"
|
17
|
+
require 'fileutils'
|
20
18
|
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
19
|
+
module Omnibus
|
20
|
+
class Compressor::Base < Packager::Base
|
21
|
+
# The {Project} instance that we are compressing
|
22
|
+
attr_reader :project
|
25
23
|
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
24
|
+
# The {Packager::Base} instance that produced the compressed file
|
25
|
+
attr_reader :packager
|
26
|
+
|
27
|
+
#
|
28
|
+
# Create a new compressor object from the given packager.
|
29
|
+
#
|
30
|
+
# @param [Project] project
|
31
|
+
#
|
32
|
+
def initialize(project)
|
33
|
+
@project = project
|
34
|
+
@packager = project.packager
|
30
35
|
end
|
31
36
|
end
|
32
37
|
end
|
@@ -0,0 +1,312 @@
|
|
1
|
+
#
|
2
|
+
# Copyright 2014 Chef Software, Inc.
|
3
|
+
#
|
4
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
5
|
+
# you may not use this file except in compliance with the License.
|
6
|
+
# You may obtain a copy of the License at
|
7
|
+
#
|
8
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
9
|
+
#
|
10
|
+
# Unless required by applicable law or agreed to in writing, software
|
11
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
12
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
13
|
+
# See the License for the specific language governing permissions and
|
14
|
+
# limitations under the License.
|
15
|
+
#
|
16
|
+
|
17
|
+
module Omnibus
|
18
|
+
class Compressor::DMG < Compressor::Base
|
19
|
+
id :dmg
|
20
|
+
|
21
|
+
setup do
|
22
|
+
# Clean any previously mounted disks
|
23
|
+
clean_disks
|
24
|
+
|
25
|
+
# Create the resources directory
|
26
|
+
create_directory(resources_dir)
|
27
|
+
|
28
|
+
# Copy the compiled pkg into the dmg
|
29
|
+
copy_file(packager.package_path, "#{resources_dir}/")
|
30
|
+
|
31
|
+
# Copy support files
|
32
|
+
support = create_directory("#{resources_dir}/.support")
|
33
|
+
copy_file(resource_path('background.png'), "#{support}/background.png")
|
34
|
+
end
|
35
|
+
|
36
|
+
build do
|
37
|
+
create_writable_dmg
|
38
|
+
attach_dmg
|
39
|
+
# Give some time to the system so attached dmg shows up in Finder
|
40
|
+
sleep 5
|
41
|
+
set_volume_icon
|
42
|
+
prettify_dmg
|
43
|
+
compress_dmg
|
44
|
+
set_dmg_icon
|
45
|
+
end
|
46
|
+
|
47
|
+
#
|
48
|
+
# @!group DSL methods
|
49
|
+
# --------------------------------------------------
|
50
|
+
|
51
|
+
#
|
52
|
+
# Set or return the starting x,y and ending x,y positions for the created
|
53
|
+
# DMG window.
|
54
|
+
#
|
55
|
+
# @example
|
56
|
+
# window_bounds "100, 100, 750, 600"
|
57
|
+
#
|
58
|
+
# @param [String] val
|
59
|
+
# the DMG window bounds
|
60
|
+
#
|
61
|
+
# @return [String]
|
62
|
+
# the DMG window bounds
|
63
|
+
#
|
64
|
+
def window_bounds(val = NULL)
|
65
|
+
if null?(val)
|
66
|
+
@window_bounds || '100, 100, 750, 600'
|
67
|
+
else
|
68
|
+
@window_bounds = val
|
69
|
+
end
|
70
|
+
end
|
71
|
+
expose :window_bounds
|
72
|
+
|
73
|
+
#
|
74
|
+
# Set or return the starting x,y position where the .pkg file should live
|
75
|
+
# in the DMG window.
|
76
|
+
#
|
77
|
+
# @example
|
78
|
+
# pkg_position "535, 50"
|
79
|
+
#
|
80
|
+
# @param [String] val
|
81
|
+
# the PKG position inside the DMG
|
82
|
+
#
|
83
|
+
# @return [String]
|
84
|
+
# the PKG position inside the DMG
|
85
|
+
#
|
86
|
+
def pkg_position(val = NULL)
|
87
|
+
if null?(val)
|
88
|
+
@pkg_position || '535, 50'
|
89
|
+
else
|
90
|
+
@pkg_position = val
|
91
|
+
end
|
92
|
+
end
|
93
|
+
expose :pkg_position
|
94
|
+
|
95
|
+
#
|
96
|
+
# @!endgroup
|
97
|
+
# --------------------------------------------------
|
98
|
+
|
99
|
+
#
|
100
|
+
# The path where the MSI resources will live.
|
101
|
+
#
|
102
|
+
# @return [String]
|
103
|
+
#
|
104
|
+
def resources_dir
|
105
|
+
File.expand_path("#{staging_dir}/Resources")
|
106
|
+
end
|
107
|
+
|
108
|
+
#
|
109
|
+
# Cleans any previously left over mounted disks.
|
110
|
+
#
|
111
|
+
# We are trying to detach disks that look like:
|
112
|
+
#
|
113
|
+
# /dev/disk1s1 on /Volumes/chef (hfs, local, nodev, nosuid, read-only, noowners, quarantine, mounted by serdar)
|
114
|
+
# /dev/disk2s1 on /Volumes/chef 1 (hfs, local, nodev, nosuid, read-only, noowners, quarantine, mounted by serdar)
|
115
|
+
#
|
116
|
+
# @return [void]
|
117
|
+
#
|
118
|
+
def clean_disks
|
119
|
+
log.info(log_key) { "Cleaning previously mounted disks" }
|
120
|
+
|
121
|
+
existing_disks = shellout!("mount | grep /Volumes/#{volume_name} | awk '{print $1}'")
|
122
|
+
existing_disks.stdout.lines.each do |existing_disk|
|
123
|
+
existing_disk.chomp!
|
124
|
+
|
125
|
+
Omnibus.logger.debug(log_key) do
|
126
|
+
"Detaching disk `#{existing_disk}' before starting dmg packaging."
|
127
|
+
end
|
128
|
+
|
129
|
+
shellout!("hdiutil detach '#{existing_disk}'")
|
130
|
+
end
|
131
|
+
end
|
132
|
+
|
133
|
+
#
|
134
|
+
# Create a writable dmg we can put assets on.
|
135
|
+
#
|
136
|
+
def create_writable_dmg
|
137
|
+
log.info(log_key) { "Creating writable dmg" }
|
138
|
+
|
139
|
+
shellout! <<-EOH.gsub(/^ {8}/, '')
|
140
|
+
hdiutil create \\
|
141
|
+
-srcfolder "#{resources_dir}" \\
|
142
|
+
-volname "#{volume_name}" \\
|
143
|
+
-fs HFS+ \\
|
144
|
+
-fsargs "-c c=64,a=16,e=16" \\
|
145
|
+
-format UDRW \\
|
146
|
+
-size 512000k \\
|
147
|
+
"#{writable_dmg}"
|
148
|
+
EOH
|
149
|
+
end
|
150
|
+
|
151
|
+
#
|
152
|
+
# Attach the dmg, storing a reference to the device for later use.
|
153
|
+
#
|
154
|
+
# @return [String]
|
155
|
+
# the name of the attached device
|
156
|
+
#
|
157
|
+
def attach_dmg
|
158
|
+
@device ||= Dir.chdir(staging_dir) do
|
159
|
+
log.info(log_key) { "Attaching dmg as disk" }
|
160
|
+
|
161
|
+
cmd = shellout! <<-EOH.gsub(/^ {10}/, '')
|
162
|
+
hdiutil attach \\
|
163
|
+
-readwrite \\
|
164
|
+
-noverify \\
|
165
|
+
-noautoopen \\
|
166
|
+
"#{writable_dmg}" | egrep '^/dev/' | sed 1q | awk '{print $1}'
|
167
|
+
EOH
|
168
|
+
|
169
|
+
cmd.stdout.strip
|
170
|
+
end
|
171
|
+
end
|
172
|
+
|
173
|
+
#
|
174
|
+
# Create the icon for the volume using sips.
|
175
|
+
#
|
176
|
+
# @return [void]
|
177
|
+
#
|
178
|
+
def set_volume_icon
|
179
|
+
log.info(log_key) { "Setting volume icon" }
|
180
|
+
|
181
|
+
icon = resource_path('icon.png')
|
182
|
+
|
183
|
+
Dir.chdir(staging_dir) do
|
184
|
+
shellout! <<-EOH.gsub(/^ {10}/, '')
|
185
|
+
# Generate the icns
|
186
|
+
mkdir tmp.iconset
|
187
|
+
sips -z 16 16 #{icon} --out tmp.iconset/icon_16x16.png
|
188
|
+
sips -z 32 32 #{icon} --out tmp.iconset/icon_16x16@2x.png
|
189
|
+
sips -z 32 32 #{icon} --out tmp.iconset/icon_32x32.png
|
190
|
+
sips -z 64 64 #{icon} --out tmp.iconset/icon_32x32@2x.png
|
191
|
+
sips -z 128 128 #{icon} --out tmp.iconset/icon_128x128.png
|
192
|
+
sips -z 256 256 #{icon} --out tmp.iconset/icon_128x128@2x.png
|
193
|
+
sips -z 256 256 #{icon} --out tmp.iconset/icon_256x256.png
|
194
|
+
sips -z 512 512 #{icon} --out tmp.iconset/icon_256x256@2x.png
|
195
|
+
sips -z 512 512 #{icon} --out tmp.iconset/icon_512x512.png
|
196
|
+
sips -z 1024 1024 #{icon} --out tmp.iconset/icon_512x512@2x.png
|
197
|
+
iconutil -c icns tmp.iconset
|
198
|
+
|
199
|
+
# Copy it over
|
200
|
+
cp tmp.icns "/Volumes/#{volume_name}/.VolumeIcon.icns"
|
201
|
+
|
202
|
+
# Source the icon
|
203
|
+
SetFile -a C "/Volumes/#{volume_name}"
|
204
|
+
EOH
|
205
|
+
end
|
206
|
+
end
|
207
|
+
|
208
|
+
#
|
209
|
+
# Use Applescript to setup the DMG with pretty logos and colors.
|
210
|
+
#
|
211
|
+
# @return [void]
|
212
|
+
#
|
213
|
+
def prettify_dmg
|
214
|
+
log.info(log_key) { "Making the dmg all pretty and stuff" }
|
215
|
+
|
216
|
+
render_template(resource_path('create_dmg.osascript.erb'),
|
217
|
+
destination: "#{staging_dir}/create_dmg.osascript",
|
218
|
+
variables: {
|
219
|
+
volume_name: volume_name,
|
220
|
+
pkg_name: packager.package_name,
|
221
|
+
window_bounds: window_bounds,
|
222
|
+
pkg_position: pkg_position,
|
223
|
+
}
|
224
|
+
)
|
225
|
+
|
226
|
+
Dir.chdir(staging_dir) do
|
227
|
+
shellout! <<-EOH.gsub(/^ {10}/, '')
|
228
|
+
osascript "#{staging_dir}/create_dmg.osascript"
|
229
|
+
EOH
|
230
|
+
end
|
231
|
+
end
|
232
|
+
|
233
|
+
#
|
234
|
+
# Compress the dmg using hdiutil and zlib.
|
235
|
+
#
|
236
|
+
# @return [void]
|
237
|
+
#
|
238
|
+
def compress_dmg
|
239
|
+
log.info(log_key) { "Compressing dmg" }
|
240
|
+
|
241
|
+
Dir.chdir(staging_dir) do
|
242
|
+
shellout! <<-EOH.gsub(/^ {10}/, '')
|
243
|
+
chmod -Rf go-w /Volumes/#{volume_name}
|
244
|
+
sync
|
245
|
+
hdiutil detach "#{@device}"
|
246
|
+
hdiutil convert \\
|
247
|
+
"#{writable_dmg}" \\
|
248
|
+
-format UDZO \\
|
249
|
+
-imagekey \\
|
250
|
+
zlib-level=9 \\
|
251
|
+
-o "#{final_dmg}"
|
252
|
+
rm -rf "#{writable_dmg}"
|
253
|
+
EOH
|
254
|
+
end
|
255
|
+
end
|
256
|
+
|
257
|
+
#
|
258
|
+
# Set the dmg icon to our custom icon.
|
259
|
+
#
|
260
|
+
# @return [void]
|
261
|
+
#
|
262
|
+
def set_dmg_icon
|
263
|
+
log.info(log_key) { "Setting dmg icon" }
|
264
|
+
|
265
|
+
Dir.chdir(staging_dir) do
|
266
|
+
shellout! <<-EOH.gsub(/^ {10}/, '')
|
267
|
+
# Convert the png to an icon
|
268
|
+
sips -i "#{resource_path('icon.png')}"
|
269
|
+
|
270
|
+
# Extract the icon into its own resource
|
271
|
+
DeRez -only icns "#{resource_path('icon.png')}" > tmp.rsrc
|
272
|
+
|
273
|
+
# Append the icon reosurce to the DMG
|
274
|
+
Rez -append tmp.rsrc -o "#{final_dmg}"
|
275
|
+
|
276
|
+
# Source the icon
|
277
|
+
SetFile -a C "#{final_dmg}"
|
278
|
+
EOH
|
279
|
+
end
|
280
|
+
end
|
281
|
+
|
282
|
+
# @see Base#package_name
|
283
|
+
def package_name
|
284
|
+
"#{project.name}-#{project.build_version}-#{project.build_iteration}.dmg"
|
285
|
+
end
|
286
|
+
|
287
|
+
# The path to the writable dmg on disk.
|
288
|
+
#
|
289
|
+
# @return [String]
|
290
|
+
def writable_dmg
|
291
|
+
File.expand_path("#{staging_dir}/#{project.name}-writable.dmg")
|
292
|
+
end
|
293
|
+
|
294
|
+
# The path where the final dmg will be produced.
|
295
|
+
#
|
296
|
+
# @return [String]
|
297
|
+
def final_dmg
|
298
|
+
dmg_name = packager.package_name.sub('.pkg', '.dmg')
|
299
|
+
File.expand_path("#{Config.package_dir}/#{dmg_name}")
|
300
|
+
end
|
301
|
+
|
302
|
+
#
|
303
|
+
# The name of the volume to create. By defauly, this is the project's
|
304
|
+
# friendly name.
|
305
|
+
#
|
306
|
+
# @return [String]
|
307
|
+
#
|
308
|
+
def volume_name
|
309
|
+
project.friendly_name
|
310
|
+
end
|
311
|
+
end
|
312
|
+
end
|