appium_lib_core 4.1.0 → 5.2.0
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/CHANGELOG.md +129 -275
- data/README.md +12 -7
- data/Rakefile +4 -0
- data/appium_lib_core.gemspec +5 -8
- data/bin/console +0 -4
- data/lib/appium_lib_core/android/device/auth_finger_print.rb +2 -1
- data/lib/appium_lib_core/android/device.rb +4 -4
- data/lib/appium_lib_core/common/base/bridge.rb +291 -90
- data/lib/appium_lib_core/common/base/capabilities.rb +10 -3
- data/lib/appium_lib_core/common/base/device_ime.rb +49 -0
- data/lib/appium_lib_core/common/base/driver.rb +223 -184
- data/lib/appium_lib_core/common/base/driver_settings.rb +51 -0
- data/lib/appium_lib_core/common/base/has_location.rb +80 -0
- data/lib/appium_lib_core/common/base/has_network_connection.rb +56 -0
- data/lib/appium_lib_core/common/base/http_default.rb +1 -3
- data/lib/appium_lib_core/common/base/remote_status.rb +31 -0
- data/lib/appium_lib_core/common/base/rotable.rb +54 -0
- data/lib/appium_lib_core/common/base/screenshot.rb +6 -6
- data/lib/appium_lib_core/common/base/search_context.rb +19 -4
- data/lib/appium_lib_core/common/base.rb +1 -3
- data/lib/appium_lib_core/common/command.rb +255 -4
- data/lib/appium_lib_core/common/device/app_management.rb +2 -14
- data/lib/appium_lib_core/common/device/image_comparison.rb +12 -4
- data/lib/appium_lib_core/common/device/keyevent.rb +4 -4
- data/lib/appium_lib_core/common/{command/mjsonwp.rb → device/orientation.rb} +14 -11
- data/lib/appium_lib_core/common/device/touch_actions.rb +2 -0
- data/lib/appium_lib_core/common/device/value.rb +6 -6
- data/lib/appium_lib_core/common/error.rb +4 -1
- data/lib/appium_lib_core/common/log.rb +4 -1
- data/lib/appium_lib_core/common/touch_action/multi_touch.rb +19 -0
- data/lib/appium_lib_core/common/touch_action/touch_actions.rb +16 -2
- data/lib/appium_lib_core/common/wait.rb +38 -6
- data/lib/appium_lib_core/device.rb +1 -5
- data/lib/appium_lib_core/driver.rb +42 -50
- data/lib/appium_lib_core/{patch.rb → element.rb} +66 -9
- data/lib/appium_lib_core/ios/uiautomation/patch.rb +1 -1
- data/lib/appium_lib_core/{common/base/command.rb → mac2/bridge.rb} +9 -8
- data/lib/appium_lib_core/mac2/device/screen.rb +48 -0
- data/lib/appium_lib_core/mac2/device.rb +92 -0
- data/lib/appium_lib_core/mac2.rb +17 -0
- data/lib/appium_lib_core/version.rb +2 -2
- data/lib/appium_lib_core.rb +2 -5
- metadata +25 -84
- data/.github/ISSUE_TEMPLATE/issue-report.md +0 -29
- data/.github/contributing.md +0 -26
- data/.github/issue_template.md +0 -20
- data/.github/workflows/unittest.yml +0 -68
- data/.gitignore +0 -18
- data/.rubocop.yml +0 -58
- data/azure-pipelines.yml +0 -15
- data/ci-jobs/functional/android_setup.yml +0 -3
- data/ci-jobs/functional/ios_setup.yml +0 -7
- data/ci-jobs/functional/publish_test_result.yml +0 -18
- data/ci-jobs/functional/run_appium.yml +0 -25
- data/ci-jobs/functional/start-emulator.sh +0 -26
- data/ci-jobs/functional_test.yml +0 -298
- data/docs/mobile_command.md +0 -34
- data/lib/appium_lib_core/common/base/bridge/mjsonwp.rb +0 -81
- data/lib/appium_lib_core/common/base/bridge/w3c.rb +0 -252
- data/lib/appium_lib_core/common/command/common.rb +0 -110
- data/lib/appium_lib_core/common/command/w3c.rb +0 -56
- data/release_notes.md +0 -816
- data/script/commands.rb +0 -200
| @@ -0,0 +1,51 @@ | |
| 1 | 
            +
            # frozen_string_literal: true
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            # Licensed under the Apache License, Version 2.0 (the "License");
         | 
