Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[R-package] [ci] Add Windows CI for R package (fixes #2335) #2936

Merged
merged 93 commits into from
Apr 26, 2020
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
93 commits
Select commit Hold shift + click to select a range
19ed854
first test of appveyor
jameslamb Mar 21, 2020
16476da
strings are strings
jameslamb Mar 21, 2020
f7573f0
lil bit of build script
jameslamb Mar 21, 2020
311d3d8
fixing paths
jameslamb Mar 21, 2020
c422b15
removed unnecessary file
jameslamb Mar 21, 2020
b2fce60
updated CRAN URL
jameslamb Mar 21, 2020
b973b7d
added a lot more printing
jameslamb Mar 21, 2020
a8873f6
fixing paths
jameslamb Mar 21, 2020
952ca55
more stuff
jameslamb Mar 21, 2020
b4cf398
fixed paths
jameslamb Mar 21, 2020
cc6d02b
more stuff
jameslamb Mar 21, 2020
adfb832
more path guessing
jameslamb Mar 21, 2020
92b0032
even more paths
jameslamb Mar 22, 2020
8d77941
more stuff
jameslamb Mar 22, 2020
b7e2abe
moar logz
jameslamb Mar 22, 2020
12fb638
and now for something totally different
jameslamb Mar 22, 2020
1091504
please work
jameslamb Mar 22, 2020
96dcc18
ok could be a thing
jameslamb Mar 22, 2020
97d9913
changing directories
jameslamb Mar 22, 2020
6ed498d
we might be in business
jameslamb Mar 22, 2020
b275d22
fixed install syntax
jameslamb Mar 22, 2020
f701325
tryinv mingw
jameslamb Mar 22, 2020
618086a
more mingw
jameslamb Mar 22, 2020
90f91e5
ignore Suggests check
jameslamb Mar 22, 2020
2f4979a
trying Azure DevOps
jameslamb Mar 22, 2020
3b07c7b
just run bare minimum for Azure DevOps
jameslamb Mar 22, 2020
2d17cae
fixed build dir thing
jameslamb Mar 22, 2020
2e9fe09
trying to set libPaths
jameslamb Mar 22, 2020
855cdc9
more testing
jameslamb Mar 22, 2020
6d8878b
trying R 3.6.3
jameslamb Mar 22, 2020
c854fe3
R 3.6.3
jameslamb Mar 22, 2020
86f4eec
this feels right
jameslamb Mar 22, 2020
8b12858
still messing around with libraries
jameslamb Mar 22, 2020
dc50ad5
more paths
jameslamb Mar 22, 2020
065df95
removed duplication in Windows testing code
jameslamb Mar 22, 2020
432df25
simpler
jameslamb Mar 22, 2020
6e73047
fixed conda stuff
jameslamb Mar 22, 2020
fec3de7
more conda stuff
jameslamb Mar 22, 2020
9b90d84
more fixes
jameslamb Mar 22, 2020
c305e9d
fixed testing script
jameslamb Mar 22, 2020
c70e352
moved AppVeyor setup to the top
jameslamb Mar 22, 2020
517e519
commenting
jameslamb Mar 22, 2020
56bf28a
ch-ch-ch-ch-chaaaanges
jameslamb Mar 22, 2020
f439ba2
paths
jameslamb Mar 22, 2020
2923111
plz work
jameslamb Mar 22, 2020
65915a1
fixed conda stuff in Windows CI
jameslamb Mar 22, 2020
f18399d
uncommented stuff to test a full build
jameslamb Mar 23, 2020
1de8f6c
fixed quotes and removed some unnecessary stuff
jameslamb Mar 23, 2020
a912213
added install.libs.R change
jameslamb Mar 23, 2020
290e5b7
quotes are impoortant
jameslamb Mar 23, 2020
2565df7
added commented-out stuff back in
jameslamb Mar 23, 2020
cd89065
added Windows script, download retries, and MSVC linking
jameslamb Mar 24, 2020
fbf494c
minor fixes
jameslamb Mar 25, 2020
244a14a
cleaned up debugging code in FindLibR
jameslamb Mar 29, 2020
42609cd
cleaned up debugging code and moved R first in CI
jameslamb Mar 29, 2020
2804d45
fixed vsts-ci indentation
jameslamb Mar 31, 2020
af3c004
cut documentation stuff out of MSVC build
jameslamb Mar 31, 2020
1c498d0
fix R CMD check for Azure
jameslamb Mar 31, 2020
9e6aa49
misc whitespace changes
jameslamb Mar 31, 2020
76d264d
merge in #2962
jameslamb Apr 2, 2020
01359ab
Merge branch 'master' into ci/r-windows-ci
jameslamb Apr 4, 2020
d100027
Added echoing of build logs from R CMD check
jameslamb Apr 4, 2020
912a2fd
cut out more documentation tests
jameslamb Apr 4, 2020
d76b551
fixed NOTE about imports from Matrix
jameslamb Apr 4, 2020
7cdfc62
Merge branch 'master' into ci/r-windows-ci
jameslamb Apr 4, 2020
1a2053f
Merge branch 'master' into ci/r-windows-ci
jameslamb Apr 13, 2020
bdf10e0
Merge branch 'master' into ci/r-windows-ci
jameslamb Apr 15, 2020
88a7a09
moved some changes out of this PR and into #2963
jameslamb Apr 15, 2020
ae813f2
fixed whitespace stuff
jameslamb Apr 15, 2020
1b2363a
added check on number of NOTES
jameslamb Apr 15, 2020
dd52dbf
adding better checks
jameslamb Apr 15, 2020
7f9eb7c
fixing check on NOTEs
jameslamb Apr 15, 2020
374ba31
removing unnecessary variable
jameslamb Apr 15, 2020
30d8af1
Update .ci/test_r_package_windows.ps1
jameslamb Apr 15, 2020
e3b9ac8
some changes
jameslamb Apr 15, 2020
419e39b
fix quoting
jameslamb Apr 15, 2020
bfebf1d
trying MINGW on Azure DevOps
jameslamb Apr 16, 2020
3e2dcfd
fixing paths
jameslamb Apr 16, 2020
8ba021a
more paths
jameslamb Apr 16, 2020
51e4d2d
fixing paths
jameslamb Apr 16, 2020
5d74019
testing paths
jameslamb Apr 16, 2020
d7c160b
fixing slashes
jameslamb Apr 16, 2020
a8582db
pinned CTAN mirror
jameslamb Apr 17, 2020
8264f4a
get better logs
jameslamb Apr 17, 2020
d843795
made sure Azure finds MinGW, fixed search for LIBR_CORE_LIBRARY, stop…
jameslamb Apr 19, 2020
10bd18d
Apply suggestions from code review
jameslamb Apr 19, 2020
6ca2be8
added CXX, CC for Windows builds and changed back to building docs on…
jameslamb Apr 19, 2020
cdf1df8
stored LIBR_CORE_LIBRARY hints in one variable
jameslamb Apr 19, 2020
9c59f33
Apply suggestions from code review
jameslamb Apr 20, 2020
747378e
changes from code review
jameslamb Apr 20, 2020
c0b87d6
increased parallel builds for Azure CI
jameslamb Apr 20, 2020
6820fc6
Apply suggestions from code review
jameslamb Apr 21, 2020
7075b80
Merge branch 'master' into ci/r-windows-ci
jameslamb Apr 25, 2020
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
Prev Previous commit
Next Next commit
removed duplication in Windows testing code
  • Loading branch information
jameslamb committed Apr 1, 2020
commit 065df95b3e14cd179fc62d9c1f873c91a0506e52
55 changes: 8 additions & 47 deletions .appveyor.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,58 +7,19 @@ configuration: # a trick to construct a build matrix with multiple Python versi

environment:
matrix:
# - COMPILER: MSVC
# TASK: r-package
# R_WINDOWS_VERSION: 3.6.1
- COMPILER: MSVC
TASK: regular
- COMPILER: MINGW
TASK: regular
- COMPILER: MINGW
TASK: r-package
R_WINDOWS_VERSION: 3.6.3
StrikerRUS marked this conversation as resolved.
Show resolved Hide resolved

clone_depth: 5

install:
- git submodule update --init --recursive # get `compute` folder
- set PATH=%PATH:C:\Program Files\Git\usr\bin;=% # delete sh.exe from PATH (mingw32-make fix)
- set PATH=C:\mingw-w64\x86_64-8.1.0-posix-seh-rt_v6-rev0\mingw64\bin;%PATH%
- set PYTHON_VERSION=%CONFIGURATION%
- ps: >-
switch ($env:PYTHON_VERSION) {
"2.7" {$env:MINICONDA = """C:\Miniconda-x64"""}
"3.5" {$env:MINICONDA = """C:\Miniconda35-x64"""}
"3.6" {$env:MINICONDA = """C:\Miniconda36-x64"""}
"3.7" {$env:MINICONDA = """C:\Miniconda37-x64"""}
default {$env:MINICONDA = """C:\Miniconda37-x64"""}
}
- set PATH=%MINICONDA%;%MINICONDA%\Scripts;%PATH%
- ps: $env:LGB_VER = (Get-Content VERSION.txt).trim()
- activate
- conda config --set always_yes yes --set changeps1 no
- conda update -q -y conda
- conda create -q -y -n test-env python=%PYTHON_VERSION% joblib matplotlib numpy pandas psutil pytest python-graphviz "scikit-learn<=0.21.3" scipy
- activate test-env

build_script:
- cd %APPVEYOR_BUILD_FOLDER%\python-package
# - IF "%COMPILER%"=="MINGW" (
# python setup.py install --mingw)
# ELSE (
# python setup.py install)
install: null
build_script: null

test_script:
# - pytest %APPVEYOR_BUILD_FOLDER%\tests\python_package_test
# - cd %APPVEYOR_BUILD_FOLDER%\examples\python-guide
# - ps: >-
# @("import matplotlib", "matplotlib.use('Agg')") + (Get-Content "plot_example.py") | Set-Content "plot_example.py" # prevent interactive window mode
# (Get-Content "plot_example.py").replace('graph.render(view=True)', 'graph.render(view=False)') | Set-Content "plot_example.py"
# - ps: >-
# foreach ($file in @(Get-ChildItem *.py)) {
# @("import sys, warnings", "warnings.showwarning = lambda message, category, filename, lineno, file=None, line=None: sys.stdout.write(warnings.formatwarning(message, category, filename, lineno, line))") + (Get-Content $file) | Set-Content $file
# python $file
# if (!$?) { $host.SetShouldExit(-1) }
# } # run all examples
# - cd %APPVEYOR_BUILD_FOLDER%\examples\python-guide\notebooks
# - conda install -q -y -n test-env ipywidgets notebook
# - jupyter nbconvert --ExecutePreprocessor.timeout=180 --to notebook --execute --inplace *.ipynb # run all notebooks
#- cmd /c "powershell -ExecutionPolicy Bypass -File %APPVEYOR_BUILD_FOLDER%\.ci\test_windows.ps1"
- cd %APPVEYOR_BUILD_FOLDER%
- powershell.exe -ExecutionPolicy Bypass -File .\.ci\test_windows.ps1
- cd %APPVEYOR_BUILD_FOLDER%
- powershell.exe -ExecutionPolicy Bypass -File .\.ci\test_windows.ps1
48 changes: 41 additions & 7 deletions .ci/test_windows.ps1
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,43 @@ function Check-Output {
}
}

# unify environment variables for Azure devops and AppVeyor
if (Test-Path env:APPVEYOR) {
$env:BUILD_SOURCESDIRECTORY = $env:APPVEYOR_BUILD_FOLDER
}

# setup for Python
if ($env:TASK -ne "r-package") {
if (Test-Path env:APPVEYOR) {
Write-Output "Running AppVeyor-specific setup"
git submodule update --init --recursive # get `compute` folder
$env:PATH = "$env:PATH;C:\Program Files\Git\usr\bin;=" # delete sh.exe from PATH (mingw32-make fix)
$env:PATH = "C:\mingw-w64\x86_64-8.1.0-posix-seh-rt_v6-rev0\mingw64\bin;$env:PATH"
$env:PYTHON_VERSION=$env:CONFIGURATION
switch ($env:PYTHON_VERSION) {
"2.7" {$env:MINICONDA = """C:\Miniconda-x64"""}
"3.5" {$env:MINICONDA = """C:\Miniconda35-x64"""}
"3.6" {$env:MINICONDA = """C:\Miniconda36-x64"""}
"3.7" {$env:MINICONDA = """C:\Miniconda37-x64"""}
default {$env:MINICONDA = """C:\Miniconda37-x64"""}
}
$env:PATH = "$env:MINICONDA;$env:MINICONDA\Scripts;$env:PATH"
$env:LGB_VER = (Get-Content VERSION.txt).trim()
}
activate
conda config --set always_yes yes --set changeps1 no
conda update -q -y conda
conda create -q -y -n test-env python=$env:PYTHON_VERSION joblib matplotlib numpy pandas psutil pytest python-graphviz "scikit-learn<=0.21.3" scipy
activate test-env
cd %APPVEYOR_BUILD_FOLDER%\python-package
Write-Output "Using compiler: '$env:COMPILER'"
if ($env:COMPILER -eq "MINGW") {
python setup.py install --mingw)
} else {
python setup.py install
}
}

