X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/0d22de74ea069003b49a9d52878d5f1ac04d71bb..2e74236fa27822addd856f194befc28382990ce0:/sdk/cli/arvados-cli.gemspec diff --git a/sdk/cli/arvados-cli.gemspec b/sdk/cli/arvados-cli.gemspec index 80abc9c497..1ff841acdd 100644 --- a/sdk/cli/arvados-cli.gemspec +++ b/sdk/cli/arvados-cli.gemspec @@ -7,39 +7,51 @@ if not File.exist?('/usr/bin/git') then exit end -git_latest_tag = `git tag -l |sort -V -r |head -n1` -git_latest_tag = git_latest_tag.encode('utf-8').strip -git_timestamp, git_hash = `git log -n1 --first-parent --format=%ct:%H .`.chomp.split(":") -git_timestamp = Time.at(git_timestamp.to_i).utc +git_dir = ENV["GIT_DIR"] +git_work = ENV["GIT_WORK_TREE"] +begin + ENV["GIT_DIR"] = File.expand_path "#{__dir__}/../../.git" + ENV["GIT_WORK_TREE"] = File.expand_path "#{__dir__}/../.." + git_timestamp, git_hash = `git log -n1 --first-parent --format=%ct:%H #{__dir__}`.chomp.split(":") + if ENV["ARVADOS_BUILDING_VERSION"] + version = ENV["ARVADOS_BUILDING_VERSION"] + else + version = `#{__dir__}/../../build/version-at-commit.sh #{git_hash}`.encode('utf-8').strip + end + version = version.sub("~dev", ".dev").sub("~rc", ".rc") + git_timestamp = Time.at(git_timestamp.to_i).utc +ensure + ENV["GIT_DIR"] = git_dir + ENV["GIT_WORK_TREE"] = git_work +end Gem::Specification.new do |s| s.name = 'arvados-cli' - s.version = "#{git_latest_tag}.#{git_timestamp.strftime('%Y%m%d%H%M%S')}" + s.version = version s.date = git_timestamp.strftime("%Y-%m-%d") s.summary = "Arvados CLI tools" s.description = "Arvados command line tools, git commit #{git_hash}" s.authors = ["Arvados Authors"] - s.email = 'gem-dev@curoverse.com' + s.email = 'packaging@arvados.org' #s.bindir = '.' s.licenses = ['Apache-2.0'] - s.files = ["bin/arv", "bin/arv-run-pipeline-instance", - "bin/arv-crunch-job", "bin/arv-tag", "bin/crunch-job", - "LICENSE-2.0.txt"] + s.files = ["bin/arv", "bin/arv-tag", "LICENSE-2.0.txt"] s.executables << "arv" - s.executables << "arv-run-pipeline-instance" - s.executables << "arv-crunch-job" s.executables << "arv-tag" s.required_ruby_version = '>= 2.1.0' - s.add_runtime_dependency 'arvados', '~> 1.2.0', '>= 1.2.0' + s.add_runtime_dependency 'arvados', '>= 1.4.1.20190320201707' # Our google-api-client dependency used to be < 0.9, but that could be - # satisfied by the buggy 0.9.pre*. https://dev.arvados.org/issues/9213 - s.add_runtime_dependency 'cure-google-api-client', '~> 0.6', '>= 0.6.3', '<0.8.9' - s.add_runtime_dependency 'activesupport', '>= 3.2.13', '< 5' + # satisfied by the buggy 0.9.pre*, cf. https://dev.arvados.org/issues/9213 + # We need at least version 0.8.7.3, cf. https://dev.arvados.org/issues/15673 + s.add_runtime_dependency('arvados-google-api-client', '>= 0.8.7.3', '< 0.8.9') + s.add_runtime_dependency 'activesupport', '>= 3.2.13', '< 5.3' s.add_runtime_dependency 'json', '>= 1.7.7', '<3' s.add_runtime_dependency 'optimist', '~> 3.0' s.add_runtime_dependency 'andand', '~> 1.3', '>= 1.3.3' - s.add_runtime_dependency 'oj', '~> 3.0' + # oj 3.10.9 requires ruby >= 2.4 and arvbox doesn't currently have it because of SSO + s.add_runtime_dependency 'oj', '< 3.10.9' s.add_runtime_dependency 'curb', '~> 0.8' + s.add_runtime_dependency 'launchy', '< 2.5' s.homepage = 'https://arvados.org' end