| 4 | 
            +
            # you may not use this file except in compliance with the License.
         | 
| 5 | 
            +
            # You may obtain a copy of the License at
         | 
| 6 | 
            +
            #
         | 
| 7 | 
            +
            #     http://www.apache.org/licenses/LICENSE-2.0
         | 
| 8 | 
            +
            #
         | 
| 9 | 
            +
            # Unless required by applicable law or agreed to in writing, software
         | 
| 10 | 
            +
            # distributed under the License is distributed on an "AS IS" BASIS,
         | 
| 11 | 
            +
            # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
         | 
| 12 | 
            +
            # See the License for the specific language governing permissions and
         | 
| 13 | 
            +
            # limitations under the License.
         | 
| 14 | 
            +
             | 
| 15 | 
            +
            module Appium
         | 
| 16 | 
            +
              module Core
         | 
| 17 | 
            +
                class Base
         | 
| 18 | 
            +
                  #
         | 
| 19 | 
            +
                  # @api private
         | 
| 20 | 
            +
                  #
         | 
| 21 | 
            +
                  class DriverSettings
         | 
| 22 | 
            +
                    # @private this class is private
         | 
| 23 | 
            +
                    def initialize(bridge)
         | 
| 24 | 
            +
                      @bridge = bridge
         | 
| 25 | 
            +
                    end
         | 
| 26 | 
            +
             | 
| 27 | 
            +
                    # Get appium Settings for current test session.
         | 
| 28 | 
            +
                    #
         | 
| 29 | 
            +
                    # @example
         | 
| 30 | 
            +
                    #
         | 
| 31 | 
            +
                    #   @driver.settings.get
         | 
| 32 | 
            +
                    #
         | 
| 33 | 
            +
                    def get
         | 
| 34 | 
            +
                      @bridge.get_settings
         | 
| 35 | 
            +
                    end
         | 
| 36 | 
            +
             | 
| 37 | 
            +
                    # Update Appium Settings for current test session
         | 
| 38 | 
            +
                    #
         | 
| 39 | 
            +
                    # @param [Hash] settings Settings to update, keys are settings, values to value to set each setting to
         | 
| 40 | 
            +
                    #
         | 
| 41 | 
            +
                    # @example
         | 
| 42 | 
            +
                    #
         | 
| 43 | 
            +
                    #   @driver.settings.update({'allowInvisibleElements': true})
         | 
| 44 | 
            +
                    #
         | 
| 45 | 
            +
                    def update(settings)
         | 
| 46 | 
            +
                      @bridge.update_settings(settings)
         | 
| 47 | 
            +
                    end
         | 
| 48 | 
            +
                  end
         | 
| 49 | 
            +
                end
         | 
| 50 | 
            +
              end
         | 
| 51 | 
            +
            end
         | 
| @@ -0,0 +1,80 @@ | |
| 1 | 
            +
            # frozen_string_literal: true
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            # Licensed under the Apache License, Version 2.0 (the "License");
         | 
| 4 | 
            +
            # you may not use this file except in compliance with the License.
         | 
| 5 | 
            +
            # You may obtain a copy of the License at
         | 
| 6 | 
            +
            #
         | 
| 7 | 
            +
            #     http://www.apache.org/licenses/LICENSE-2.0
         | 
| 8 | 
            +
            #
         | 
