calabash-android 0.8.4 → 0.9.0.pre1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/features-skeleton/support/app_installation_hooks.rb +2 -3
- data/lib/calabash-android/dependencies.rb +6 -6
- data/lib/calabash-android/helpers.rb +12 -3
- data/lib/calabash-android/java_keystore.rb +1 -1
- data/lib/calabash-android/lib/TestServer.apk +0 -0
- data/lib/calabash-android/operations.rb +50 -3
- data/lib/calabash-android/version.rb +1 -1
- data/lib/calabash-android/wait_helpers.rb +5 -5
- metadata +4 -4
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA1:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: edc88bc8eeb9c7dc9dea37c99103d2071e70b67b
         | 
| 4 | 
            +
              data.tar.gz: 7101653b3282165fe7ff093af7bf9a3ecbfb4525
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 72acb203da0cb7a76a5bc03f23378b1849588bc10bc92dfe2403b231e9989ecf1fc18f11def1c6d3a090d6406ef01b9a4320388f600fdeed617da12f1babc3aa
         | 
| 7 | 
            +
              data.tar.gz: f80bf8ce279a0bfed373d5ed89e21cd5bd24e49510099085ca145f2554c71ab4340e83f60bc6df691f8f55241143a2403830d81f64690bc70c2caf7a8cdc3da8
         | 
| @@ -15,9 +15,8 @@ Before do |scenario| | |
| 15 15 | 
             
                  log 'First scenario in feature - reinstalling apps'
         | 
| 16 16 | 
             
                end
         | 
| 17 17 |  | 
| 18 | 
            -
                 | 
| 19 | 
            -
                 | 
| 20 | 
            -
                install_app(ENV['APP_PATH'])
         | 
| 18 | 
            +
                ensure_app_installed
         | 
| 19 | 
            +
                clear_app_data
         | 
| 21 20 | 
             
                FeatureMemory.feature = feature
         | 
| 22 21 | 
             
                FeatureMemory.invocation = 1
         | 
| 23 22 | 
             
              else
         | 
| @@ -391,17 +391,17 @@ module Calabash | |
| 391 391 | 
             
                                end
         | 
| 392 392 | 
             
                            end
         | 
| 393 393 |  | 
| 394 | 
            -
                            if File.exist?('~/Library/Developer/Xamarin/android-sdk-mac_x86/')
         | 
| 395 | 
            -
                                return '~/Library/Developer/Xamarin/android-sdk-mac_x86/'
         | 
| 394 | 
            +
                            if File.exist?(File.expand_path('~/Library/Developer/Xamarin/android-sdk-mac_x86/'))
         | 
| 395 | 
            +
                                return File.expand_path('~/Library/Developer/Xamarin/android-sdk-mac_x86/')
         | 
| 396 396 | 
             
                            end
         | 
| 397 397 |  | 
| 398 | 
            -
                            if File.exist?('~/Library/Developer/Xamarin/android-sdk-macosx/')
         | 
| 399 | 
            -
                                return '~/Library/Developer/Xamarin/android-sdk-macosx/'
         | 
| 398 | 
            +
                            if File.exist?(File.expand_path('~/Library/Developer/Xamarin/android-sdk-macosx/'))
         | 
| 399 | 
            +
                                return File.expand_path('~/Library/Developer/Xamarin/android-sdk-macosx/')
         | 
| 400 400 | 
             
                            end
         | 
| 401 401 |  | 
| 402 402 | 
             
                            # Default location when installing with Android Studio
         | 
| 403 | 
            -
                            if File.exist?('~/Library/Android/sdk/')
         | 
| 404 | 
            -
                                return '~/Library/Android/sdk/'
         | 
| 403 | 
            +
                            if File.exist?(File.expand_path('~/Library/Android/sdk/'))
         | 
| 404 | 
            +
                                return File.expand_path('~/Library/Android/sdk/')
         | 
| 405 405 | 
             
                            end
         | 
| 406 406 |  | 
| 407 407 | 
             
                            if File.exist?('C:\\Android\\android-sdk')
         | 
| @@ -8,6 +8,7 @@ require 'calabash-android/environment' | |
| 8 8 | 
             
            require 'calabash-android/logging'
         | 
| 9 9 | 
             
            require 'calabash-android/dependencies'
         | 
| 10 10 | 
             
            require 'calabash-android/version'
         | 
| 11 | 
            +
            require 'calabash-android/utils'
         | 
| 11 12 |  | 
| 12 13 | 
             
            def package_name(app)
         | 
| 13 14 | 
             
              unless File.exist?(app)
         | 
