2016-03-07 19:52:19 -05:00
|
|
|
# frozen_string_literal: true
|
2018-02-28 19:11:41 -05:00
|
|
|
|
2012-08-09 20:38:07 -04:00
|
|
|
require 'spec_helper'
|
|
|
|
|
2019-08-17 20:24:40 -04:00
|
|
|
RSpec.describe Capybara::Result do
|
2012-08-09 20:38:07 -04:00
|
|
|
let :string do
|
|
|
|
Capybara.string <<-STRING
|
|
|
|
<ul>
|
|
|
|
<li>Alpha</li>
|
|
|
|
<li>Beta</li>
|
|
|
|
<li>Gamma</li>
|
|
|
|
<li>Delta</li>
|
|
|
|
</ul>
|
|
|
|
STRING
|
|
|
|
end
|
|
|
|
|
|
|
|
let :result do
|
2017-11-14 15:14:24 -05:00
|
|
|
string.all '//li', minimum: 0 # pass minimum: 0 so lazy evaluation doesn't get triggered yet
|
2012-08-09 20:38:07 -04:00
|
|
|
end
|
|
|
|
|
2018-07-10 17:18:39 -04:00
|
|
|
it 'has a length' do
|
2013-11-14 12:43:36 -05:00
|
|
|
expect(result.length).to eq(4)
|
2012-08-09 20:38:07 -04:00
|
|
|
end
|
|
|
|
|
2018-07-10 17:18:39 -04:00
|
|
|
it 'has a first element' do
|
2012-08-09 20:38:07 -04:00
|
|
|
result.first.text == 'Alpha'
|
|
|
|
end
|
|
|
|
|
2018-07-10 17:18:39 -04:00
|
|
|
it 'has a last element' do
|
2012-08-09 20:38:07 -04:00
|
|
|
result.last.text == 'Delta'
|
|
|
|
end
|
|
|
|
|
2013-10-29 16:43:11 -04:00
|
|
|
it 'can supports values_at method' do
|
2018-02-28 19:11:41 -05:00
|
|
|
expect(result.values_at(0, 2).map(&:text)).to eq(%w[Alpha Gamma])
|
2013-10-29 16:43:11 -04:00
|
|
|
end
|
|
|
|
|
2018-07-10 17:18:39 -04:00
|
|
|
it 'can return an element by its index' do
|
2013-11-14 12:43:36 -05:00
|
|
|
expect(result.at(1).text).to eq('Beta')
|
|
|
|
expect(result[2].text).to eq('Gamma')
|
2012-08-09 20:38:07 -04:00
|
|
|
end
|
|
|
|
|
2018-07-10 17:18:39 -04:00
|
|
|
it 'can be mapped' do
|
2018-02-28 19:11:41 -05:00
|
|
|
expect(result.map(&:text)).to eq(%w[Alpha Beta Gamma Delta])
|
2012-08-09 20:38:07 -04:00
|
|
|
end
|
|
|
|
|
2018-07-10 17:18:39 -04:00
|
|
|
it 'can be selected' do
|
2019-10-15 21:06:45 -04:00
|
|
|
expect(result.count do |element|
|
2012-08-09 20:38:07 -04:00
|
|
|
element.text.include? 't'
|
2019-10-15 21:06:45 -04:00
|
|
|
end).to eq(2)
|
2012-08-09 20:38:07 -04:00
|
|
|
end
|
|
|
|
|
2018-07-10 17:18:39 -04:00
|
|
|
it 'can be reduced' do
|
2013-11-14 12:43:36 -05:00
|
|
|
expect(result.reduce('') do |memo, element|
|
2018-02-28 19:11:41 -05:00
|
|
|
memo + element.text[0]
|
2013-11-14 12:43:36 -05:00
|
|
|
end).to eq('ABGD')
|
2012-08-09 20:38:07 -04:00
|
|
|
end
|
2013-09-16 07:19:06 -04:00
|
|
|
|
|
|
|
it 'can be sampled' do
|
2013-11-14 12:43:36 -05:00
|
|
|
expect(result).to include(result.sample)
|
2013-09-16 07:19:06 -04:00
|
|
|
end
|
2013-10-29 16:43:11 -04:00
|
|
|
|
|
|
|
it 'can be indexed' do
|
2013-11-14 12:43:36 -05:00
|
|
|
expect(result.index do |el|
|
2013-10-29 16:43:11 -04:00
|
|
|
el.text == 'Gamma'
|
2013-11-14 12:43:36 -05:00
|
|
|
end).to eq(2)
|
2013-10-29 16:43:11 -04:00
|
|
|
end
|
2016-08-05 17:44:33 -04:00
|
|
|
|
2020-02-03 20:48:36 -05:00
|
|
|
def recalc_result
|
|
|
|
string.all '//li', minimum: 0 # pass minimum: 0 so lazy evaluation doesn't get triggered yet
|
|
|
|
end
|
|
|
|
|
2016-08-05 17:44:33 -04:00
|
|
|
it 'supports all modes of []' do
|
2020-02-03 20:48:36 -05:00
|
|
|
expect(recalc_result[1].text).to eq 'Beta'
|
|
|
|
expect(recalc_result[0, 2].map(&:text)).to eq %w[Alpha Beta]
|
|
|
|
expect(recalc_result[1..3].map(&:text)).to eq %w[Beta Gamma Delta]
|
|
|
|
expect(recalc_result[-1].text).to eq 'Delta'
|
|
|
|
expect(recalc_result[-2, 3].map(&:text)).to eq %w[Gamma Delta]
|
|
|
|
expect(recalc_result[1...3].map(&:text)).to eq %w[Beta Gamma]
|
|
|
|
expect(recalc_result[1..7].map(&:text)).to eq %w[Beta Gamma Delta]
|
|
|
|
expect(recalc_result[2...-1].map(&:text)).to eq %w[Gamma]
|
2021-03-27 15:23:04 -04:00
|
|
|
expect(recalc_result[2..-1].map(&:text)).to eq %w[Gamma Delta] # rubocop:disable Style/SlicingWithRange
|
|
|
|
expect(recalc_result[2..].map(&:text)).to eq %w[Gamma Delta]
|
2020-02-03 20:48:36 -05:00
|
|
|
end
|
|
|
|
|
2021-03-27 15:23:04 -04:00
|
|
|
it 'supports endless ranges' do
|
|
|
|
expect(result[2..].map(&:text)).to eq %w[Gamma Delta]
|
|
|
|
end
|
2020-02-03 20:48:36 -05:00
|
|
|
|
2022-04-30 13:26:55 -04:00
|
|
|
it 'supports inclusive positive beginless ranges' do
|
|
|
|
expect(result[..2].map(&:text)).to eq %w[Alpha Beta Gamma]
|
|
|
|
end
|
2020-02-03 20:48:36 -05:00
|
|
|
|
2022-04-30 13:26:55 -04:00
|
|
|
it 'supports inclusive negative beginless ranges' do
|
|
|
|
expect(result[..-2].map(&:text)).to eq %w[Alpha Beta Gamma]
|
|
|
|
expect(result[..-1].map(&:text)).to eq %w[Alpha Beta Gamma Delta]
|
|
|
|
end
|
2020-02-03 20:48:36 -05:00
|
|
|
|
2022-04-30 13:26:55 -04:00
|
|
|
it 'supports exclusive positive beginless ranges' do
|
|
|
|
expect(result[...2].map(&:text)).to eq %w[Alpha Beta]
|
|
|
|
end
|
2020-02-03 20:48:36 -05:00
|
|
|
|
2022-04-30 13:26:55 -04:00
|
|
|
it 'supports exclusive negative beginless ranges' do
|
|
|
|
expect(result[...-2].map(&:text)).to eq %w[Alpha Beta]
|
|
|
|
expect(result[...-1].map(&:text)).to eq %w[Alpha Beta Gamma]
|
|
|
|
end
|
2016-08-05 17:44:33 -04:00
|
|
|
|
2017-05-31 14:50:32 -04:00
|
|
|
it 'works with filter blocks' do
|
|
|
|
result = string.all('//li') { |node| node.text == 'Alpha' }
|
|
|
|
expect(result.size).to eq 1
|
|
|
|
end
|
|
|
|
|
2018-02-28 19:11:41 -05:00
|
|
|
# Not a great test but it indirectly tests what is needed
|
2018-07-10 17:18:39 -04:00
|
|
|
it 'should evaluate filters lazily for idx' do
|
2019-04-11 18:01:59 -04:00
|
|
|
skip 'JRuby has an issue with lazy enumerator evaluation' if jruby_lazy_enumerator_workaround?
|
2018-02-28 19:11:41 -05:00
|
|
|
# Not processed until accessed
|
2022-04-30 13:26:55 -04:00
|
|
|
expect(result.instance_variable_get(:@result_cache).size).to be 0
|
2016-08-05 17:44:33 -04:00
|
|
|
|
2018-02-28 19:11:41 -05:00
|
|
|
# Only one retrieved when needed
|
2016-08-05 17:44:33 -04:00
|
|
|
result.first
|
2022-04-30 13:26:55 -04:00
|
|
|
expect(result.instance_variable_get(:@result_cache).size).to be 1
|
2016-08-05 17:44:33 -04:00
|
|
|
|
2018-02-28 19:11:41 -05:00
|
|
|
# works for indexed access
|
2016-08-31 17:55:03 -04:00
|
|
|
result[0]
|
2022-04-30 13:26:55 -04:00
|
|
|
expect(result.instance_variable_get(:@result_cache).size).to be 1
|
2016-08-31 17:55:03 -04:00
|
|
|
|
2016-08-05 17:44:33 -04:00
|
|
|
result[2]
|
2022-04-30 13:26:55 -04:00
|
|
|
expect(result.instance_variable_get(:@result_cache).size).to be 3
|
2016-08-05 17:44:33 -04:00
|
|
|
|
2018-02-28 19:11:41 -05:00
|
|
|
# All cached when converted to array
|
2016-08-05 17:44:33 -04:00
|
|
|
result.to_a
|
2022-04-30 13:26:55 -04:00
|
|
|
expect(result.instance_variable_get(:@result_cache).size).to eq 4
|
2016-08-05 17:44:33 -04:00
|
|
|
end
|
2016-10-18 11:54:57 -04:00
|
|
|
|
2018-07-10 17:18:39 -04:00
|
|
|
it 'should evaluate filters lazily for range' do
|
2019-04-11 18:01:59 -04:00
|
|
|
skip 'JRuby has an issue with lazy enumerator evaluation' if jruby_lazy_enumerator_workaround?
|
2018-05-11 18:14:51 -04:00
|
|
|
result[0..1]
|
2022-04-30 13:26:55 -04:00
|
|
|
expect(result.instance_variable_get(:@result_cache).size).to be 2
|
2018-05-11 18:39:34 -04:00
|
|
|
|
|
|
|
expect(result[0..7].size).to eq 4
|
2022-04-30 13:26:55 -04:00
|
|
|
expect(result.instance_variable_get(:@result_cache).size).to be 4
|
2018-05-11 18:14:51 -04:00
|
|
|
end
|
|
|
|
|
2018-07-10 17:18:39 -04:00
|
|
|
it 'should evaluate filters lazily for idx and length' do
|
2019-04-11 18:01:59 -04:00
|
|
|
skip 'JRuby has an issue with lazy enumerator evaluation' if jruby_lazy_enumerator_workaround?
|
2018-05-11 18:14:51 -04:00
|
|
|
result[1, 2]
|
2022-04-30 13:26:55 -04:00
|
|
|
expect(result.instance_variable_get(:@result_cache).size).to be 3
|
2018-05-11 18:39:34 -04:00
|
|
|
|
|
|
|
expect(result[2, 5].size).to eq 2
|
2022-04-30 13:26:55 -04:00
|
|
|
expect(result.instance_variable_get(:@result_cache).size).to be 4
|
2018-05-11 18:14:51 -04:00
|
|
|
end
|
|
|
|
|
2018-07-10 17:18:39 -04:00
|
|
|
it 'should only need to evaluate one result for any?' do
|
2019-04-11 18:01:59 -04:00
|
|
|
skip 'JRuby has an issue with lazy enumerator evaluation' if jruby_lazy_enumerator_workaround?
|
2018-05-16 15:47:08 -04:00
|
|
|
result.any?
|
2022-04-30 13:26:55 -04:00
|
|
|
expect(result.instance_variable_get(:@result_cache).size).to be 1
|
2018-05-16 15:47:08 -04:00
|
|
|
end
|
|
|
|
|
2018-07-10 17:18:39 -04:00
|
|
|
it 'should evaluate all elements when #to_a called' do
|
2018-05-11 18:14:51 -04:00
|
|
|
# All cached when converted to array
|
|
|
|
result.to_a
|
2022-04-30 13:26:55 -04:00
|
|
|
expect(result.instance_variable_get(:@result_cache).size).to eq 4
|
2018-05-11 18:14:51 -04:00
|
|
|
end
|
|
|
|
|
2019-10-15 20:40:27 -04:00
|
|
|
describe '#each' do
|
2016-10-18 11:54:57 -04:00
|
|
|
it 'lazily evaluates' do
|
2019-04-11 18:01:59 -04:00
|
|
|
skip 'JRuby has an issue with lazy enumerator evaluation' if jruby_lazy_enumerator_workaround?
|
2018-02-28 19:11:41 -05:00
|
|
|
results = []
|
2016-10-18 11:54:57 -04:00
|
|
|
result.each do |el|
|
|
|
|
results << el
|
2022-04-30 13:26:55 -04:00
|
|
|
expect(result.instance_variable_get(:@result_cache).size).to eq results.size
|
2016-10-18 11:54:57 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
expect(results.size).to eq 4
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'without a block' do
|
|
|
|
it 'returns an iterator' do
|
|
|
|
expect(result.each).to be_a(Enumerator)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'lazily evaluates' do
|
2019-04-11 18:01:59 -04:00
|
|
|
skip 'JRuby has an issue with lazy enumerator evaluation' if jruby_lazy_enumerator_workaround?
|
2018-02-28 19:11:41 -05:00
|
|
|
result.each.with_index do |_el, idx|
|
2022-04-30 13:26:55 -04:00
|
|
|
expect(result.instance_variable_get(:@result_cache).size).to eq(idx + 1) # 0 indexing
|
2016-10-18 11:54:57 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2018-05-03 17:19:03 -04:00
|
|
|
|
2019-04-11 18:01:59 -04:00
|
|
|
def jruby_lazy_enumerator_workaround?
|
2020-05-15 12:04:53 -04:00
|
|
|
RUBY_PLATFORM == 'java'
|
2019-04-11 18:01:59 -04:00
|
|
|
end
|
2012-08-09 20:38:07 -04:00
|
|
|
end
|