if ($env:TASK -eq "regular") {
mkdir $env:BUILD_SOURCESDIRECTORY/build; cd $env:BUILD_SOURCESDIRECTORY/build
cmake -A x64 .. ; cmake --build . --target ALL_BUILD --config Release ; Check-Output $?
Expand Down Expand Up @@ -57,24 +94,22 @@ if ($env:TASK -eq "regular") {
# based on https://github.com/RGF-team/rgf/blob/master/R-package/.R.appveyor.ps1
if ($env:TASK -eq "r-package"){

#Get-ChildItem env: | Export-CliXml ./env-vars.clixml
#Import-CliXml .\env-vars.clixml | % { Set-Item "env:$($_.Name)" $_.Value }
$env:R_LIB_PATH = "C:/RLibrary"
$env:R_LIBS = "$env:R_LIB_PATH/R/library"
Write-Output "R_LIB_PATH: $env:R_LIB_PATH"
Write-Output "R_LIBS: $env:R_LIBS"

if (Test-Path env:APPVEYOR) {
cd $env:APPVEYOR_BUILD_FOLDER
}
# if (Test-Path env:APPVEYOR) {
# cd $env:APPVEYOR_BUILD_FOLDER
# }
cd $env:BUILD_SOURCESDIRECTORY

tzutil /s "GMT Standard Time"

[Void][System.IO.Directory]::CreateDirectory($env:R_LIB_PATH)

#$env:PATH = "$env:R_LIB_PATH\Rtools\bin;" + "$env:R_LIB_PATH\R\bin\x64;" + "$env:R_LIB_PATH\R\R-$env:R_WINDOWS_VERSION\bin\x64;" + "$env:R_LIB_PATH\R\R-$env:R_WINDOWS_VERSION\bin;" + "$env:R_LIB_PATH\miktex\texmfs\install\miktex\bin\x64;" + $env:PATH
$env:PATH = "$env:R_LIB_PATH/Rtools/bin;" + "$env:R_LIB_PATH/R/bin/x64;" + "$env:R_LIB_PATH/miktex/texmfs/install/miktex/bin/x64;" + $env:PATH
Write-Output "PATH: $env:PATH"
$env:BINPREF = "C:/mingw-w64/x86_64-8.1.0-posix-seh-rt_v6-rev0/mingw64/bin/"

# set up R if it doesn't exist yet
Expand Down Expand Up @@ -119,7 +154,6 @@ if ($env:TASK -eq "r-package"){
Rscript.exe -e "install.packages(c('data.table', 'jsonlite', 'Matrix', 'R6', 'testthat'), dependencies = c('Imports', 'Depends', 'LinkingTo'), lib = '$env:R_LIBS')" ; Check-Output $?

Write-Output "Building R package"
#Rscript.exe -e "install.packages('R6', pkgType = 'source')"
Rscript --no-save -e "print(.libPaths())"
Rscript --no-save -e "print('loading R6'); library(R6)"
Rscript --no-save -e "print('R_LIBS'); print(Sys.getenv('R_LIBS'))"
Expand Down
32 changes: 16 additions & 16 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,24 +14,24 @@ env:
global: # default values
- PYTHON_VERSION=3.7
matrix:
- TASK=regular PYTHON_VERSION=3.6
- TASK=sdist PYTHON_VERSION=2.7
- TASK=bdist
- TASK=if-else
- TASK=lint
- TASK=check-docs
- TASK=mpi METHOD=source
- TASK=mpi METHOD=pip
- TASK=gpu METHOD=source PYTHON_VERSION=3.5
- TASK=gpu METHOD=pip PYTHON_VERSION=3.6
# - TASK=regular PYTHON_VERSION=3.6
# - TASK=sdist PYTHON_VERSION=2.7
# - TASK=bdist
# - TASK=if-else
# - TASK=lint
# - TASK=check-docs
# - TASK=mpi METHOD=source
# - TASK=mpi METHOD=pip
# - TASK=gpu METHOD=source PYTHON_VERSION=3.5
# - TASK=gpu METHOD=pip PYTHON_VERSION=3.6
- TASK=r-package

matrix:
exclude:
- os: osx
env: TASK=gpu METHOD=source PYTHON_VERSION=3.5
- os: osx
env: TASK=gpu METHOD=pip PYTHON_VERSION=3.6
# - os: osx
# env: TASK=gpu METHOD=source PYTHON_VERSION=3.5
# - os: osx
# env: TASK=gpu METHOD=pip PYTHON_VERSION=3.6
- os: osx
env: TASK=lint
- os: osx
Expand All @@ -45,11 +45,11 @@ before_install:
- if [[ $TRAVIS_OS_NAME == "osx" ]]; then
export OS_NAME="macos";
export COMPILER="gcc";
export R_MAC_VERSION=3.6.1;
export R_MAC_VERSION=3.6.3;
else
export OS_NAME="linux";
export COMPILER="clang";
export R_TRAVIS_LINUX_VERSION=3.6.1-3bionic;
export R_TRAVIS_LINUX_VERSION=3.6.3-3bionic;
fi
- export CONDA="$HOME/miniconda"
- export PATH="$CONDA/bin:$PATH"
Expand Down
24 changes: 11 additions & 13 deletions .vsts-ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,7 @@ jobs:
echo "##vso[task.setvariable variable=CONDA]$CONDA"
echo "##vso[task.prependpath]$CONDA/bin"
echo "##vso[task.setvariable variable=JAVA_HOME]$JAVA_HOME_8_X64"
echo "##vso[task.setvariable variable=R_MAC_VERSION]3.6.1"
echo "##vso[task.setvariable variable=R_MAC_VERSION]3.6.3"
displayName: 'Set variables'
- bash: $(Build.SourcesDirectory)/.ci/setup.sh
displayName: Setup
Expand All @@ -119,24 +119,22 @@ jobs:
strategy:
maxParallel: 3
jameslamb marked this conversation as resolved.
Show resolved Hide resolved
matrix:
# regular:
# TASK: regular
# PYTHON_VERSION: 3.7
# sdist:
# TASK: sdist
# PYTHON_VERSION: 2.7
# bdist:
# TASK: bdist
# PYTHON_VERSION: 3.5
regular:
TASK: regular
PYTHON_VERSION: 3.7
sdist:
TASK: sdist
PYTHON_VERSION: 2.7
bdist:
TASK: bdist
PYTHON_VERSION: 3.5
rpkg:
TASK: r-package
R_WINDOWS_VERSION: 3.6.3
steps:
- powershell: Write-Host "##vso[task.prependpath]$env:CONDA\Scripts"
displayName: Enable conda
- script: |
cmd /c 'activate & conda config --set always_yes yes --set changeps1 no & conda update -q -y conda & conda create -q -y -n %CONDA_ENV% python=%PYTHON_VERSION% joblib matplotlib numpy pandas psutil pytest python-graphviz "scikit-learn<=0.21.3" scipy'
cmd /c "activate %CONDA_ENV% & powershell -ExecutionPolicy Bypass -File %BUILD_SOURCESDIRECTORY%/.ci/test_windows.ps1"
- script: cmd /c "activate %CONDA_ENV% & powershell -ExecutionPolicy Bypass -File %BUILD_SOURCESDIRECTORY%/.ci/test_windows.ps1"
displayName: Test
- task: PublishBuildArtifacts@1
condition: and(succeeded(), in(variables['TASK'], 'regular', 'sdist', 'bdist'), not(startsWith(variables['Build.SourceBranch'], 'refs/pull/')))
Expand Down