Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
56 changes: 55 additions & 1 deletion appveyor.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@
os: Visual Studio 2015

only_commits:
# Skip commits not related to Python, C++, C#, Go, Ruby or Rust
# Skip commits not related to Python, C++, C#, Go, R, Ruby, or Rust
files:
- appveyor.yml
- c_glib/
Expand All @@ -29,6 +29,7 @@ only_commits:
- format/
- go/
- python/
- r/
- ruby/
- rust/

Expand Down Expand Up @@ -102,6 +103,8 @@ environment:
GO111MODULE: on
GOTOOLDIR: '%GOROOT%\pkg\tool\windows_amd64'
PATH: '%GOPATH%\bin;%GOROOT%\bin;%PATH%'
- JOB: "R without libarrow"
USE_CLCACHE: false

MSVC_DEFAULT_OPTIONS: ON
APPVEYOR_SAVE_CACHE_ON_ERROR: true
Expand All @@ -119,6 +122,57 @@ before_build:
build_script:
- call ci\appveyor-build.bat

for:
-
matrix:
only:
- JOB: "R without libarrow"
init:
ps: |
$ErrorActionPreference = "Stop"
Invoke-WebRequest http://raw.githubusercontent.com/krlmlr/r-appveyor/master/scripts/appveyor-tool.ps1 -OutFile "..\appveyor-tool.ps1"
Import-Module '..\appveyor-tool.ps1'

before_build:
- cd r
- ps: Bootstrap
- cd %APPVEYOR_BUILD_FOLDER%

build_script:
# TODO: for the version of the R tests that builds, probably can't use this
# ci script because we need to build with the Rtools toolchain
# - call ci\appveyor-build.bat
- pushd r
- travis-tool.sh install_deps

test_script:
- travis-tool.sh run_tests

on_failure:
- travis-tool.sh dump_logs

environment:
NOT_CRAN: true

artifacts:
- path: 'r\*.Rcheck\**\*.log'
name: Logs

- path: 'r\*.Rcheck\**\*.out'
name: Logs

- path: 'r\*.Rcheck\**\*.fail'
name: Logs

- path: 'r\*.Rcheck\**\*.Rout'
name: Logs

- path: 'r\*_*.tar.gz'
name: Bits

- path: 'r\*_*.zip'
name: Bits

# Disable test discovery
test: off

Expand Down
7 changes: 7 additions & 0 deletions ci/appveyor-filter-changes.bat
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,13 @@ if "%JOB%" == "Rust" (
echo ===
appveyor exit
)
) else if "%JOB:~,2%" == "R " (
if "%ARROW_CI_R_AFFECTED%" == "0" (
echo ===
echo === No C++ or R changes, exiting job
echo ===
appveyor exit
)
) else (
if "%ARROW_CI_PYTHON_AFFECTED%" == "0" (
echo ===
Expand Down
14 changes: 0 additions & 14 deletions dev/release/00-prepare-test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -130,13 +130,6 @@ def test_update_version_pre_tag
"+Version: #{@release_version}"],
],
},
{
path: "r/src/Makevars.win",
hunks: [
["-VERSION = #{@previous_version}.9000",
"+VERSION = #{@release_version}"],
],
},
{
path: "ruby/red-arrow-cuda/lib/arrow-cuda/version.rb",
hunks: [
Expand Down Expand Up @@ -279,13 +272,6 @@ def test_update_version_post_tag
"+Version: #{@release_version}.9000"],
],
},
{
path: "r/src/Makevars.win",
hunks: [
["-VERSION = #{@release_version}",
"+VERSION = #{@release_version}.9000"],
],
},
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What are these changes about?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The 00-prepare.sh does not modify Makevars.win anymore, the generation of this file is now deferred at installation (@nealrichardson please confirm) via the added configure.win.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This patch makes Makevars.win be generated dynamically, so there's no longer a file that needs to be updated in the release scripts.