| @@ -190,8 +191,8 @@ def fingerprint_from_apk(app_path) | |
| 190 191 | 
             
                  cmd = "\"#{Calabash::Android::Dependencies.keytool_path}\" -v -printcert -J\"-Dfile.encoding=utf-8\" -file \"#{signature_files.first}\""
         | 
| 191 192 | 
             
                  log cmd
         | 
| 192 193 | 
             
                  fingerprints = `#{cmd}`
         | 
| 193 | 
            -
                  md5_fingerprint =  | 
| 194 | 
            -
                  log " | 
| 194 | 
            +
                  md5_fingerprint = extract_sha1_fingerprint(fingerprints)
         | 
| 195 | 
            +
                  log "SHA1 fingerprint for signing cert (#{app_path}): #{md5_fingerprint}"
         | 
| 195 196 | 
             
                  md5_fingerprint
         | 
| 196 197 | 
             
                end
         | 
| 197 198 | 
             
              end
         | 
| @@ -203,6 +204,12 @@ def extract_md5_fingerprint(fingerprints) | |
| 203 204 | 
             
              m.first
         | 
| 204 205 | 
             
            end
         | 
| 205 206 |  | 
| 207 | 
            +
            def extract_sha1_fingerprint(fingerprints)
         | 
| 208 | 
            +
              m = fingerprints.scan(/SHA1.*((?:[a-fA-F\d]{2}:){15}[a-fA-F\d]{2})/).flatten
         | 
| 209 | 
            +
              raise "No SHA1 fingerprint found:\n #{fingerprints}" if m.empty?
         | 
| 210 | 
            +
              m.first
         | 
| 211 | 
            +
            end
         | 
| 212 | 
            +
             | 
| 206 213 | 
             
            def extract_signature_algorithm_name(fingerprints)
         | 
| 207 214 | 
             
              m = fingerprints.scan(/Signature algorithm name: (.*)/).flatten
         | 
| 208 215 | 
             
              raise "No signature algorithm names found:\n #{fingerprints}" if m.empty?
         | 
| @@ -210,5 +217,7 @@ def extract_signature_algorithm_name(fingerprints) | |
| 210 217 | 
             
            end
         | 
| 211 218 |  | 
| 212 219 | 
             
            def log(message, error = false)
         | 
| 213 | 
            -
               | 
| 220 | 
            +
              if error or ARGV.include? "-v" or ARGV.include? "--verbose" or ENV["DEBUG"] == "1"
         | 
| 221 | 
            +
                $stdout.puts "#{Time.now.strftime("%Y-%m-%d %H:%M:%S")} - #{message}"
         | 
| 222 | 
            +
              end
         | 
| 214 223 | 
             
            end
         | 
| @@ -38,7 +38,7 @@ class JavaKeystore | |
| 38 38 | 
             
                @password = password
         | 
| 39 39 | 
             
                log "Key store data:"
         | 
| 40 40 | 
             
                log keystore_data
         | 
| 41 | 
            -
                @fingerprint =  | 
| 41 | 
            +
                @fingerprint = extract_sha1_fingerprint(keystore_data)
         | 
| 42 42 | 
             
                @signature_algorithm_name = extract_signature_algorithm_name(keystore_data)
         | 
| 43 43 | 
             
                log "Fingerprint: #{fingerprint}"
         | 
| 44 44 | 
             
                log "Signature algorithm name: #{signature_algorithm_name}"
         | 
| Binary file | 
| @@ -26,6 +26,7 @@ require 'cucumber' | |
| 26 26 | 
             
            require 'date'
         | 
| 27 27 | 
             
            require 'time'
         | 
| 28 28 | 
             
            require 'shellwords'
         | 
| 29 | 
            +
            require 'digest'
         | 
| 29 30 |  | 
| 30 31 | 
             
            Calabash::Android::Dependencies.setup
         | 
| 31 32 |  | 
| @@ -54,7 +55,7 @@ module Calabash module Android | |
| 54 55 | 
             
                end
         | 
| 55 56 |  | 
| 56 57 | 
             
                def log(message)
         | 
| 57 | 
            -
                  $stdout.puts "#{Time.now.strftime("%Y-%m-%d %H:%M:%S")} - #{message}" if (ARGV.include? "-v" or ARGV.include? "--verbose")
         | 
| 58 | 
            +
                  $stdout.puts "#{Time.now.strftime("%Y-%m-%d %H:%M:%S")} - #{message}" if (ARGV.include? "-v" or ARGV.include? "--verbose" or ENV["DEBUG"] == "1")
         | 
