diff --git a/README.md b/README.md
index 66e7605a63142..6295e7374e1ee 100644
--- a/README.md
+++ b/README.md
@@ -20,7 +20,14 @@
Build Status |
-
+
+
+ |
+
+ |
+
+
+
|
diff --git a/appveyor.yml b/appveyor.yml
index 9cec7895f1493..094a2a096c1ce 100644
--- a/appveyor.yml
+++ b/appveyor.yml
@@ -1,3 +1,13 @@
+# With infos from
+# http://tjelvarolsson.com/blog/how-to-continuously-test-your-python-code-on-windows-using-appveyor/
+# https://packaging.python.org/en/latest/appveyor/
+# https://github.com/rmcgibbo/python-appveyor-conda-example
+
+# Backslashes in quotes need to be escaped: \ -> "\\"
+
+matrix:
+ fast_finish: true # immediately finish build once one of the jobs fails.
+
environment:
global:
# SDK v7.0 MSVC Express 2008's SetEnv.cmd script will fail if the
@@ -6,33 +16,60 @@ environment:
CMD_IN_ENV: "cmd /E:ON /V:ON /C .\\ci\\run_with_env.cmd"
matrix:
- - PYTHON: "C:\\Python27_32"
- PYTHON_VERSION: "2.7"
- PYTHON_ARCH: "32"
+ - PYTHON: "C:\\Python35_64"
+ PYTHON_VERSION: "3.5"
+ PYTHON_ARCH: "64"
+ CONDA_PY: "35"
+ CONDA_NPY: "110"
- PYTHON: "C:\\Python27_64"
PYTHON_VERSION: "2.7"
PYTHON_ARCH: "64"
+ CONDA_PY: "27"
+ CONDA_NPY: "110"
- - PYTHON: "C:\\Python34_32"
- PYTHON_VERSION: "3.4"
- PYTHON_ARCH: "32"
+# We always use a 64-bit machine, but can build x86 distributions
+# with the PYTHON_ARCH variable (which is used by CMD_IN_ENV).
+platform:
+ - x64
- - PYTHON: "C:\\Python34_64"
- PYTHON_VERSION: "3.4"
- PYTHON_ARCH: "64"
+# all our python builds have to happen in tests_script...
+build: false
+
+init:
+ - "ECHO %PYTHON_VERSION% %PYTHON%"
install:
# this installs the appropriate Miniconda (Py2/Py3, 32/64 bit),
- # as well as pip, conda-build, and the binstar CLI
+ - powershell .\ci\install.ps1
+ - SET PATH=%PYTHON%;%PYTHON%\Scripts;%PATH%
- echo "install"
- cd
- ls -ltr
- - powershell .\\ci\\install_appveyor.ps1
- - "SET PATH=%PYTHON%;%PYTHON%\\Scripts;%PATH%"
+ - git tag --sort v:refname
-build: false
+ # install our build environment
+ - cmd: conda config --set show_channel_urls yes --set always_yes yes --set changeps1 no
+ - cmd: conda update -q conda
+ - cmd: conda config --add channels http://conda.anaconda.org/pandas
+ - cmd: conda config --set ssl_verify false
+
+ # this is now the downloaded conda...
+ - conda info -a
+
+ # build em using the local source checkout in the correct windows env
+ - conda install conda-build
+ - cmd: '%CMD_IN_ENV% conda build conda.recipe -q --no-test'
+
+ # create our env
+ - SET REQ=ci\requirements-%PYTHON_VERSION%-%PYTHON_ARCH%.run
+ - cmd: conda create -q -n pandas python=%PYTHON_VERSION% nose
+ - cmd: activate pandas
+ - cmd: conda install -q --file=%REQ%
+ - ps: conda install -q (conda build conda.recipe -q --output --no-test)
test_script:
- - "%CMD_IN_ENV% %PYTHON%/python.exe setup.py build_ext --inplace"
- - "%PYTHON%/Scripts/nosetests -A \"not slow and not network and not disabled\" pandas"
+ # tests
+ - cd \
+ - conda list pandas
+ - nosetests --exe -A "not slow and not network and not disabled" pandas
diff --git a/ci/install.ps1 b/ci/install.ps1
new file mode 100644
index 0000000000000..c964973c67693
--- /dev/null
+++ b/ci/install.ps1
@@ -0,0 +1,96 @@
+# Sample script to install Miniconda under Windows
+# Authors: Olivier Grisel, Jonathan Helmus and Kyle Kastner, Robert McGibbon
+# License: CC0 1.0 Universal: http://creativecommons.org/publicdomain/zero/1.0/
+
+$MINICONDA_URL = "http://repo.continuum.io/miniconda/"
+
+
+function DownloadMiniconda ($python_version, $platform_suffix) {
+ $webclient = New-Object System.Net.WebClient
+ if ($python_version -match "3.4") {
+ $filename = "Miniconda3-latest-Windows-" + $platform_suffix + ".exe"
+ } else {
+ $filename = "Miniconda-latest-Windows-" + $platform_suffix + ".exe"
+ }
+ $url = $MINICONDA_URL + $filename
+
+ $basedir = $pwd.Path + "\"
+ $filepath = $basedir + $filename
+ if (Test-Path $filename) {
+ Write-Host "Reusing" $filepath
+ return $filepath
+ }
+
+ # Download and retry up to 3 times in case of network transient errors.
+ Write-Host "Downloading" $filename "from" $url
+ $retry_attempts = 2
+ for($i=0; $i -lt $retry_attempts; $i++){
+ try {
+ $webclient.DownloadFile($url, $filepath)
+ break
+ }
+ Catch [Exception]{
+ Start-Sleep 1
+ }
+ }
+ if (Test-Path $filepath) {
+ Write-Host "File saved at" $filepath
+ } else {
+ # Retry once to get the error message if any at the last try
+ $webclient.DownloadFile($url, $filepath)
+ }
+ return $filepath
+}
+
+
+function InstallMiniconda ($python_version, $architecture, $python_home) {
+ Write-Host "Installing Python" $python_version "for" $architecture "bit architecture to" $python_home
+ if (Test-Path $python_home) {
+ Write-Host $python_home "already exists, skipping."
+ return $false
+ }
+ if ($architecture -match "32") {
+ $platform_suffix = "x86"
+ } else {
+ $platform_suffix = "x86_64"
+ }
+
+ $filepath = DownloadMiniconda $python_version $platform_suffix
+ Write-Host "Installing" $filepath "to" $python_home
+ $install_log = $python_home + ".log"
+ $args = "/S /D=$python_home"
+ Write-Host $filepath $args
+ Start-Process -FilePath $filepath -ArgumentList $args -Wait -Passthru
+ if (Test-Path $python_home) {
+ Write-Host "Python $python_version ($architecture) installation complete"
+ } else {
+ Write-Host "Failed to install Python in $python_home"
+ Get-Content -Path $install_log
+ Exit 1
+ }
+}
+
+
+function InstallCondaPackages ($python_home, $spec) {
+ $conda_path = $python_home + "\Scripts\conda.exe"
+ $args = "install --yes " + $spec
+ Write-Host ("conda " + $args)
+ Start-Process -FilePath "$conda_path" -ArgumentList $args -Wait -Passthru
+}
+
+function UpdateConda ($python_home) {
+ $conda_path = $python_home + "\Scripts\conda.exe"
+ Write-Host "Updating conda..."
+ $args = "update --yes conda"
+ Write-Host $conda_path $args
+ Start-Process -FilePath "$conda_path" -ArgumentList $args -Wait -Passthru
+}
+
+
+function main () {
+ InstallMiniconda $env:PYTHON_VERSION $env:PYTHON_ARCH $env:PYTHON
+ UpdateConda $env:PYTHON
+ InstallCondaPackages $env:PYTHON "conda-build jinja2 anaconda-client"
+}
+
+main
diff --git a/ci/requirements-2.7-64.run b/ci/requirements-2.7-64.run
new file mode 100644
index 0000000000000..260ae8125e040
--- /dev/null
+++ b/ci/requirements-2.7-64.run
@@ -0,0 +1,22 @@
+dateutil
+pytz
+numpy
+xlwt
+numexpr
+pytables
+matplotlib
+openpyxl
+xlrd
+sqlalchemy
+lxml=3.2.1
+scipy
+xlsxwriter
+boto
+bottleneck
+patsy
+html5lib
+beautiful-soup
+jinja2=2.8
+
+#pymysql=0.6.3
+#psycopg2=2.5.2
diff --git a/ci/requirements-3.5-64.run b/ci/requirements-3.5-64.run
new file mode 100644
index 0000000000000..6beeb2fc31369
--- /dev/null
+++ b/ci/requirements-3.5-64.run
@@ -0,0 +1,25 @@
+python-dateutil
+pytz
+numpy
+openpyxl
+xlsxwriter
+xlrd
+xlwt
+patsy
+scipy
+numexpr
+pytables
+html5lib
+lxml
+matplotlib
+jinja2
+blosc
+
+# currently causing some warnings
+#sqlalchemy
+#pymysql
+#psycopg2
+
+# not available from conda
+#beautiful-soup
+#bottleneck
diff --git a/ci/run_with_env.cmd b/ci/run_with_env.cmd
index 3a472bc836c30..848f4608c8627 100644
--- a/ci/run_with_env.cmd
+++ b/ci/run_with_env.cmd
@@ -1,3 +1,7 @@
+:: EXPECTED ENV VARS: PYTHON_ARCH (either x86 or x64)
+:: CONDA_PY (either 27, 33, 35 etc. - only major version is extracted)
+::
+::
:: To build extensions for 64 bit Python 3, we need to configure environment
:: variables to use the MSVC 2010 C++ compilers from GRMSDKX_EN_DVD.iso of:
:: MS Windows SDK for Windows 7 and .NET Framework 4 (SDK v7.1)
@@ -6,7 +10,8 @@
:: variables to use the MSVC 2008 C++ compilers from GRMSDKX_EN_DVD.iso of:
:: MS Windows SDK for Windows 7 and .NET Framework 3.5 (SDK v7.0)
::
-:: 32 bit builds do not require specific environment configurations.
+:: 32 bit builds, and 64-bit builds for 3.5 and beyond, do not require specific
+:: environment configurations.
::
:: Note: this script needs to be run with the /E:ON and /V:ON flags for the
:: cmd interpreter, at least for (SDK v7.0)
@@ -15,33 +20,76 @@
:: https://github.com/cython/cython/wiki/64BitCythonExtensionsOnWindows
:: http://stackoverflow.com/a/13751649/163740
::
-:: Author: Olivier Grisel
+:: Author: Phil Elson
+:: Original Author: Olivier Grisel (https://github.com/ogrisel/python-appveyor-demo)
:: License: CC0 1.0 Universal: http://creativecommons.org/publicdomain/zero/1.0/
+::
+:: Notes about batch files for Python people:
+::
+:: Quotes in values are literally part of the values:
+:: SET FOO="bar"
+:: FOO is now five characters long: " b a r "
+:: If you don't want quotes, don't include them on the right-hand side.
+::
+:: The CALL lines at the end of this file look redundant, but if you move them
+:: outside of the IF clauses, they do not run properly in the SET_SDK_64==Y
+:: case, I don't know why.
+:: originally from https://github.com/pelson/Obvious-CI/blob/master/scripts/obvci_appveyor_python_build_env.cmd
@ECHO OFF
SET COMMAND_TO_RUN=%*
SET WIN_SDK_ROOT=C:\Program Files\Microsoft SDKs\Windows
-SET MAJOR_PYTHON_VERSION="%PYTHON_VERSION:~0,1%"
-IF %MAJOR_PYTHON_VERSION% == "2" (
+:: Extract the major and minor versions, and allow for the minor version to be
+:: more than 9. This requires the version number to have two dots in it.
+SET MAJOR_PYTHON_VERSION=%CONDA_PY:~0,1%
+
+IF "%CONDA_PY:~2,1%" == "" (
+ :: CONDA_PY style, such as 27, 34 etc.
+ SET MINOR_PYTHON_VERSION=%CONDA_PY:~1,1%
+) ELSE (
+ IF "%CONDA_PY:~3,1%" == "." (
+ SET MINOR_PYTHON_VERSION=%CONDA_PY:~2,1%
+ ) ELSE (
+ SET MINOR_PYTHON_VERSION=%CONDA_PY:~2,2%
+ )
+)
+
+:: Based on the Python version, determine what SDK version to use, and whether
+:: to set the SDK for 64-bit.
+IF %MAJOR_PYTHON_VERSION% == 2 (
SET WINDOWS_SDK_VERSION="v7.0"
-) ELSE IF %MAJOR_PYTHON_VERSION% == "3" (
- SET WINDOWS_SDK_VERSION="v7.1"
+ SET SET_SDK_64=Y
) ELSE (
- ECHO Unsupported Python version: "%MAJOR_PYTHON_VERSION%"
- EXIT 1
+ IF %MAJOR_PYTHON_VERSION% == 3 (
+ SET WINDOWS_SDK_VERSION="v7.1"
+ IF %MINOR_PYTHON_VERSION% LEQ 4 (
+ SET SET_SDK_64=Y
+ ) ELSE (
+ SET SET_SDK_64=N
+ )
+ ) ELSE (
+ ECHO Unsupported Python version: "%MAJOR_PYTHON_VERSION%"
+ EXIT /B 1
+ )
)
IF "%PYTHON_ARCH%"=="64" (
- ECHO Configuring Windows SDK %WINDOWS_SDK_VERSION% for Python %MAJOR_PYTHON_VERSION% on a 64 bit architecture
- SET DISTUTILS_USE_SDK=1
- SET MSSdk=1
- "%WIN_SDK_ROOT%\%WINDOWS_SDK_VERSION%\Setup\WindowsSdkVer.exe" -q -version:%WINDOWS_SDK_VERSION%
- "%WIN_SDK_ROOT%\%WINDOWS_SDK_VERSION%\Bin\SetEnv.cmd" /x64 /release
- ECHO Executing: %COMMAND_TO_RUN%
- call %COMMAND_TO_RUN% || EXIT 1
+ IF %SET_SDK_64% == Y (
+ ECHO Configuring Windows SDK %WINDOWS_SDK_VERSION% for Python %MAJOR_PYTHON_VERSION% on a 64 bit architecture
+ SET DISTUTILS_USE_SDK=1
+ SET MSSdk=1
+ "%WIN_SDK_ROOT%\%WINDOWS_SDK_VERSION%\Setup\WindowsSdkVer.exe" -q -version:%WINDOWS_SDK_VERSION%
+ "%WIN_SDK_ROOT%\%WINDOWS_SDK_VERSION%\Bin\SetEnv.cmd" /x64 /release
+ ECHO Executing: %COMMAND_TO_RUN%
+ call %COMMAND_TO_RUN% || EXIT /B 1
+ ) ELSE (
+ ECHO Using default MSVC build environment for 64 bit architecture
+ ECHO Executing: %COMMAND_TO_RUN%
+ call %COMMAND_TO_RUN% || EXIT /B 1
+ )
) ELSE (
ECHO Using default MSVC build environment for 32 bit architecture
ECHO Executing: %COMMAND_TO_RUN%
- call %COMMAND_TO_RUN% || EXIT 1
+ call %COMMAND_TO_RUN% || EXIT /B 1
)
diff --git a/conda.recipe/meta.yaml b/conda.recipe/meta.yaml
index 0f1789f3c07a9..279327b93c805 100644
--- a/conda.recipe/meta.yaml
+++ b/conda.recipe/meta.yaml
@@ -6,7 +6,7 @@ build:
number: {{ environ.get('GIT_DESCRIBE_NUMBER', 0) }}
source:
- git_url: ../
+ path: ../../
requirements:
build:
@@ -28,12 +28,6 @@ test:
imports:
- pandas
- #requires:
- # - nose
-
- #commands:
- # - nosetests --exe -A "not slow and not network and not disabled" pandas
-
about:
home: http://pandas.pydata.org
license: BSD