Commit 6c47faa8 authored by Thomas Van Lenten's avatar Thomas Van Lenten

Make the CocoaPods integration tests more robust

- Env solution doesn't seem to always work, use template pod files and copy
  them in place instead.
- Flush the pods cache before and after runs.
- Make pod install verbose to have the info incase something goes wrong.
parent c034ba76
...@@ -3,9 +3,7 @@ platform :osx, '10.9' ...@@ -3,9 +3,7 @@ platform :osx, '10.9'
install! 'cocoapods', :deterministic_uuids => false install! 'cocoapods', :deterministic_uuids => false
if ENV['USE_FRAMEWORKS'] == 'YES' then use_frameworks!
use_frameworks!
end
target 'OSXCocoaPodsTester' do target 'OSXCocoaPodsTester' do
pod 'Protobuf', :path => '../../../..' pod 'Protobuf', :path => '../../../..'
......
source 'https://github.com/CocoaPods/Specs.git'
platform :osx, '10.9'
install! 'cocoapods', :deterministic_uuids => false
target 'OSXCocoaPodsTester' do
pod 'Protobuf', :path => '../../../..'
end
...@@ -3,9 +3,7 @@ platform :ios, '8.0' ...@@ -3,9 +3,7 @@ platform :ios, '8.0'
install! 'cocoapods', :deterministic_uuids => false install! 'cocoapods', :deterministic_uuids => false
if ENV['USE_FRAMEWORKS'] == 'YES' then use_frameworks!
use_frameworks!
end
target 'iOSCocoaPodsTester' do target 'iOSCocoaPodsTester' do
pod 'Protobuf', :path => '../../../..' pod 'Protobuf', :path => '../../../..'
......
source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '8.0'
install! 'cocoapods', :deterministic_uuids => false
target 'iOSCocoaPodsTester' do
pod 'Protobuf', :path => '../../../..'
end
...@@ -31,7 +31,7 @@ OPTIONS: ...@@ -31,7 +31,7 @@ OPTIONS:
EOF EOF
} }
TEST_MODES=( "yes" "no" ) TEST_MODES=( "static" "framework" )
TEST_NAMES=( "iOSCocoaPodsTester" "OSXCocoaPodsTester" ) TEST_NAMES=( "iOSCocoaPodsTester" "OSXCocoaPodsTester" )
while [[ $# != 0 ]]; do while [[ $# != 0 ]]; do
case "${1}" in case "${1}" in
...@@ -40,10 +40,10 @@ while [[ $# != 0 ]]; do ...@@ -40,10 +40,10 @@ while [[ $# != 0 ]]; do
exit 0 exit 0
;; ;;
--skip-static ) --skip-static )
TEST_MODES=(${TEST_MODES[@]/no}) TEST_MODES=(${TEST_MODES[@]/static})
;; ;;
--skip-framework ) --skip-framework )
TEST_MODES=(${TEST_MODES[@]/yes}) TEST_MODES=(${TEST_MODES[@]/framework})
;; ;;
--skip-ios ) --skip-ios )
TEST_NAMES=(${TEST_NAMES[@]/iOSCocoaPodsTester}) TEST_NAMES=(${TEST_NAMES[@]/iOSCocoaPodsTester})
...@@ -93,24 +93,34 @@ cleanup() { ...@@ -93,24 +93,34 @@ cleanup() {
# incase something does hiccup. # incase something does hiccup.
xcodebuild -workspace "${TEST_NAME}.xcworkspace" -scheme "${TEST_NAME}" clean > /dev/null || true xcodebuild -workspace "${TEST_NAME}.xcworkspace" -scheme "${TEST_NAME}" clean > /dev/null || true
pod deintegrate > /dev/null || true pod deintegrate > /dev/null || true
# Delete the files left after pod deintegrate # Flush the cache so nothing is left behind.
pod cache clean --all || true
# Delete the files left after pod deintegrate.
rm -f Podfile.lock || true rm -f Podfile.lock || true
rm -rf "${TEST_NAME}.xcworkspace" || true rm -rf "${TEST_NAME}.xcworkspace" || true
git checkout -- "${TEST_NAME}.xcodeproj" || true git checkout -- "${TEST_NAME}.xcodeproj" || true
# Remove the Podfile that was put in place.
rm -f Podfile || true
} }
do_test() { do_test() {
local TEST_NAME="$1" local TEST_NAME="$1"
local USE_FRAMEWORKS_VALUE="$2" local TEST_MODE="$2"
header "${TEST_NAME}" - USE_FRAMEWORKS: "${USE_FRAMEWORKS_VALUE}" header "${TEST_NAME}" - Mode: "${TEST_MODE}"
cd "${ScriptDir}/${TEST_NAME}" cd "${ScriptDir}/${TEST_NAME}"
# Hook in cleanup for any failures. # Hook in cleanup for any failures.
trap "cleanup ${TEST_NAME}" EXIT trap "cleanup ${TEST_NAME}" EXIT
# Invoke pod and then xcodebuild, but catch the results so we can cleanup. # Ensure nothing is cached by pods to start with that could throw things off.
USE_FRAMEWORKS="${USE_FRAMEWORKS_VALUE}" pod install pod cache clean --all
# Put the right Podfile in place.
cp -f "Podfile-${TEST_MODE}" "Podfile"
# Do the work!
pod install --verbose
xcodebuild -workspace "${TEST_NAME}.xcworkspace" -scheme "${TEST_NAME}" build xcodebuild -workspace "${TEST_NAME}.xcworkspace" -scheme "${TEST_NAME}" build
# Clear the hook and manually run cleanup. # Clear the hook and manually run cleanup.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment