beaker-pe 2.16.1 → 2.18.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 52bc9c52ef4e5ca4a1dc4e0c92dde1369ad90e50e075b643a75ecf90646d3312
4
- data.tar.gz: f2b0073bc2a1823e975eb185ca22b79af5ca174e74fe0d8249341c8b40db97b2
3
+ metadata.gz: 91b77453890c3f2af4eecb5a655e069e902d6061ca8724b7bee3c14de7d7c584
4
+ data.tar.gz: e5675b005b3061014800b7dbc1a49576ed9c561de139db7dd84ea57770c756f6
5
5
  SHA512:
6
- metadata.gz: 5f486788d637cfe5618b679106dd4b58e484140573febd086fc34a69689503ea24a1976f0ac3d611214b2c600ba9cb43e6c29e10dc928e92cb14c10e569a3e43
7
- data.tar.gz: 1639bef650aaf36093bc393697a3d3a0c82e93ca67e98eae8b6fa8ddcead96c2dc3d5c38bdda548d3725eeebf15d8200596cf00235b73dc241468cd850671218
6
+ metadata.gz: 39fb9fa81be0a7f5fb6970086ded2dd2104c8c68a81b31cc34c31b62a0199d7772089c207f3c495318b5d5526bba13b4a69666a14ff9430354067f8ed20f059e
7
+ data.tar.gz: 8f65cad0d0e2657594e55ba0ca5cf36af231f2451ea281d51e62fa4d42ec6a3988f234c874a3a5cb6badffa02a6aab29a2279dbd656d725999efc1eb2ef2627a
@@ -36,27 +36,6 @@ jobs:
36
36
  return response.tag_name
37
37
  result-encoding: string
38
38
 
39
- - name: Generate Changelog
40
- uses: docker://githubchangeloggenerator/github-changelog-generator:1.16.2
41
- with:
42
- args: >-
43
- --future-release ${{ steps.nv.outputs.version }}
44
- env:
45
- CHANGELOG_GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
46
-
47
- - name: Validate Changelog
48
- run : |
49
- set -e
50
- if output=$(git status --porcelain) && [ ! -z "$output" ]; then
51
- echo "Here is the current git status:"
52
- git status
53
- echo
54
- echo "The following changes were detected:"
55
- git --no-pager diff
56
- echo "Uncommitted PRs found in the changelog. Please submit a release prep PR of changes after running './release-prep'"
57
- exit 1
58
- fi
59
-
60
39
  - name: Generate Release Notes
61
40
  uses: docker://githubchangeloggenerator/github-changelog-generator:1.16.2
62
41
  with:
data/Gemfile.lock CHANGED
@@ -1,11 +1,11 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- beaker-pe (2.16.1)
4
+ beaker-pe (2.18.0)
5
5
  beaker (>= 4.0, < 6)
6
6
  beaker-abs
7
7
  beaker-answers (~> 0.0)
8
- beaker-puppet (>= 1, < 3)
8
+ beaker-puppet (>= 1)
9
9
  beaker-vmpooler (~> 1.0)
10
10
  stringify-hash (~> 0.0.0)
11
11
 
data/beaker-pe.gemspec CHANGED
@@ -33,7 +33,7 @@ Gem::Specification.new do |s|
33
33
 
34
34
  # Run time dependencies
35
35
  s.add_runtime_dependency 'beaker', '>= 4.0', '< 6'
36
- s.add_runtime_dependency 'beaker-puppet', '>=1', '<3'
36
+ s.add_runtime_dependency 'beaker-puppet', '>=1'
37
37
  s.add_runtime_dependency 'stringify-hash', '~> 0.0.0'
38
38
  s.add_runtime_dependency 'beaker-answers', '~> 0.0'
39
39
  s.add_runtime_dependency 'beaker-abs'
@@ -891,6 +891,231 @@ module Beaker
891
891
  end
892
892
  end
893
893
 
