2016-02-15 14:00:52 +01:00
|
|
|
|
|
|
|
# Use the Android base system since it provides the SDK, etc.
|
|
|
|
language: java
|
|
|
|
|
|
|
|
matrix:
|
|
|
|
include:
|
2019-03-30 22:10:21 +01:00
|
|
|
- os: osx
|
|
|
|
osx_image: xcode10.2
|
|
|
|
env: ANDROID_SDK_ROOT=/usr/local/share/android-sdk
|
|
|
|
env: ANDROID_HOME=/usr/local/share/android-sdk
|
2016-02-15 14:00:52 +01:00
|
|
|
- os: osx
|
2018-05-04 09:35:26 +02:00
|
|
|
osx_image: xcode9.3
|
2018-03-07 15:15:28 +01:00
|
|
|
env: ANDROID_SDK_ROOT=/usr/local/share/android-sdk
|
|
|
|
env: ANDROID_HOME=/usr/local/share/android-sdk
|
2017-09-17 12:54:43 +02:00
|
|
|
- os: osx
|
2018-05-04 09:35:26 +02:00
|
|
|
osx_image: xcode8.3
|
2017-09-17 12:54:43 +02:00
|
|
|
env: ANDROID_SDK_ROOT=/usr/local/share/android-sdk
|
|
|
|
env: ANDROID_HOME=/usr/local/share/android-sdk
|
2016-02-15 14:00:52 +01:00
|
|
|
|
2017-09-19 19:58:45 +02:00
|
|
|
android:
|
|
|
|
components:
|
|
|
|
- android-23 # required for `fdroid build` test
|
2019-03-30 22:10:21 +01:00
|
|
|
- build-tools-28.0.3 # required for `fdroid build` test
|
2017-09-19 19:58:45 +02:00
|
|
|
licenses:
|
|
|
|
- 'android-sdk-preview-.+'
|
|
|
|
- 'android-sdk-license-.+'
|
2016-02-15 14:00:52 +01:00
|
|
|
|
2017-10-18 13:40:32 +02:00
|
|
|
# * ensure java8 is installed since Android SDK doesn't work with Java9
|
|
|
|
# * Java needs to be at least 1.8.0_131 to have MD5 properly disabled
|
|
|
|
# https://blogs.oracle.com/java-platform-group/oracle-jre-will-no-longer-trust-md5-signed-code-by-default
|
|
|
|
# https://opsech.io/posts/2017/Jun/09/openjdk-april-2017-security-update-131-8u131-and-md5-signed-jars.html
|
2019-07-01 11:06:16 +02:00
|
|
|
# * mercurial is unused and requires Python 2.x
|
2016-02-15 14:00:52 +01:00
|
|
|
install:
|
2019-07-01 22:43:06 +02:00
|
|
|
- export HOMEBREW_CURL_RETRIES=10
|
2019-07-01 10:15:49 +02:00
|
|
|
- brew update > /dev/null
|
2019-07-01 11:06:16 +02:00
|
|
|
- if [ "`sw_vers -productVersion | sed 's,10\.\([0-9]*\).*,\1,'`" -ge 14 ]; then
|
|
|
|
python3 --version;
|
|
|
|
elif [ "`sw_vers -productVersion | sed 's,10\.\([0-9]*\).*,\1,'`" -gt 10 ]; then
|
|
|
|
brew uninstall mercurial --force;
|
2018-03-07 15:14:30 +01:00
|
|
|
brew upgrade python;
|
2019-07-01 10:15:49 +02:00
|
|
|
else
|
2018-03-07 15:14:30 +01:00
|
|
|
brew install python3;
|
2019-07-01 10:15:49 +02:00
|
|
|
fi
|
|
|
|
- brew install dash bash gnu-sed gradle jenv
|
|
|
|
- export PATH="/usr/local/opt/gnu-sed/libexec/gnubin:$PATH"
|
2019-07-01 22:43:06 +02:00
|
|
|
- brew uninstall java --force || true
|
|
|
|
- brew cask uninstall java --force || true
|
|
|
|
- brew tap adoptopenjdk/openjdk
|
2019-09-23 11:31:14 +02:00
|
|
|
- travis_retry brew cask install adoptopenjdk8
|
|
|
|
- travis_retry brew cask install android-sdk
|
2017-09-19 19:58:31 +02:00
|
|
|
|
2019-07-01 10:15:49 +02:00
|
|
|
- export AAPT_VERSION=`sed -n "s,^MINIMUM_AAPT_VERSION\s*=\s*['\"]\(.*\)[['\"],\1,p" fdroidserver/common.py`
|
|
|
|
- mkdir -p "$ANDROID_HOME/licenses"
|
|
|
|
- echo -e "\n8933bad161af4178b1185d1a37fbf41ea5269c55" > "$ANDROID_HOME/licenses/android-sdk-license"
|
|
|
|
- echo -e "\nd56f5187479451eabf01fb78af6dfcb131a6481e" >> "$ANDROID_HOME/licenses/android-sdk-license"
|
|
|
|
- echo -e "\n24333f8a63b6825ea9c5514f83c2829b004d1fee" >> "$ANDROID_HOME/licenses/android-sdk-license"
|
|
|
|
- echo -e "\n84831b9409646a918e30573bab4c9c91346d8abd" > "$ANDROID_HOME/licenses/android-sdk-preview-license"
|
2019-07-02 21:15:15 +02:00
|
|
|
- echo y | travis_retry $ANDROID_HOME/tools/bin/sdkmanager "platform-tools" > /dev/null
|
|
|
|
- echo y | travis_retry $ANDROID_HOME/tools/bin/sdkmanager "build-tools;$AAPT_VERSION" > /dev/null
|
|
|
|
- echo y | travis_retry $ANDROID_HOME/tools/bin/sdkmanager "platforms;android-23" > /dev/null
|
2017-09-19 19:58:31 +02:00
|
|
|
|
2019-07-02 21:15:15 +02:00
|
|
|
- travis_retry sudo pip3 install --progress-bar off babel
|
|
|
|
- travis_retry sudo pip3 install --quiet --progress-bar off --editable .
|
2019-07-01 10:15:49 +02:00
|
|
|
- sudo rm -rf fdroidserver.egg-info
|
2017-09-19 19:58:31 +02:00
|
|
|
|
2019-07-01 10:15:49 +02:00
|
|
|
- ls -l /System/Library/Java/JavaVirtualMachines || true
|
|
|
|
- ls -l /Library/Java/JavaVirtualMachines || true
|
2019-07-01 22:43:06 +02:00
|
|
|
- for f in /Library/Java/JavaVirtualMachines/*.jdk; do jenv add $f; done
|
2019-07-01 10:15:49 +02:00
|
|
|
- echo $PATH
|
|
|
|
- echo $JAVA_HOME
|
|
|
|
- jenv versions
|
|
|
|
- /usr/libexec/java_home
|
|
|
|
- java -version
|
|
|
|
- which java
|
|
|
|
- javac -version
|
|
|
|
- which javac
|
|
|
|
- jarsigner -help
|
|
|
|
- which jarsigner
|
|
|
|
- keytool -help
|
|
|
|
- which keytool
|
2019-07-01 22:43:06 +02:00
|
|
|
- sudo rm -rf /Library/Java/JavaVirtualMachines/jdk1.8.0_1*.jdk || true
|
2016-02-15 14:00:52 +01:00
|
|
|
|
2017-10-20 08:59:56 +02:00
|
|
|
# The OSX tests seem to run slower, they often timeout. So only run
|
split pip tests to run separately for Ubuntu/trusty and Debian/stretch
Trying to reuse the pip test run is now a lot more work than just
writing it cutstom for each target platform.
Ubuntu/trusty does not have androguard 3.1.x nor aapt >= 26.x, so
using trusty's aapt will always have errors scraping some names from
APKs. This continues to use Google's binary.
`apt-get update` is now disabled by default by Travis, this adds it
back so that the latest files from the PPA are used.
Here's one example of an issue with pip on trusty:
https://github.com/requests/requests/issues/4006
pip3 install --quiet -e /home/travis/build/fdroidtravis/fdroidserver
Exception:
Traceback (most recent call last):
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python-wheels/setuptools-3.3-py2.py3-none-any.whl/pkg_resources.py", line 2482, in _dep_map
return self.__dep_map
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python-wheels/setuptools-3.3-py2.py3-none-any.whl/pkg_resources.py", line 2344, in __getattr__
raise AttributeError(attr)
AttributeError: _DistInfoDistribution__dep_map
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python3.4/site-packages/pip/basecommand.py", line 122, in main
status = self.run(options, args)
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python3.4/site-packages/pip/commands/install.py", line 278, in run
requirement_set.prepare_files(finder, force_root_egg_info=self.bundle, bundle=self.bundle)
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python3.4/site-packages/pip/req.py", line 1266, in prepare_files
req_to_install.extras):
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python-wheels/setuptools-3.3-py2.py3-none-any.whl/pkg_resources.py", line 2291, in requires
dm = self._dep_map
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python-wheels/setuptools-3.3-py2.py3-none-any.whl/pkg_resources.py", line 2484, in _dep_map
self.__dep_map = self._compute_dependencies()
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python-wheels/setuptools-3.3-py2.py3-none-any.whl/pkg_resources.py", line 2517, in _compute_dependencies
common = frozenset(reqs_for_extra(None))
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python-wheels/setuptools-3.3-py2.py3-none-any.whl/pkg_resources.py", line 2514, in reqs_for_extra
if req.marker_fn(override={'extra':extra}):
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python-wheels/setuptools-3.3-py2.py3-none-any.whl/_markerlib/markers.py", line 113, in marker_fn
return eval(compiled_marker, environment)
File "<environment marker>", line 1, in <module>
NameError: name 'platform_system' is not defined
2018-05-11 11:05:11 +02:00
|
|
|
# the test suite with the installed version of fdroid.
|
2019-09-23 10:52:13 +02:00
|
|
|
#
|
|
|
|
# macOS sticks with bash 3.x because of licenses, so avoid use new bash syntax
|
2016-02-15 14:00:52 +01:00
|
|
|
script:
|
2019-09-23 10:52:13 +02:00
|
|
|
- /bin/bash --version
|
|
|
|
- /bin/bash -n gradlew-fdroid tests/run-tests
|
|
|
|
|
split pip tests to run separately for Ubuntu/trusty and Debian/stretch
Trying to reuse the pip test run is now a lot more work than just
writing it cutstom for each target platform.
Ubuntu/trusty does not have androguard 3.1.x nor aapt >= 26.x, so
using trusty's aapt will always have errors scraping some names from
APKs. This continues to use Google's binary.
`apt-get update` is now disabled by default by Travis, this adds it
back so that the latest files from the PPA are used.
Here's one example of an issue with pip on trusty:
https://github.com/requests/requests/issues/4006
pip3 install --quiet -e /home/travis/build/fdroidtravis/fdroidserver
Exception:
Traceback (most recent call last):
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python-wheels/setuptools-3.3-py2.py3-none-any.whl/pkg_resources.py", line 2482, in _dep_map
return self.__dep_map
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python-wheels/setuptools-3.3-py2.py3-none-any.whl/pkg_resources.py", line 2344, in __getattr__
raise AttributeError(attr)
AttributeError: _DistInfoDistribution__dep_map
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python3.4/site-packages/pip/basecommand.py", line 122, in main
status = self.run(options, args)
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python3.4/site-packages/pip/commands/install.py", line 278, in run
requirement_set.prepare_files(finder, force_root_egg_info=self.bundle, bundle=self.bundle)
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python3.4/site-packages/pip/req.py", line 1266, in prepare_files
req_to_install.extras):
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python-wheels/setuptools-3.3-py2.py3-none-any.whl/pkg_resources.py", line 2291, in requires
dm = self._dep_map
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python-wheels/setuptools-3.3-py2.py3-none-any.whl/pkg_resources.py", line 2484, in _dep_map
self.__dep_map = self._compute_dependencies()
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python-wheels/setuptools-3.3-py2.py3-none-any.whl/pkg_resources.py", line 2517, in _compute_dependencies
common = frozenset(reqs_for_extra(None))
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python-wheels/setuptools-3.3-py2.py3-none-any.whl/pkg_resources.py", line 2514, in reqs_for_extra
if req.marker_fn(override={'extra':extra}):
File "/home/travis/build/fdroidtravis/fdroidserver/env/lib/python-wheels/setuptools-3.3-py2.py3-none-any.whl/_markerlib/markers.py", line 113, in marker_fn
return eval(compiled_marker, environment)
File "<environment marker>", line 1, in <module>
NameError: name 'platform_system' is not defined
2018-05-11 11:05:11 +02:00
|
|
|
- ./tests/run-tests
|
2016-02-15 14:00:52 +01:00
|
|
|
|
|
|
|
after_failure:
|
|
|
|
- cd $TRAVIS_BUILD_DIR
|
|
|
|
- ls -lR | curl -F 'clbin=<-' https://clbin.com
|