| 9 | 
            +
            # Unless required by applicable law or agreed to in writing, software
         | 
| 10 | 
            +
            # distributed under the License is distributed on an "AS IS" BASIS,
         | 
| 11 | 
            +
            # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
         | 
| 12 | 
            +
            # See the License for the specific language governing permissions and
         | 
| 13 | 
            +
            # limitations under the License.
         | 
| 14 | 
            +
             | 
| 15 | 
            +
            module Appium
         | 
| 16 | 
            +
              module Core
         | 
| 17 | 
            +
                class Base
         | 
| 18 | 
            +
                  #
         | 
| 19 | 
            +
                  # @api private
         | 
| 20 | 
            +
                  #
         | 
| 21 | 
            +
                  module HasLocation
         | 
| 22 | 
            +
                    # Get the location of the device.
         | 
| 23 | 
            +
                    #
         | 
| 24 | 
            +
                    # @return [::Selenium::WebDriver::Location]
         | 
| 25 | 
            +
                    #
         | 
| 26 | 
            +
                    # @example
         | 
| 27 | 
            +
                    #
         | 
| 28 | 
            +
                    #   driver.location #=> ::Selenium::WebDriver::Location.new(10, 10, 10)
         | 
| 29 | 
            +
                    #
         | 
| 30 | 
            +
                    def location
         | 
| 31 | 
            +
                      @bridge.location
         | 
| 32 | 
            +
                    end
         | 
| 33 | 
            +
             | 
| 34 | 
            +
                    # Set the location of the device.
         | 
| 35 | 
            +
                    #
         | 
| 36 | 
            +
                    # @param [::Selenium::WebDriver::Location] location Set the location.
         | 
| 37 | 
            +
                    #
         | 
| 38 | 
            +
                    # @example
         | 
| 39 | 
            +
                    #
         | 
| 40 | 
            +
                    #   driver.location = ::Selenium::WebDriver::Location.new(10, 10, 10)
         | 
| 41 | 
            +
                    #
         | 
| 42 | 
            +
                    def location=(location)
         | 
| 43 | 
            +
                      unless location.is_a?(::Selenium::WebDriver::Location)
         | 
| 44 | 
            +
                        raise TypeError, "expected #{::Selenium::WebDriver::Location}, got #{location.inspect}:#{location.class}"
         | 
| 45 | 
            +
                      end
         | 
| 46 | 
            +
             | 
| 47 | 
            +
                      @bridge.set_location location.latitude, location.longitude, location.altitude
         | 
| 48 | 
            +
                    end
         | 
| 49 | 
            +
             | 
| 50 | 
            +
                    # Set the location of the device.
         | 
| 51 | 
            +
                    #
         | 
| 52 | 
            +
                    # @param [String, Number] latitude Set the latitude.
         | 
| 53 | 
            +
                    # @param [String, Number] longitude Set the longitude.
         | 
| 54 | 
            +
                    # @param [String, Number] altitude Set the altitude.
         | 
| 55 | 
            +
                    # @param [String, Number] speed Set the speed to apply the location on Android real devices
         | 
| 56 | 
            +
                    #                               in meters/second @since Appium 1.21.0 and in knots for emulators @since Appium 1.22.0.
         | 
| 57 | 
            +
                    # @param [String, Number] satellites Sets the count of geo satellites being tracked in range 1..12 @since Appium 1.22.0.
         | 
| 58 | 
            +
                    #                                    This number is respected on Emulators.
         | 
| 59 | 
            +
                    # @param [::Selenium::WebDriver::Location]
         | 
| 60 | 
            +
                    #
         | 
| 61 | 
            +
                    # @example
         | 
| 62 | 
            +
                    #
         | 
| 63 | 
            +
                    #   driver.location = ::Selenium::WebDriver::Location.new(10, 10, 10)
         | 
| 64 | 
            +
                    #
         | 
| 65 | 
            +
                    def set_location(latitude, longitude, altitude, speed: nil, satellites: nil)
         | 
| 66 | 
            +
                      if speed.nil? && satellites.nil?
         | 
| 67 | 
            +
                        self.location = ::Selenium::WebDriver::Location.new(Float(latitude), Float(longitude), Float(altitude))
         | 
| 68 | 
            +
                      else
         | 
| 69 | 
            +
                        loc = ::Selenium::WebDriver::Location.new(Float(latitude), Float(longitude), Float(altitude))
         | 
| 70 | 
            +
             | 
| 71 | 
            +
                        speed = Float(speed) unless speed.nil?
         | 
| 72 | 
            +
                        satellites = Integer(satellites) unless satellites.nil?
         | 
| 73 | 
            +
             | 
| 74 | 
            +
                        @bridge.set_location loc.latitude, loc.longitude, loc.altitude, speed: speed, satellites: satellites
         | 
| 75 | 
            +
                      end
         | 
| 76 | 
            +
                    end
         | 
| 77 | 
            +
                  end
         | 
| 78 | 
            +
                end
         | 
| 79 | 
            +
              end
         | 
| 80 | 
            +
            end
         | 
| @@ -0,0 +1,56 @@ | |
| 1 | 
            +
            # frozen_string_literal: true
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            # Licensed under the Apache License, Version 2.0 (the "License");
         | 
| 4 | 
            +
            # you may not use this file except in compliance with the License.
         | 
| 5 | 
            +
            # You may obtain a copy of the License at
         | 
| 6 | 
            +
            #
         | 
| 7 | 
            +
            #     http://www.apache.org/licenses/LICENSE-2.0
         | 
| 8 | 
            +
            #
         | 
| 9 | 
            +
            # Unless required by applicable law or agreed to in writing, software
         | 
| 10 | 
            +
            # distributed under the License is distributed on an "AS IS" BASIS,
         | 
| 11 | 
            +
            # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
         | 
| 12 | 
            +
            # See the License for the specific language governing permissions and
         | 
| 13 | 
            +
            # limitations under the License.
         | 
| 14 | 
            +
             | 
| 15 | 
            +
            module Appium
         | 
| 16 | 
            +
              module Core
         | 
| 17 | 
            +
                class Base
         | 
| 18 | 
            +
                  #
         | 
| 19 | 
            +
                  # @api private
         | 
| 20 | 
            +
                  #
         | 
| 21 | 
            +
                  module HasNetworkConnection
         | 
| 22 | 
            +
                    def network_connection_type
         | 
| 23 | 
            +
                      connection_value = @bridge.network_connection
         | 
| 24 | 
            +
             | 
| 25 | 
            +
                      connection_type = values_to_type[connection_value]
         | 
| 26 | 
            +
             | 
| 27 | 
            +
                      # In case the connection type is not recognized return the
         | 
| 28 | 
            +
                      # connection value.
         | 
| 29 | 
            +
                      connection_type || connection_value
         | 
| 30 | 
            +
                    end
         | 
| 31 | 
            +
             | 
| 32 | 
            +
                    def network_connection_type=(connection_type)
         | 
| 33 | 
            +
                      raise ::Appium::Core::Error::ArgumentError, 'Invalid connection type' unless valid_type? connection_type
         | 
| 34 | 
            +
             | 
| 35 | 
            +
                      connection_value = type_to_values[connection_type]
         | 
| 36 | 
            +
             | 
| 37 | 
            +
                      @bridge.network_connection = connection_value
         | 
| 38 | 
            +
                    end
         | 
| 39 | 
            +
             | 
| 40 | 
            +
                    private
         | 
| 41 | 
            +
             | 
| 42 | 
            +
                    def type_to_values
         | 
| 43 | 
            +
                      { airplane_mode: 1, wifi: 2, data: 4, all: 6, none: 0 }
         | 
| 44 | 
            +
                    end
         | 
| 45 | 
            +
             | 
| 46 | 
            +
                    def values_to_type
         | 
| 47 | 
            +
                      type_to_values.invert
         | 
| 48 | 
            +
                    end
         | 
| 49 | 
            +
             | 
| 50 | 
            +
                    def valid_type?(type)
         | 
| 51 | 
            +
                      type_to_values.keys.include? type
         | 
| 52 | 
            +
                    end
         | 
| 53 | 
            +
                  end
         | 
| 54 | 
            +
                end
         | 
| 55 | 
            +
              end
         | 
| 56 | 
            +
            end
         | 
| @@ -55,8 +55,6 @@ module Appium | |
| 55 55 | 
             
                      def update_sending_request_to(scheme:, host:, port:, path:)
         | 
| 56 56 | 
             
                        return @server_url unless validate_url_param(scheme, host, port, path)
         | 
| 57 57 |  | 
| 58 | 
            -
                        ::Appium::Logger.debug("[experimental] This feature, #{__method__}, is an experimental")
         | 
| 59 | 
            -
             | 
| 60 58 | 
             
                        # Add / if 'path' does not have it
         | 
| 61 59 | 
             
                        path = path.start_with?('/') ? path : "/#{path}"
         | 
| 62 60 | 
             
                        path = path.end_with?('/') ? path : "#{path}/"
         | 
| @@ -71,7 +69,7 @@ module Appium | |
| 71 69 | 
             
                        return true unless [scheme, host, port, path].include?(nil)
         | 
| 72 70 |  | 
| 73 71 | 
             
                        message = "Given parameters are scheme: '#{scheme}', host: '#{host}', port: '#{port}', path: '#{path}'"
         | 
| 74 | 
            -
                        ::Appium::Logger. | 
| 72 | 
            +
                        ::Appium::Logger.debug(message)
         | 
| 75 73 | 
             
                        false
         | 
| 76 74 | 
             
                      end
         | 
| 77 75 |  | 
| @@ -0,0 +1,31 @@ | |
| 1 | 
            +
            # frozen_string_literal: true
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            # Licensed under the Apache License, Version 2.0 (the "License");
         | 
| 4 | 
            +
            # you may not use this file except in compliance with the License.
         | 
| 5 | 
            +
            # You may obtain a copy of the License at
         | 
| 6 | 
            +
            #
         | 
| 7 | 
            +
            #     http://www.apache.org/licenses/LICENSE-2.0
         | 
| 8 | 
            +
            #
         | 
| 9 | 
            +
            # Unless required by applicable law or agreed to in writing, software
         | 
| 10 | 
            +
            # distributed under the License is distributed on an "AS IS" BASIS,
         | 
| 11 | 
            +
            # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
         | 
| 12 | 
            +
            # See the License for the specific language governing permissions and
         | 
| 13 | 
            +
            # limitations under the License.
         | 
| 14 | 
            +
             | 
| 15 | 
            +
            module Appium
         | 
| 16 | 
            +
              module Core
         | 
| 17 | 
            +
                class Base
         | 
| 18 | 
            +
                  #
         | 
| 19 | 
            +
                  # @api private
         | 
| 20 | 
            +
                  #
         | 
| 21 | 
            +
             | 
| 22 | 
            +
                  module HasRemoteStatus
         | 
| 23 | 
            +
                    # Selenium binding has this ability only in Remote Binding,
         | 
| 24 | 
            +
                    # so this library has this method by own for safe.
         | 
| 25 | 
            +
                    def remote_status
         | 
| 26 | 
            +
                      bridge.status
         | 
| 27 | 
            +
                    end
         | 
| 28 | 
            +
                  end
         | 
| 29 | 
            +
                end
         | 
| 30 | 
            +
              end
         | 
| 31 | 
            +
            end
         | 
| @@ -0,0 +1,54 @@ | |
| 1 | 
            +
            # frozen_string_literal: true
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            # Licensed under the Apache License, Version 2.0 (the "License");
         | 
