File: delete_if_spec.rb

package info (click to toggle)
ruby2.7 2.7.4-1%2Bdeb11u1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 112,576 kB
  • sloc: ruby: 849,454; ansic: 697,834; yacc: 45,100; xml: 25,367; pascal: 10,051; javascript: 6,575; sh: 3,848; makefile: 759; cpp: 713; asm: 333; python: 295; lisp: 97; sed: 94; perl: 62; awk: 36
file content (44 lines) | stat: -rw-r--r-- 1,418 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
require_relative '../../spec_helper'
require_relative 'fixtures/classes'
require_relative 'shared/iteration'
require_relative '../enumerable/shared/enumeratorized'

describe "Hash#delete_if" do
  it "yields two arguments: key and value" do
    all_args = []
    { 1 => 2, 3 => 4 }.delete_if { |*args| all_args << args }
    all_args.sort.should == [[1, 2], [3, 4]]
  end

  it "removes every entry for which block is true and returns self" do
    h = { a: 1, b: 2, c: 3, d: 4 }
    h.delete_if { |k,v| v % 2 == 1 }.should equal(h)
    h.should == { b: 2, d: 4 }
  end

  it "removes all entries if the block is true" do
    h = { a: 1, b: 2, c: 3 }
    h.delete_if { |k,v| true }.should equal(h)
    h.should == {}
  end

  it "processes entries with the same order as each()" do
    h = { a: 1, b: 2, c: 3, d: 4 }

    each_pairs = []
    delete_pairs = []

    h.each_pair { |k,v| each_pairs << [k, v] }
    h.delete_if { |k,v| delete_pairs << [k,v] }

    each_pairs.should == delete_pairs
  end

  it "raises a #{frozen_error_class} if called on a frozen instance" do
    -> { HashSpecs.frozen_hash.delete_if { false } }.should raise_error(frozen_error_class)
    -> { HashSpecs.empty_frozen_hash.delete_if { true } }.should raise_error(frozen_error_class)
  end

  it_behaves_like :hash_iteration_no_block, :delete_if
  it_behaves_like :enumeratorized_with_origin_size, :delete_if, { 1 => 2, 3 => 4, 5 => 6 }
end