# Licensed to the Apache Software Foundation (ASF) under one # or more contributor license agreements. See the NOTICE file # distributed with this work for additional information # regarding copyright ownership. The ASF licenses this file # to you under the Apache License, Version 2.0 (the # "License"); you may not use this file except in compliance # with the License. You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, # software distributed under the License is distributed on an # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY # KIND, either express or implied. See the License for the # specific language governing permissions and limitations # under the License. class SourceTest < Test::Unit::TestCase include GitRunnable include VersionDetectable def setup @current_commit = git_current_commit detect_versions @tag_name = "apache-arrow-#{@release_version}" @script = File.expand_path("dev/release/02-source.sh") Dir.mktmpdir do |dir| Dir.chdir(dir) do yield end end end def source(*targets) env = { "SOURCE_DEFAULT" => "0", "release_hash" => @current_commit, } targets.each do |target| env["SOURCE_#{target}"] = "1" end output = sh(env, @script, @release_version, "0") sh("tar", "xf", "#{@tag_name}.tar.gz") output end def test_symbolic_links source Dir.chdir(@tag_name) do assert_equal([], Find.find(".").find_all {|path| File.symlink?(path)}) end end def test_csharp_git_commit_information source Dir.chdir("#{@tag_name}/csharp") do FileUtils.mv("dummy.git", "../.git") sh("dotnet", "pack", "-c", "Release") FileUtils.mv("../.git", "dummy.git") Dir.chdir("artifacts/Apache.Arrow/Release") do sh("unzip", "Apache.Arrow.#{@snapshot_version}.nupkg") FileUtils.chmod(0400, "Apache.Arrow.nuspec") nuspec = REXML::Document.new(File.read("Apache.Arrow.nuspec")) nuspec_repository = nuspec.elements["package/metadata/repository"] attributes = {} nuspec_repository.attributes.each do |key, value| attributes[key] = value end assert_equal({ "type" => "git", "url" => "https://github.com/apache/arrow", "commit" => @current_commit, }, attributes) end end end def test_python_version source Dir.chdir("#{@tag_name}/python") do sh("python3", "setup.py", "sdist") if on_release_branch? pyarrow_source_archive = "dist/pyarrow-#{@release_version}.tar.gz" else pyarrow_source_archive = "dist/pyarrow-#{@release_version}a0.tar.gz" end assert_equal([pyarrow_source_archive], Dir.glob("dist/pyarrow-*.tar.gz")) end end def test_vote jira_url = "https://issues.apache.org/jira" jql_conditions = [ "project = ARROW", "status in (Resolved, Closed)", "fixVersion = #{@release_version}", ] jql = jql_conditions.join(" AND ") n_resolved_issues = nil search_url = URI("#{jira_url}/rest/api/2/search?jql=#{CGI.escape(jql)}") search_url.open do |response| n_resolved_issues = JSON.parse(response.read)["total"] end output = source("VOTE") assert_equal(<<-VOTE.strip, output[/^-+$(.+?)^-+$/m, 1].strip) To: dev@arrow.apache.org Subject: [VOTE] Release Apache Arrow #{@release_version} - RC0 Hi, I would like to propose the following release candidate (RC0) of Apache Arrow version #{@release_version}. This is a release consisting of #{n_resolved_issues} resolved JIRA issues[1]. This release candidate is based on commit: #{@current_commit} [2] The source release rc0 is hosted at [3]. The binary artifacts are hosted at [4][5][6][7][8][9]. The changelog is located at [10]. Please download, verify checksums and signatures, run the unit tests, and vote on the release. See [11] for how to validate a release candidate. The vote will be open for at least 72 hours. [ ] +1 Release this as Apache Arrow #{@release_version} [ ] +0 [ ] -1 Do not release this as Apache Arrow #{@release_version} because... [1]: https://issues.apache.org/jira/issues/?jql=project%20%3D%20ARROW%20AND%20status%20in%20%28Resolved%2C%20Closed%29%20AND%20fixVersion%20%3D%20#{@release_version} [2]: https://github.com/apache/arrow/tree/#{@current_commit} [3]: https://dist.apache.org/repos/dist/dev/arrow/apache-arrow-#{@release_version}-rc0 [4]: https://apache.jfrog.io/artifactory/arrow/amazon-linux-rc/ [5]: https://apache.jfrog.io/artifactory/arrow/centos-rc/ [6]: https://apache.jfrog.io/artifactory/arrow/debian-rc/ [7]: https://apache.jfrog.io/artifactory/arrow/nuget-rc/#{@release_version}-rc0 [8]: https://apache.jfrog.io/artifactory/arrow/python-rc/#{@release_version}-rc0 [9]: https://apache.jfrog.io/artifactory/arrow/ubuntu-rc/ [10]: https://github.com/apache/arrow/blob/#{@current_commit}/CHANGELOG.md [11]: https://cwiki.apache.org/confluence/display/ARROW/How+to+Verify+Release+Candidates VOTE end end