| 4 | 
            +
            # you may not use this file except in compliance with the License.
         | 
| 5 | 
            +
            # You may obtain a copy of the License at
         | 
| 6 | 
            +
            #
         | 
| 7 | 
            +
            #     http://www.apache.org/licenses/LICENSE-2.0
         | 
| 8 | 
            +
            #
         | 
| 9 | 
            +
            # Unless required by applicable law or agreed to in writing, software
         | 
| 10 | 
            +
            # distributed under the License is distributed on an "AS IS" BASIS,
         | 
| 11 | 
            +
            # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
         | 
| 12 | 
            +
            # See the License for the specific language governing permissions and
         | 
| 13 | 
            +
            # limitations under the License.
         | 
| 14 | 
            +
             | 
| 15 | 
            +
            module Appium
         | 
| 16 | 
            +
              module Core
         | 
| 17 | 
            +
                class Base
         | 
| 18 | 
            +
                  #
         | 
| 19 | 
            +
                  # @api private
         | 
| 20 | 
            +
                  #
         | 
| 21 | 
            +
             | 
| 22 | 
            +
                  module Rotatable
         | 
| 23 | 
            +
                    ORIENTATIONS = %i[landscape portrait].freeze
         | 
| 24 | 
            +
             | 
| 25 | 
            +
                    #
         | 
| 26 | 
            +
                    # Change the screen orientation
         | 
| 27 | 
            +
                    #
         | 
| 28 | 
            +
                    # @param [:landscape, :portrait] orientation
         | 
| 29 | 
            +
                    #
         | 
| 30 | 
            +
                    #
         | 
| 31 | 
            +
                    def rotation=(orientation)
         | 
| 32 | 
            +
                      unless ORIENTATIONS.include?(orientation)
         | 
| 33 | 
            +
                        raise ::Appium::Core::Error::ArgumentError, "expected #{ORIENTATIONS.inspect}, got #{orientation.inspect}"
         | 
| 34 | 
            +
                      end
         | 
| 35 | 
            +
             | 
| 36 | 
            +
                      bridge.screen_orientation = orientation.to_s.upcase
         | 
| 37 | 
            +
                    end
         | 
| 38 | 
            +
                    alias rotate rotation=
         | 
| 39 | 
            +
             | 
| 40 | 
            +
                    #
         | 
| 41 | 
            +
                    # Get the current screen orientation
         | 
| 42 | 
            +
                    #
         | 
| 43 | 
            +
                    # @return [:landscape, :portrait] orientation
         | 
| 44 | 
            +
                    #
         | 
| 45 | 
            +
                    # @api public
         | 
| 46 | 
            +
                    #
         | 
| 47 | 
            +
             | 
| 48 | 
            +
                    def orientation
         | 
| 49 | 
            +
                      bridge.screen_orientation.to_sym.downcase
         | 
| 50 | 
            +
                    end
         | 
| 51 | 
            +
                  end
         | 
| 52 | 
            +
                end
         | 
| 53 | 
            +
              end
         | 
| 54 | 
            +
            end
         | 
| @@ -15,7 +15,7 @@ | |
| 15 15 | 
             
            module Appium
         | 
| 16 16 | 
             
              module Core
         | 
| 17 17 | 
             
                class Base
         | 
| 18 | 
            -
                  module  | 
| 18 | 
            +
                  module TakesScreenshot
         | 
| 19 19 | 
             
                    #
         | 
| 20 20 | 
             
                    # Save a PNG screenshot to the given path
         | 
| 21 21 | 
             
                    #
         | 
| @@ -63,8 +63,8 @@ module Appium | |
| 63 63 | 
             
                    def save_element_screenshot(element, png_path)
         | 
| 64 64 | 
             
                      extension = File.extname(png_path).downcase
         | 
| 65 65 | 
             
                      if extension != '.png'
         | 
