Skip to content

Commit

Permalink
(SIMP-10415) Honor build/rpm_metadata/requires
Browse files Browse the repository at this point in the history
Before this patch, the project's RPM .spec file used a hard-coded
`Release:` number that could not be overridden by the optional
`build/rpm_metadata/release` file used by other projects.  The lack of
this capability prevents GHA pkg:single builds from tagging & building
pre-release RPMs for the assets  when PRs are still pending for final
release, which in turn prevents staging full yum repositories to start
testing the product install and dep resolution.

This patch adds support for `build/rpm_metadata/release`, and defaults
to the standard `-1` Release value.

[SIMP-10415] #comment Update rubygem-simp-cli
[SIMP-10416] #close
  • Loading branch information
op-ct committed Aug 5, 2021
1 parent 539d900 commit a70f657
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 3 deletions.
46 changes: 44 additions & 2 deletions build/rubygem-simp-cli.spec
Original file line number Diff line number Diff line change
@@ -1,3 +1,45 @@
%{lua:
--
-- When buildng the RPM, declare macro 'pup_module_info_dir' with the path to
-- the top-level project directory. This directory should contain the
-- following items:
-- * 'build' directory
-- * 'README.md' file
--
package_release = '1'
local potential_src_dirs = {
rpm.expand('%{pup_module_info_dir}'),
rpm.expand('%{_sourcedir}'),
posix.getcwd(),
}
local src_dir = "\0"

for _k,dir in pairs(potential_src_dirs) do
if (posix.stat(dir .. '/build', 'type') == 'directory') and (posix.stat(dir .. '/README.md', 'type') == 'regular') then
src_dir = dir
break
end
end

if src_dir == "\0" then
error(
"FATAL: Cannot determine RPM project's src_dir!\n" ..
"\t* Paths tried: '" .. table.concat(potential_src_dirs, "', '") .."\n" ..
"\t* PROTIP: Declare macro %pup_module_info_dir\n"
)
end

rel_file = (io.open(src_dir .. "/build/rpm_metadata/release", "r") or io.open(src_dir .. "/release", "r"))
if rel_file then
for line in rel_file:lines() do
if not (line:match("^%s*#") or line:match("^%s*$")) then
package_release = line
break
end
end
end
}

%global gemname simp-cli

%global gemdir /usr/share/simp/ruby
Expand All @@ -12,7 +54,7 @@
Summary: a cli interface to configure/manage SIMP
Name: rubygem-%{gemname}
Version: %{cli_version}
Release: 1%{?dist}
Release: %{lua: print(package_release)}%{?dist}
Group: Development/Languages
License: Apache-2.0
URL: https://github.com/simp/rubygem-simp-cli
Expand Down Expand Up @@ -65,7 +107,7 @@ Documentation for %{name}
%package highline
Summary: A highline Gem for use with the SIMP CLI
Version: %{highline_version}
Release: 0
Release: %{lua: print(package_release)}%{?dist}
License: GPL-2.0
URL: https://github.com/JEG2/highline
Source11: highline-%{highline_version}.gem
Expand Down
2 changes: 1 addition & 1 deletion simp-cli.gemspec
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@ Gem::Specification.new do |s|
s.add_development_dependency 'pry', '~> 0'
s.add_development_dependency 'pry-doc', '~> 0'
s.add_development_dependency 'dotenv', '~> 1'
s.add_development_dependency 'rubocop', '~> 0.29'
s.add_development_dependency 'rubocop', '~> 0.49'

# simple text description of external requirements (for humans to read)
s.requirements << 'SIMP OS installation'
Expand Down

0 comments on commit a70f657

Please sign in to comment.