File: list_spec.rb

package info (click to toggle)
jruby 1.7.26-1%2Bdeb9u1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 84,572 kB
  • sloc: ruby: 669,910; java: 253,056; xml: 35,152; ansic: 9,187; yacc: 7,267; cpp: 5,244; sh: 1,036; makefile: 345; jsp: 48; tcl: 40
file content (110 lines) | stat: -rw-r--r-- 2,651 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
require File.dirname(__FILE__) + "/../spec_helper"

java_import "java.util.ArrayList"

describe "List Ruby extensions" do
  before(:each) do
    @data = ["foo", "quux", "bar", "aa"]
    @list = ArrayList.new(@data)
  end

  it "should support index() with one argument" do
    @list.index("quux").should == 1
  end

  it "should return nil on index() with one argument that does not exist" do
    @list.index(451).should == nil
  end

  it "should support index() with a block" do
    @list.index{|x| x == "bar" }.should == 2
  end

  it "should support index() with a block that does not exist" do
    @list.index{|x| x == :nazgul }.should == nil
  end

  it "should support index() with nil (not found)" do
    @list.index(nil).should == nil
  end

  it "should support index() with nil (found)" do
    ArrayList.new(["foo", "quux", nil, "bar", "aa"]).index(nil).should == 2
  end

  it "should support index() with no arguments" do
    @list.index.each {|x| x == "foo" }.should == 0
  end

  it "should support index() with no arguments (not existing)" do
    @list.index.each {|x| x == ":-(" }.should == nil
  end

  # Java 8 adds a single-parameter sort method to List that sorts in-place
  if ENV_JAVA['java.specification.version'] < '1.8'
    it "should be sortable with sort() without block" do
      @list.sort.to_a.should == @data.sort
    end

    it "should be sortable with sort() with block" do
      result = @list.sort do |a, b|
        a.length <=> b.length
      end

      expected = @data.sort do |a, b|
        a.length <=> b.length
      end

      result.to_a.should == expected
    end
  end

  it "should be sortable with sort!() without block" do
    list = ArrayList.new(@data)
    list.sort!
    list.to_a.should == @data.sort
  end

  it "should be sortable with sort!() with block" do
    list = ArrayList.new(@data)
    list.sort! do |a, b|
      a.length <=> b.length
    end

    expected = @data.sort do |a, b|
      a.length <=> b.length
    end

    list.to_a.should == expected
  end

  it "should support slicing with 2 arguments" do
    @list[0,3].to_a.should == @data[0,3]
  end

  it "should support slicing with inclusive ranges" do
    @list[0..3].to_a.should == @data[0..3]
  end

   it "should support slicing with exclusive ranges" do
    @list[0...2].to_a.should == @data[0...2]
  end

  it "should respect to_ary objects defined on iteration" do
    class Pair
      def initialize(a, b)
        @a = a
        @b = b
      end

      def to_ary
        [@a, @b]
      end
    end

    ArrayList.new([Pair.new(:x, :y)]).each do |car, cdr|
      car.should == :x
      cdr.should == :y
    end
  end
end