diff options
author | Tim Smith <tsmith@chef.io> | 2020-05-04 16:41:10 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-05-04 16:41:10 -0700 |
commit | 5aa7e5a2b98684e26b51b29c41b26ce7f5a3746e (patch) | |
tree | 6653aa7e7d41fb4933d31e33bda2e52cebce393a /Rakefile | |
parent | 7e4ea765ace14dc2e89921577187429d34836a3b (diff) | |
parent | b07a6d088c01d4ff6a186ab89632bf57e758b6b5 (diff) | |
download | chef-5aa7e5a2b98684e26b51b29c41b26ce7f5a3746e.tar.gz |
Merge pull request #9739 from chef/robb/reorder-gem-installs-in-hab-build
fix Habitat Windows package build
Diffstat (limited to 'Rakefile')
-rw-r--r-- | Rakefile | 41 |
1 files changed, 25 insertions, 16 deletions
@@ -34,24 +34,32 @@ require "bundler/gem_helper" ENV["CHEF_LICENSE"] = "accept-no-persist" -# hack the chef-config install to run before the traditional install task -task :super_install do - %w{chef-utils chef-config}.each do |gem| - path = ::File.join(::File.dirname(__FILE__), gem) - Dir.chdir(path) - sh("rake install") +namespace :pre_install do + desc "Runs 'rake install' for the gems that live in subdirectories in this repo" + task :install_gems_from_dirs do + %w{chef-utils chef-config}.each do |gem| + path = ::File.join(::File.dirname(__FILE__), gem) + Dir.chdir(path) do + sh("rake install") + end + end end -# Templating the powershell extensions so we can inject distro constants - template_file = ::File.join(::File.dirname(__FILE__), "distro", "templates", "powershell", "chef", "chef.psm1.erb") - psm1_path = ::File.join(::File.dirname(__FILE__), "distro", "powershell", "chef") - FileUtils.mkdir_p psm1_path - template = ERB.new(IO.read(template_file)) - chef_psm1 = template.result - File.open(::File.join(psm1_path, "chef.psm1"), "w") { |f| f.write(chef_psm1) } + desc "Renders the powershell extensions with distro flavoring" + task :render_powershell_extension do + template_file = ::File.join(::File.dirname(__FILE__), "distro", "templates", "powershell", "chef", "chef.psm1.erb") + psm1_path = ::File.join(::File.dirname(__FILE__), "distro", "powershell", "chef") + FileUtils.mkdir_p psm1_path + template = ERB.new(IO.read(template_file)) + chef_psm1 = template.result + File.open(::File.join(psm1_path, "chef.psm1"), "w") { |f| f.write(chef_psm1) } + end + + task all: ["pre_install:install_gems_from_dirs", "pre_install:render_powershell_extension"] end -task install: :super_install +# hack in all the preinstall tasks to occur before the tradtional install task +task install: "pre_install:all" # make sure we build the correct gemspec on windows gemspec = Gem.win_platform? ? "chef-universal-mingw32" : "chef" @@ -60,8 +68,9 @@ Bundler::GemHelper.install_tasks name: gemspec # this gets appended to the normal bundler install helper task :install do chef_bin_path = ::File.join(::File.dirname(__FILE__), "chef-bin") - Dir.chdir(chef_bin_path) - sh("rake install:force") + Dir.chdir(chef_bin_path) do + sh("rake install:force") + end end task :pedant, :chef_zero_spec |