| 58 59 | 
             
                end
         | 
| 59 60 |  | 
| 60 61 | 
             
                def macro(txt)
         | 
| @@ -106,6 +107,14 @@ module Calabash module Android | |
| 106 107 | 
             
                  default_device.reinstall_apps
         | 
| 107 108 | 
             
                end
         | 
| 108 109 |  | 
| 110 | 
            +
                # Ensures that the application and the test-server are installed.
         | 
| 111 | 
            +
                #
         | 
| 112 | 
            +
                # If the application has already been installed, it does nothing.
         | 
| 113 | 
            +
                # If the test-server has already been installed, it does nothing.
         | 
| 114 | 
            +
                def ensure_app_installed
         | 
| 115 | 
            +
                  default_device.ensure_apps_installed
         | 
| 116 | 
            +
                end
         | 
| 117 | 
            +
             | 
| 109 118 | 
             
                def reinstall_test_server
         | 
| 110 119 | 
             
                  default_device.reinstall_test_server
         | 
| 111 120 | 
             
                end
         | 
| @@ -333,6 +342,24 @@ module Calabash module Android | |
| 333 342 | 
             
                    install_app(@test_server_path)
         | 
| 334 343 | 
             
                  end
         | 
| 335 344 |  | 
| 345 | 
            +
                  @@installed_apps ||= {}
         | 
| 346 | 
            +
             | 
| 347 | 
            +
                  def ensure_apps_installed
         | 
| 348 | 
            +
                    apps = [@app_path, @test_server_path]
         | 
| 349 | 
            +
             | 
| 350 | 
            +
                    apps.each do |app|
         | 
| 351 | 
            +
                      package = package_name(app)
         | 
| 352 | 
            +
                      md5 = Digest::MD5.file(File.expand_path(app))
         | 
| 353 | 
            +
             | 
| 354 | 
            +
                      if !application_installed?(package) || (!@@installed_apps.keys.include?(package) || @@installed_apps[package] != md5)
         | 
| 355 | 
            +
                        log "MD5 checksum for app '#{app}' (#{package}): #{md5}"
         | 
| 356 | 
            +
                        uninstall_app(package)
         | 
| 357 | 
            +
                        install_app(app)
         | 
| 358 | 
            +
                        @@installed_apps[package] = md5
         | 
| 359 | 
            +
                      end
         | 
| 360 | 
            +
                    end
         | 
| 361 | 
            +
                  end
         | 
| 362 | 
            +
             | 
| 336 363 | 
             
                  def install_app(app_path)
         | 
| 337 364 | 
             
                    if _sdk_version >= 23
         | 
| 338 365 | 
             
                      cmd = "#{adb_command} install -g \"#{app_path}\""
         | 
| @@ -384,7 +411,7 @@ module Calabash module Android | |
| 384 411 | 
             
                    log "Uninstalling: #{package_name}"
         | 
| 385 412 | 
             
                    log `#{adb_command} uninstall #{package_name}`
         | 
| 386 413 |  | 
| 387 | 
            -
                    succeeded = ! | 
| 414 | 
            +
                    succeeded = !application_installed?(package_name)
         | 
| 388 415 |  | 
| 389 416 | 
             
                    unless succeeded
         | 
| 390 417 | 
             
                      ::Cucumber.wants_to_quit = true
         | 
| @@ -392,6 +419,10 @@ module Calabash module Android | |
| 392 419 | 
             
                    end
         | 
| 393 420 | 
             
                  end
         | 
| 394 421 |  | 
| 422 | 
            +
                  def application_installed?(package_name)
         | 
| 423 | 
            +
                    (`#{adb_command} shell pm list packages`.lines.map{|line| line.chomp.sub("package:", "")}.include?(package_name))
         | 
| 424 | 
            +
                  end
         | 
| 425 | 
            +
             | 
| 395 426 | 
             
                  def app_running?
         | 
| 396 427 | 
             
                    begin
         | 
| 397 428 | 
             
                      http("/ping") == "pong"
         | 
| @@ -625,6 +656,9 @@ module Calabash module Android | |
| 625 656 | 
             
                  end
         | 
| 626 657 |  | 
| 627 658 | 
             
                  def connected_devices
         | 
| 659 | 
            +
                    # Run empty ADB command to remove eventual first-run messages
         | 
| 660 | 
            +
                    `"#{Calabash::Android::Dependencies.adb_path}" devices`
         | 
| 661 | 
            +
             | 
| 628 662 | 
             
                    lines = `"#{Calabash::Android::Dependencies.adb_path}" devices`.split("\n")
         | 