{
path: "ruby/red-arrow-cuda/lib/arrow-cuda/version.rb",
hunks: [
Expand Down
8 changes: 0 additions & 8 deletions dev/release/00-prepare.sh
Original file line number Diff line number Diff line change
Expand Up @@ -101,14 +101,6 @@ update_versions() {
git add DESCRIPTION
cd -

cd "${SOURCE_DIR}/../../r/src"
sed -i.bak -E -e \
"s/^VERSION = .+/VERSION = ${r_version}/" \
Makevars.win
rm -f Makevars.win.bak
git add Makevars.win
cd -

cd "${SOURCE_DIR}/../../ruby"
sed -i.bak -E -e \
"s/^ VERSION = \".+\"/ VERSION = \"${version}\"/g" \
Expand Down
47 changes: 47 additions & 0 deletions r/configure.win
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
#!/bin/bash

# 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.


# generate code
if [ "$ARROW_R_DEV" == "TRUE" ]; then
echo "*** Generating code with data-raw/codegen.R"
"${R_HOME}/bin${R_ARCH_BIN}/Rscript.exe" data-raw/codegen.R
fi

VERSION=$(grep ^Version DESCRIPTION | sed s/Version:\ //)
# Try to find/download a C++ Arrow binary
"${R_HOME}/bin${R_ARCH_BIN}/Rscript.exe" "tools/winlibs.R" $VERSION
# If binary not found, script exits nonzero
if [ $? -ne 0 ]; then
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is this expected? And should you exit immediately if this failure is encountered.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

tools/winlibs.R will exit nonzero if https://github.com/apache/arrow/pull/4538/files/328bc376f9adb2717d1505f96d8d7452ee9d8212#diff-48db18073973d5ea65a7f0023f920145R22 fails to find and download a prebuilt binary. This triggers the fallback build-package-without-libarrow behavior (see #4471).

I can add some comments to explain.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ok now I understand more clearly. I think this warrants a comment or clearer message, e.g.

"Failed to download and extract libarrow runtime and dependencies. The R arrow package will compile with shim methods. Please run arrow::install_arrow() to install required runtime libraries and recompile this package with proper support."

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Or separate this message in half, one for users, and a comment for maintainers.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Just pushed some comments

# We'll have to install without libarrow. Note to the user how to rectify.
echo "------------------------- NOTE ---------------------------"
echo "After installation, please run arrow::install_arrow() to install"
echo "required runtime libraries"
echo "---------------------------------------------------------"
else
# Set the right flags to point to and enable arrow/parquet
RWINLIB="../windows/arrow-${VERSION}"
PKG_CFLAGS="-I${RWINLIB}/include -DARROW_STATIC -DPARQUET_STATIC -DARROW_R_WITH_PARQUET -DARROW_R_WITH_ARROW"
PKG_LIBS="-L${RWINLIB}/lib"'$(subst gcc,,$(COMPILED_BY))$(R_ARCH) '"-L${RWINLIB}/lib"'$(R_ARCH) '"-lparquet -larrow -lthrift -lboost_regex-mt-s -ldouble-conversion -lz -lws2_32"
fi

echo "*** Writing Makevars.win"
sed -e "s|@cflags@|$PKG_CFLAGS|" -e "s|@libs@|$PKG_LIBS|" src/Makevars.in > src/Makevars.win
# Success
exit 0
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Small bash nit, exit 0 does not need to be explicited since it's implicit that a script returns 0.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is copypasta from r/configure 🤷‍♂

38 changes: 0 additions & 38 deletions r/src/Makevars.win

This file was deleted.

6 changes: 3 additions & 3 deletions r/tools/winlibs.R
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,10 @@

# Download static arrow from rwinlib
VERSION <- commandArgs(TRUE)
if(!file.exists(sprintf("../windows/arrow-%s/include/arrow/api.h", VERSION))){
if(!file.exists(sprintf("windows/arrow-%s/include/arrow/api.h", VERSION))){
if(getRversion() < "3.3.0") setInternet2()
download.file(sprintf("https://github.com/rwinlib/arrow/archive/v%s.zip", VERSION), "lib.zip", quiet = TRUE)
dir.create("../windows", showWarnings = FALSE)
unzip("lib.zip", exdir = "../windows")
dir.create("windows", showWarnings = FALSE)
unzip("lib.zip", exdir = "windows")
unlink("lib.zip")
}