diff options
author | bnewbold <bnewbold@robocracy.org> | 2016-04-05 13:14:53 -0400 |
---|---|---|
committer | bnewbold <bnewbold@robocracy.org> | 2016-04-05 16:16:47 -0400 |
commit | 84f6fc774ef06c44ddb03df67636e68d4d53cb40 (patch) | |
tree | 51596732f049f17cd0b76dc2f1379b381d83e036 | |
parent | 3ad62ec14d7218bd8b3636a6d8f0f9c5fbe16db2 (diff) | |
download | PyX.jl-84f6fc774ef06c44ddb03df67636e68d4d53cb40.tar.gz PyX.jl-84f6fc774ef06c44ddb03df67636e68d4d53cb40.zip |
Fix travis CI builds (py2.7 and py3.5); update TODOtravis-debug
This took some epic Travis/Julia/Python munging because of Travis's
weird python path setup, and it will probably break as soon as python
is upgraded from 3.5 to 3.6 on their servers.
Might be useful to other Julia Python-wrapping libraries!
-rw-r--r-- | .travis.yml | 26 | ||||
-rw-r--r-- | TODO | 4 |
2 files changed, 23 insertions, 7 deletions
diff --git a/.travis.yml b/.travis.yml index 8b6aa97..24083b5 100644 --- a/.travis.yml +++ b/.travis.yml @@ -12,14 +12,34 @@ julia: # Note: deps are tricky! Need full TeX/LaTeX, etc before_install: - if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then sudo apt-get -qq update ; fi - - if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then sudo apt-get install -y python-pyx python3-pip ; fi - - if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then sudo pip3 install PyX ; fi + - if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then sudo apt-get install -y python-pyx python3-pip python-pip ; fi + # Yes, we really do need to double-install PyX with both apt-get and pip here! + # See: https://github.com/travis-ci/travis-ci/issues/4989 (python path) + # Also: https://github.com/travis-ci/travis-ci/issues/1705 (pip permissions) + - if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then pip install --user -I PyX==0.12.1 ; fi + - if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then pip3 install --user PyX ; fi - if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then brew update > /dev/null ; fi - if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then brew install caskroom/cask/brew-cask > /dev/null; fi - if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then brew cask install mactex > /dev/null ; fi - if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then sudo pip install PyX ; fi + # Python stuff on Travis CI seems to be a total mess. The below should work circa April 2016. + # Note the output of the below debugging statements... the default python + # environment on the path is under /opt, and is different for the regular user + # vs. sudo/root, and pip/pip3 may also get confused about paths + - which python2 + - which python3 + - sudo which python2 + - sudo which python3 + - python2 -c "import sys; print(sys.path)" + - python3 -c "import sys; print(sys.path)" + - pip freeze + - pip3 freeze - python2 -c "import pyx; print(pyx.__version__)" - python3 -c "import pyx; print(pyx.__version__)" + - /usr/bin/python2 -c "import pyx; print(pyx.__version__)" + - /opt/python/3.5.0/bin/python3 -c "import pyx; print(pyx.__version__)" + # This line would fail! + #- /usr/bin/python3 -c "import pyx; print(pyx.__version__)" - julia -e 'Pkg.update()' - julia -e 'Pkg.add("PyCall")' notifications: @@ -30,5 +50,5 @@ script: - julia -e 'Pkg.clone(pwd());' - julia -e 'ENV["PYTHON"] = "/usr/bin/python2"; Pkg.build("PyCall")' - julia -e 'Pkg.build("PyX"); Pkg.test("PyX"; coverage=true)' - - julia -e 'ENV["PYTHON"] = "/usr/bin/python3"; Pkg.build("PyCall")' + - julia -e 'ENV["PYTHON"] = "/opt/python/3.5.0/bin/python3"; Pkg.build("PyCall")' - julia -e 'Pkg.build("PyX"); Pkg.test("PyX"; coverage=true)' @@ -1,4 +0,0 @@ -- lots of temporary files (.log, .dvi, etc) get left around. need to somehow - tell python to exit cleanly at the end, and maybe also use a different - temporary directory. -- travis: figure out how to do both Python2 and Python3 tests |