894
+ # Gets host-specific information for PE promoted puppet-agent packages (Mac version)
895
+ #
896
+ # @param [Host] host
897
+ # @param [String] puppet_collection Name of the puppet collection to use
898
+ # @param [Hash{Symbol=>String}] opts Options hash to provide extra values
899
+ #
900
+ # @return [String, String, String] Host-specific information for packages
901
+ # 1. release_path_end Suffix for the release_path. Used on Windows. Check
902
+ # {Windows::Pkg#pe_puppet_agent_promoted_package_info} to see usage.
903
+ # 2. release_file Path to the file on release build servers
904
+ # 3. download_file Filename for the package itself
905
+ def pe_puppet_agent_promoted_package_info_mac(host, puppet_collection = nil, opts = {} )
906
+ error_message = "Must provide %s argument to get puppet agent dev package information"
907
+ raise ArgumentError, error_message % "puppet_collection" unless puppet_collection
908
+
909
+ variant, version, arch, _codename = host['platform'].to_array
910
+ release_file = "/repos/apple/#{version}/#{puppet_collection}/#{arch}/puppet-agent-*"
911
+
912
+ # macOS puppet-agent tarballs haven't always included arch
913
+ agent_version = opts[:puppet_agent_version]
914
+ agent_version_f = agent_version&.to_f
915
+
916
+ download_file = if agent_version_f.nil? || (agent_version_f < 6.28 || (agent_version_f >= 7.0 && agent_version_f < 7.18))
917
+ "puppet-agent-#{variant}-#{version}.tar.gz"
918
+ else
919
+ "puppet-agent-#{variant}-#{version}-#{arch}.tar.gz"
920
+ end
921
+
922
+ return '', release_file, download_file
923
+ end
924
+
925
+ # Gets host-specific information for PE promoted puppet-agent packages (Windows version)
926
+ #
927
+ # @param [Host] host
928
+ # @param [String] puppet_collection Name of the puppet collection to use
929
+ # @param [Hash{Symbol=>String}] opts Options hash to provide extra values
930
+ #
931
+ # @return [String, String, String] Host-specific information for packages
932
+ # 1. release_path_end Suffix for the release_path
933
+ # 2. release_file Path to the file on release build servers
934
+ # 3. download_file Filename for the package itself
935
+ def pe_puppet_agent_promoted_package_info_windows(host, _puppet_collection = nil, _opts = {} )
936
+ is_config_32 = host['ruby_arch'] == 'x86' || host['install_32'] || host['install_32']
937
+ should_install_64bit = host.is_x86_64? && !is_config_32
938
+ # only install 64bit builds if
939
+ # - we do not have install_32 set on host
940
+ # - we do not have install_32 set globally
941
+ arch_suffix = should_install_64bit ? '64' : '86'
942
+ release_path_end = "/windows"
943
+ release_file = "/puppet-agent-x#{arch_suffix}.msi"
944
+ download_file = "puppet-agent-x#{arch_suffix}.msi"
945
+ return release_path_end, release_file, download_file
946
+ end
947
+
948
+ # Gets host-specific information for PE promoted puppet-agent packages (Unix version)
949
+ #
950
+ # @param [Host] host
951
+ # @param [String] puppet_collection Name of the puppet collection to use
952
+ # @param [Hash{Symbol=>String}] opts Options hash to provide extra values
953
+ #
954
+ # @return [String, String, String] Host-specific information for packages
955
+ # 1. release_path_end Suffix for the release_path. Used on Windows. Check
956
+ # {Windows::Pkg#pe_puppet_agent_promoted_package_info} to see usage.
957
+ # 2. release_file Path to the file on release build servers
958
+ # 3. download_file Filename for the package itself
959
+ def pe_puppet_agent_promoted_package_info_unix(host, puppet_collection = nil, _opts = {} )
960
+ error_message = "Must provide %s argument to get puppet agent dev package information"
961
+ raise ArgumentError, error_message % "puppet_collection" unless puppet_collection
962
+
963
+ variant, version, arch, codename = host['platform'].to_array
964
+ case variant
965
+ when /^(fedora|el|centos|redhat|opensuse|sles)$/
966
+ variant = ((['centos', 'redhat'].include?(variant)) ? 'el' : variant)
967
+ release_file = "/repos/#{variant}/#{version}/#{puppet_collection}/#{arch}/puppet-agent-*.rpm"
968
+ download_file = "puppet-agent-#{variant}-#{version}-#{arch}.tar.gz"
969
+ when /^(debian|ubuntu|cumulus)$/
970
+ if arch == 'x86_64'
971
+ arch = 'amd64'
972
+ end
973
+ version = version[0,2] + '.' + version[2,2] if (variant.include?('ubuntu') && !version.include?("."))
974
+ release_file = "/repos/apt/#{codename}/pool/#{puppet_collection}/p/puppet-agent/puppet-agent*#{arch}.deb"
975
+ download_file = "puppet-agent-#{variant}-#{version}-#{arch}.tar.gz"
976
+ when /^solaris$/
977
+ if arch == 'x86_64'
978
+ arch = 'i386'
979
+ end
980
+ release_file = "/repos/solaris/#{version}/#{puppet_collection}/"
981
+ download_file = "puppet-agent-#{variant}-#{version}-#{arch}.tar.gz"
982
+ else
983
+ raise "No pe-promoted installation step for #{variant} yet..."
984
+ end
985
+ return '', release_file, download_file
986
+ end
987
+
988
+ def pe_puppet_agent_promoted_package_install_dispatch(host, onhost_copy_base, onhost_copied_download, onhost_copied_file, download_file, _opts)
989
+ case host
990
+ when Mac::Host
991
+ return pe_puppet_agent_promoted_package_install_mac(host, onhost_copy_base, onhost_copied_download, onhost_copied_file, download_file, _opts)
992
+ when Unix::Host
993
+ return pe_puppet_agent_promoted_package_install_unix(host, onhost_copy_base, onhost_copied_download, onhost_copied_file, download_file, _opts)
994
+ end
995
+ raise RuntimeError("#{host.class} not one of Beaker::(Mac|Unix)::Host")
996
+ end
997
+
998
+ # Installs a given PE promoted package on a Mac host
999
+ #
1000
+ # @param [Host] host Host to install package on
1001
+ # @param [String] onhost_copy_base Base copy directory on the host
1002
+ # @param [String] onhost_copied_download Downloaded file path on the host
1003
+ # @param [String] onhost_copied_file Copied file path once un-compressed
1004
+ # @param [String] download_file File name of the downloaded file
1005
+ # @param [Hash{Symbol=>String}] opts additional options
1006
+ #
1007
+ # @return nil
1008
+ def pe_puppet_agent_promoted_package_install_mac(
1009
+ host, onhost_copy_base, onhost_copied_download, onhost_copied_file, _download_file, _opts
1010
+ )
1011
+ host.execute("tar -zxvf #{onhost_copied_download} -C #{onhost_copy_base}")
1012
+ # move to better location
1013
+ host.execute("mv #{onhost_copied_file}.dmg .")
1014
+ host.install_package("puppet-agent-*")
1015
+ end
1016
+
1017
+
1018
+ # Installs a given PE promoted package on a Unix host
1019
+ #
1020
+ # @param [Host] host Host to install package on
1021
+ # @param [String] onhost_copy_base Base copy directory on the host
1022
+ # @param [String] onhost_copied_download Downloaded file path on the host
1023
+ # @param [String] onhost_copied_file Copied file path once un-compressed
1024
+ # @param [String] download_file File name of the downloaded file
1025
+ # @param [Hash{Symbol=>String}] opts additional options
1026
+ #
1027
+ # @return nil
1028
+ def pe_puppet_agent_promoted_package_install_unix(
1029
+ host, onhost_copy_base, onhost_copied_download, onhost_copied_file, download_file, _opts
1030
+ )
1031
+ host.uncompress_local_tarball(onhost_copied_download, onhost_copy_base, download_file )
1032
+ if /^solaris/.match?(host['platform'])
1033
+ # above uncompresses the install from .tar.gz -> .p5p into the
1034
+ # onhost_copied_file directory w/a weird name. We have to read that file
1035
+ # name from the filesystem, so that we can provide it to install_local...
1036
+ pkg_filename = host.execute( "ls #{onhost_copied_file}" )
1037
+ onhost_copied_file = "#{onhost_copied_file}#{pkg_filename}"
1038
+ end
1039
+
1040
+ host.install_local_package(onhost_copied_file, onhost_copy_base )
1041
+ nil
1042
+ end
1043
+
1044
+ def pe_puppet_agent_promoted_package_info_dispatch(host, puppet_collection = nil, opts = {})
1045
+ case host
1046
+ when Windows::Host
1047
+ return pe_puppet_agent_promoted_package_info_windows(host, puppet_collection, opts)
1048
+ when Mac::Host
1049
+ return pe_puppet_agent_promoted_package_info_mac(host, puppet_collection, opts)
1050
+ when Unix::Host
1051
+ return pe_puppet_agent_promoted_package_info_unix(host, puppet_collection, opts)
1052
+ end
1053
+ raise RuntimeError("#{host.class} not one of Beaker::(Windows|Mac|Unix)::Host")
1054
+ end
1055
+
1056
+ # Install shared repo of the puppet-agent on the given host(s). Downloaded from
1057
+ # location of the form PE_PROMOTED_BUILDS_URL/PE_VER/puppet-agent/AGENT_VERSION/repo
1058
+ #
1059
+ # @param [Host, Array<Host>, String, Symbol] hosts One or more hosts to act upon,
1060
+ # or a role (String or Symbol) that identifies one or more hosts.
1061
+ # @param [Hash{Symbol=>String}] opts An options hash
1062
+ # @option opts [String] :puppet_agent_version The version of puppet-agent to install, defaults to 'latest'
1063
+ # @option opts [String] :pe_ver The version of PE (will also use host['pe_ver']), defaults to '4.0'
1064
+ # @option opts [String] :copy_base_local Directory where puppet-agent artifact
1065
+ # will be stored locally
1066
+ # (default: 'tmp/repo_configs')
1067
+ # @option opts [String] :copy_dir_external Directory where puppet-agent
1068
+ # artifact will be pushed to on the external machine
1069
+ # (default: '/root')
1070
+ # @option opts [String] :puppet_collection Defaults to 'PC1'
1071
+ # @option opts [String] :pe_promoted_builds_url Base URL to pull artifacts from
1072
+ def install_puppet_agent_pe_promoted_repo_on(hosts, opts)
1073
+ opts[:puppet_agent_version] ||= 'latest'
1074
+
1075
+ block_on hosts do |host|
1076
+ pe_ver = host[:pe_ver] || opts[:pe_ver] || '4.0.0-rc1'
1077
+ opts = sanitize_opts(opts)
1078
+ opts[:download_url] =
1079
+ "#{opts[:pe_promoted_builds_url]}/puppet-agent/#{pe_ver}/#{opts[:puppet_agent_version]}/repos"
1080
+ opts[:copy_base_local] ||= File.join('tmp', 'repo_configs')
1081
+ opts[:copy_dir_external] ||= host.external_copy_base
1082
+ opts[:puppet_collection] ||= puppet_collection_for(:puppet_agent, opts[:puppet_agent_version])
1083
+ add_role(host, 'aio') # we are installing agent, so we want aio role
1084
+ release_path = opts[:download_url]
1085
+ variant, version, arch, codename = host['platform'].to_array
1086
+ copy_dir_local = File.join(opts[:copy_base_local], variant)
1087
+ onhost_copy_base = opts[:copy_dir_external]
1088
+
1089
+ release_path_end, release_file, download_file =
1090
+ pe_puppet_agent_promoted_package_info_dispatch(
1091
+ host,
1092
+ opts[:puppet_collection], opts
1093
+ )
1094
+ release_path << release_path_end
1095
+
1096
+ onhost_copied_download = File.join(onhost_copy_base, download_file)
1097
+ onhost_copied_file = File.join(onhost_copy_base, release_file)
1098
+ fetch_http_file(release_path, download_file, copy_dir_local)
1099
+ scp_to host, File.join(copy_dir_local, download_file), onhost_copy_base
1100
+
1101
+ if variant == 'windows'
1102
+ result = on host, "echo #{onhost_copied_file}"
1103
+ onhost_copied_file = result.raw_output.chomp
1104
+ opts = { debug: host[:pe_debug] || opts[:pe_debug] }
1105
+ # couldn't pull this out, because it's relying on
1106
+ # {Beaker::DSL::InstallUtils::WindowsUtils} methods,
1107
+ # which I didn't want to attack right now. TODO
1108
+ install_msi_on(host, onhost_copied_file, {}, opts)
1109
+ else
1110
+ pe_puppet_agent_promoted_package_install_dispatch(
1111
+ host,
1112
+ onhost_copy_base, onhost_copied_download,
1113
+ onhost_copied_file, download_file, opts
1114
+ )
1115
+ end
1116
+ configure_type_defaults_on(host)
1117
+ end
1118
+ end
894
1119
 