| 66 | 
            -
                        ::Appium::Logger.warn 'name used for saved screenshot does not match file type. '\
         | 
| 67 | 
            -
             | 
| 66 | 
            +
                        ::Appium::Logger.warn 'name used for saved screenshot does not match file type. ' \
         | 
| 67 | 
            +
                                              'It should end with .png extension'
         | 
| 68 68 | 
             
                      end
         | 
| 69 69 | 
             
                      File.open(png_path, 'wb') { |f| f << element_screenshot_as(element, :png) }
         | 
| 70 70 | 
             
                    end
         | 
| @@ -84,9 +84,9 @@ module Appium | |
| 84 84 | 
             
                    def element_screenshot_as(element, format)
         | 
| 85 85 | 
             
                      case format
         | 
| 86 86 | 
             
                      when :base64
         | 
| 87 | 
            -
                        bridge. | 
| 87 | 
            +
                        bridge.element_screenshot element.id
         | 
| 88 88 | 
             
                      when :png
         | 
| 89 | 
            -
                        bridge. | 
| 89 | 
            +
                        bridge.element_screenshot(element.id).unpack('m')[0]
         | 
| 90 90 | 
             
                      else
         | 
| 91 91 | 
             
                        raise Core::Error::UnsupportedOperationError, "unsupported format: #{format.inspect}"
         | 
| 92 92 | 
             
                      end
         | 
| @@ -106,7 +106,7 @@ module Appium | |
| 106 106 | 
             
                        ::Appium::Logger.warn 'name used for saved screenshot does not match file type. '\
         | 
| 107 107 | 
             
                                              'It should end with .png extension'
         | 
| 108 108 | 
             
                      end
         | 
| 109 | 
            -
                      viewport_screenshot_encode64 = bridge. | 
| 109 | 
            +
                      viewport_screenshot_encode64 = bridge.viewport_screenshot
         | 
| 110 110 | 
             
                      File.open(png_path, 'wb') { |f| f << viewport_screenshot_encode64.unpack('m')[0] }
         | 
| 111 111 | 
             
                    end
         | 
| 112 112 | 
             
                  end
         | 
| @@ -32,6 +32,7 @@ module Appium | |
| 32 32 | 
             
                      predicate:            '-ios predicate string',
         | 
| 33 33 | 
             
                      class_chain:          '-ios class chain',
         | 
| 34 34 | 
             
                      # Windows with windows prefix
         | 
| 35 | 
            +
                      # @deprecated
         | 
| 35 36 | 
             
                      windows_uiautomation: '-windows uiautomation',
         | 
| 36 37 | 
             
                      # Tizen with Tizen prefix
         | 
| 37 38 | 
             
                      tizen_uiautomation:   '-tizen uiautomation'
         | 
| @@ -122,6 +123,7 @@ module Appium | |
| 122 123 | 
             
                    #     e.tag_name #=> "XCUIElementTypeStaticText"
         | 
| 123 124 | 
             
                    #
         | 
| 124 125 | 
             
                    #     # For Windows
         | 
| 126 | 
            +
                    #     # @deprecated
         | 
| 125 127 | 
             
                    #     @driver.find_elements :windows_uiautomation, '....'
         | 
| 126 128 | 
             
                    #
         | 
| 127 129 | 
             
                    #     # For Tizen
         | 
| @@ -141,6 +143,8 @@ module Appium | |
| 141 143 | 
             
                    #
         | 
| 142 144 | 
             
                    # Find all elements matching the given arguments
         | 
| 143 145 | 
             
                    #
         | 
| 146 | 
            +
                    # @return [Array<Selenium::WebDriver::Element>]
         | 
| 147 | 
            +
                    #
         | 
| 144 148 | 
             
                    # @see SearchContext#find_elements
         | 
| 145 149 | 
             
                    #
         | 
| 146 150 | 
             
                    def find_elements(*args)
         | 
| @@ -156,8 +160,17 @@ module Appium | |
| 156 160 | 
             
                    private
         | 