| 629 663 | 
             
                    start_index = lines.index{ |x| x =~ /List of devices attached/ } + 1
         | 
| 630 664 | 
             
                    lines[start_index..-1].collect { |l| l.split("\t").first }
         | 
| @@ -642,8 +676,21 @@ module Calabash module Android | |
| 642 676 | 
             
                  end
         | 
| 643 677 |  | 
| 644 678 | 
             
                  def clear_app_data
         | 
| 645 | 
            -
                     | 
| 679 | 
            +
                    unless application_installed?(package_name(@app_path))
         | 
| 680 | 
            +
                      raise "Cannot clear data, application #{package_name(@app_path)} is not installed"
         | 
| 681 | 
            +
                    end
         | 
| 682 | 
            +
             | 
| 683 | 
            +
                    unless application_installed?(package_name(@test_server_path))
         | 
| 684 | 
            +
                      raise "Cannot clear data, test-server #{package_name(@test_server_path)} is not installed"
         | 
| 685 | 
            +
                    end
         | 
| 686 | 
            +
             | 
| 687 | 
            +
                    cmd = "#{adb_command} shell am instrument #{package_name(@test_server_path)}/sh.calaba.instrumentationbackend.ClearAppData2"
         | 
| 646 688 | 
             
                    raise "Could not clear data" unless system(cmd)
         | 
| 689 | 
            +
             | 
| 690 | 
            +
                    # Wait for the cleanup activity to finish. This is a hard sleep for now
         | 
| 691 | 
            +
                    sleep 2
         | 
| 692 | 
            +
             | 
| 693 | 
            +
                    true
         | 
| 647 694 | 
             
                  end
         | 
| 648 695 |  | 
| 649 696 | 
             
                  def pull(remote, local)
         | 
| @@ -18,12 +18,12 @@ module Calabash | |
| 18 18 |  | 
| 19 19 | 
             
                  def wait_for(options_or_timeout=DEFAULT_OPTS, &block)
         | 
| 20 20 | 
             
                    #note Hash is preferred, number acceptable for backwards compat
         | 
| 21 | 
            -
                    default_timeout = 30
         | 
| 22 21 | 
             
                    timeout = options_or_timeout || default_timeout
         | 
| 23 | 
            -
                     | 
| 24 | 
            -
                     | 
| 25 | 
            -
                     | 
| 26 | 
            -
                     | 
| 22 | 
            +
                    default_timeout = DEFAULT_OPTS[:timeout]
         | 
| 23 | 
            +
                    post_timeout = DEFAULT_OPTS[:post_timeout]
         | 
| 24 | 
            +
                    retry_frequency = DEFAULT_OPTS[:retry_frequency]
         | 
| 25 | 
            +
                    timeout_message = DEFAULT_OPTS[:timeout_message]
         | 
| 26 | 
            +
                    screenshot_on_error = DEFAULT_OPTS[:screenshot_on_error]
         | 
| 27 27 |  | 
| 28 28 | 
             
                    if options_or_timeout.is_a?(Hash)
         | 
| 29 29 | 
             
                      timeout = options_or_timeout[:timeout] || default_timeout
         | 
    
        metadata
    CHANGED
    
    | @@ -1,14 +1,14 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: calabash-android
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 0. | 
| 4 | 
            +
              version: 0.9.0.pre1
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Jonas Maturana Larsen
         | 
| 8 8 | 
             
            autorequire: 
         | 
| 9 9 | 
             
            bindir: bin
         | 
| 10 10 | 
             
            cert_chain: []
         | 
| 11 | 
            -
            date:  | 
| 11 | 
            +
            date: 2017-02-08 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies:
         | 
| 13 13 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 14 14 | 
             
              name: cucumber
         | 
| @@ -385,9 +385,9 @@ required_ruby_version: !ruby/object:Gem::Requirement | |
| 385 385 | 
             
                  version: '0'
         | 
| 386 386 | 
             
            required_rubygems_version: !ruby/object:Gem::Requirement
         | 
| 387 387 | 
             
              requirements:
         | 
| 388 | 
            -
              - - " | 
| 388 | 
            +
              - - ">"
         | 
| 389 389 | 
             
                - !ruby/object:Gem::Version
         | 
| 390 | 
            -
                  version:  | 
| 390 | 
            +
                  version: 1.3.1
         | 
| 391 391 | 
             
            requirements: []
         | 
| 392 392 | 
             
            rubyforge_project: 
         | 
| 393 393 | 
             
            rubygems_version: 2.5.1
         |