895
1120
  def generic_install hosts, opts = {}
896
1121
  step "Installing PE on a generic set of hosts"
@@ -3,7 +3,7 @@ module Beaker
3
3
  module PE
4
4
 
5
5
  module Version
6
- STRING = '2.16.1'
6
+ STRING = '2.18.0'
7
7
  end
8
8
 
9
9
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: beaker-pe
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.16.1
4
+ version: 2.18.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Puppetlabs
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2024-04-04 00:00:00.000000000 Z
11
+ date: 2024-06-12 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rspec
@@ -183,9 +183,6 @@ dependencies:
183
183
  - - ">="
184
184
  - !ruby/object:Gem::Version
185
185
  version: '1'
186
- - - "<"
187
- - !ruby/object:Gem::Version
188
- version: '3'
189
186
  type: :runtime
190
187
  prerelease: false
191
188
  version_requirements: !ruby/object:Gem::Requirement
@@ -193,9 +190,6 @@ dependencies:
193
190
  - - ">="
194
191
  - !ruby/object:Gem::Version
195
192
  version: '1'
196
- - - "<"
197
- - !ruby/object:Gem::Version
198
- version: '3'
199
193
  - !ruby/object:Gem::Dependency
200
194
  name: stringify-hash
201
195
  requirement: !ruby/object:Gem::Requirement
@@ -329,7 +323,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
329
323
  - !ruby/object:Gem::Version
330
324
  version: '0'
331
325
  requirements: []
332
- rubygems_version: 3.3.26
326
+ rubygems_version: 3.3.27
333
327
  signing_key:
334
328
  specification_version: 4
335
329
  summary: Beaker PE DSL Helpers!