| 157 161 |  | 
| 158 162 | 
             
                    def _set_by_from_finders(how)
         | 
| 163 | 
            +
                      if how == :windows_uiautomation
         | 
| 164 | 
            +
                        ::Appium::Logger.warn(
         | 
| 165 | 
            +
                          '[DEPRECATION] :windows_uiautomation is deprecated. Please use other locators.'
         | 
| 166 | 
            +
                        )
         | 
| 167 | 
            +
                      end
         | 
| 168 | 
            +
             | 
| 159 169 | 
             
                      by = FINDERS[how.to_sym]
         | 
| 160 | 
            -
                       | 
| 170 | 
            +
                      unless by
         | 
| 171 | 
            +
                        raise ::Appium::Core::Error::ArgumentError,
         | 
| 172 | 
            +
                              "cannot find element by #{how.inspect}. Available finders are #{FINDERS.keys}."
         | 
| 173 | 
            +
                      end
         | 
| 161 174 |  | 
| 162 175 | 
             
                      by
         | 
| 163 176 | 
             
                    end
         | 
| @@ -169,16 +182,18 @@ module Appium | |
| 169 182 | 
             
                      when 1
         | 
| 170 183 | 
             
                        arg = args.first
         | 
| 171 184 |  | 
| 172 | 
            -
                         | 
| 185 | 
            +
                        unless arg.respond_to?(:shift)
         | 
| 186 | 
            +
                          raise ::Appium::Core::Error::ArgumentError, "expected #{arg.inspect}:#{arg.class} to respond to #shift"
         | 
| 187 | 
            +
                        end
         | 
| 173 188 |  | 
| 174 189 | 
             
                        # this will be a single-entry hash, so use #shift over #first or #[]
         | 
| 175 190 | 
             
                        arr = arg.dup.shift
         | 
| 176 191 |  | 
| 177 | 
            -
                        raise ArgumentError, "expected #{arr.inspect} to have 2 elements" unless arr.size == 2
         | 
| 192 | 
            +
                        raise ::Appium::Core::Error::ArgumentError, "expected #{arr.inspect} to have 2 elements" unless arr.size == 2
         | 
| 178 193 |  | 
| 179 194 | 
             
                        arr
         | 
| 180 195 | 
             
                      else
         | 
| 181 | 
            -
                        raise ArgumentError, "wrong number of arguments (#{args.size} for 2)"
         | 
| 196 | 
            +
                        raise ::Appium::Core::Error::ArgumentError, "wrong number of arguments (#{args.size} for 2)"
         | 
| 182 197 | 
             
                      end
         | 
| 183 198 | 
             
                    end
         | 
| 184 199 | 
             
                  end # module SearchContext
         | 
| @@ -29,14 +29,12 @@ require_relative 'device/clipboard_content_type' | |
| 29 29 | 
             
            require_relative 'device/device'
         | 
| 30 30 | 
             
            require_relative 'device/touch_actions'
         | 
| 31 31 | 
             
            require_relative 'device/execute_driver'
         | 
| 32 | 
            +
            require_relative 'device/orientation'
         | 
| 32 33 |  | 
| 33 34 | 
             
            # The following files have selenium-webdriver related stuff.
         | 
| 34 35 | 
             
            require_relative 'base/driver'
         | 
| 35 36 | 
             
            require_relative 'base/bridge'
         | 
| 36 | 
            -
            require_relative 'base/bridge/mjsonwp'
         | 
| 37 | 
            -
            require_relative 'base/bridge/w3c'
         | 
| 38 37 | 
             
            require_relative 'base/capabilities'
         | 
| 39 38 | 
             
            require_relative 'base/http_default'
         | 
| 40 39 | 
             
            require_relative 'base/search_context'
         | 
| 41 | 
            -
            require_relative 'base/command'
         | 
| 42 40 | 
             
            require_relative 'base/platform'
         |