source: EcnlProtoTool/trunk/mruby-1.3.0/mrbgems/mruby-hash-ext/test/hash.rb@ 331

Last change on this file since 331 was 331, checked in by coas-nagasima, 6 years ago

prototoolに関連するプロジェクトをnewlibからmuslを使うよう変更・更新
ntshellをnewlibの下位の実装から、muslのsyscallの実装に変更・更新
以下のOSSをアップデート
・mruby-1.3.0
・musl-1.1.18
・onigmo-6.1.3
・tcc-0.9.27
以下のOSSを追加
・openssl-1.1.0e
・curl-7.57.0
・zlib-1.2.11
以下のmrbgemsを追加
・iij/mruby-digest
・iij/mruby-env
・iij/mruby-errno
・iij/mruby-iijson
・iij/mruby-ipaddr
・iij/mruby-mock
・iij/mruby-require
・iij/mruby-tls-openssl

  • Property svn:eol-style set to native
  • Property svn:mime-type set to text/x-ruby;charset=UTF-8
File size: 5.7 KB
Line 
1##
2# Hash(Ext) Test
3
4assert('Hash.[] Hash') do
5 a = Hash['a_key' => 'a_value']
6
7 assert_equal({'a_key' => 'a_value'}, a)
8end
9
10assert('Hash.[] [ [ ["b_key", "b_value" ] ] ]') do
11 a = Hash[ [ ['b_key', 'b_value'] ] ]
12
13 assert_equal({'b_key' => 'b_value'}, a)
14
15 a = Hash[ [ ] ]
16
17 assert_equal({}, a)
18
19 assert_raise(ArgumentError) do
20 Hash[ [ ['b_key', 'b_value', 'b_over'] ] ]
21 end
22
23 assert_raise(ArgumentError) do
24 Hash[ [ [] ] ]
25 end
26end
27
28assert('Hash.[] "c_key", "c_value"') do
29 a = Hash['c_key', 'c_value', 'd_key', 1]
30
31 assert_equal({'c_key' => 'c_value', 'd_key' => 1}, a)
32
33 a = Hash[]
34
35 assert_equal({}, a)
36
37 assert_raise(ArgumentError) do
38 Hash['d_key']
39 end
40end
41
42assert('Hash.[] for sub class') do
43 sub_hash_class = Class.new(Hash)
44 sub_hash = sub_hash_class[]
45 assert_equal(sub_hash_class, sub_hash.class)
46end
47
48assert('Hash.try_convert') do
49 assert_nil Hash.try_convert(nil)
50 assert_nil Hash.try_convert("{1=>2}")
51 assert_equal({1=>2}, Hash.try_convert({1=>2}))
52end
53
54assert('Hash#merge!') do
55 a = { 'abc_key' => 'abc_value', 'cba_key' => 'cba_value' }
56 b = { 'cba_key' => 'XXX', 'xyz_key' => 'xyz_value' }
57
58 result_1 = a.merge! b
59
60 a = { 'abc_key' => 'abc_value', 'cba_key' => 'cba_value' }
61 result_2 = a.merge!(b) do |key, original, new|
62 original
63 end
64
65 assert_equal({'abc_key' => 'abc_value', 'cba_key' => 'XXX',
66 'xyz_key' => 'xyz_value' }, result_1)
67 assert_equal({'abc_key' => 'abc_value', 'cba_key' => 'cba_value',
68 'xyz_key' => 'xyz_value' }, result_2)
69
70 assert_raise(TypeError) do
71 { 'abc_key' => 'abc_value' }.merge! "a"
72 end
73end
74
75assert('Hash#values_at') do
76 h = { "cat" => "feline", "dog" => "canine", "cow" => "bovine" }
77 assert_equal ["bovine", "feline"], h.values_at("cow", "cat")
78
79 keys = []
80 (0...1000).each { |v| keys.push "#{v}" }
81 h = Hash.new { |hash,k| hash[k] = k }
82 assert_equal keys, h.values_at(*keys)
83end
84
85assert('Hash#fetch') do
86 h = { "cat" => "feline", "dog" => "canine", "cow" => "bovine" }
87 assert_equal "feline", h.fetch("cat")
88 assert_equal "mickey", h.fetch("mouse", "mickey")
89 assert_equal "minny", h.fetch("mouse"){"minny"}
90 assert_equal "mouse", h.fetch("mouse"){|k| k}
91 assert_raise(KeyError) do
92 h.fetch("gnu")
93 end
94end
95
96assert("Hash#delete_if") do
97 base = { 1 => 'one', 2 => false, true => 'true', 'cat' => 99 }
98 h1 = { 1 => 'one', 2 => false, true => 'true' }
99 h2 = { 2 => false, 'cat' => 99 }
100 h3 = { 2 => false }
101
102 h = base.dup
103 assert_equal(h, h.delete_if { false })
104 assert_equal({}, h.delete_if { true })
105
106 h = base.dup
107 assert_equal(h1, h.delete_if {|k,v| k.instance_of?(String) })
108 assert_equal(h1, h)
109
110 h = base.dup
111 assert_equal(h2, h.delete_if {|k,v| v.instance_of?(String) })
112 assert_equal(h2, h)
113
114 h = base.dup
115 assert_equal(h3, h.delete_if {|k,v| v })
116 assert_equal(h3, h)
117
118 h = base.dup
119 n = 0
120 h.delete_if {|*a|
121 n += 1
122 assert_equal(2, a.size)
123 assert_equal(base[a[0]], a[1])
124 h.shift
125 true
126 }
127 assert_equal(base.size, n)
128end
129
130assert("Hash#flatten") do
131 a = {1=> "one", 2 => [2,"two"], 3 => [3, ["three"]]}
132 assert_equal [1, "one", 2, [2, "two"], 3, [3, ["three"]]], a.flatten
133 assert_equal [[1, "one"], [2, [2, "two"]], [3, [3, ["three"]]]], a.flatten(0)
134 assert_equal [1, "one", 2, [2, "two"], 3, [3, ["three"]]], a.flatten(1)
135 assert_equal [1, "one", 2, 2, "two", 3, 3, ["three"]], a.flatten(2)
136 assert_equal [1, "one", 2, 2, "two", 3, 3, "three"], a.flatten(3)
137end
138
139assert("Hash#invert") do
140 h = { 1 => 'one', 2 => 'two', 3 => 'three',
141 true => 'true', nil => 'nil' }.invert
142 assert_equal 1, h['one']
143 assert_equal true, h['true']
144 assert_equal nil, h['nil']
145
146 h = { 'a' => 1, 'b' => 2, 'c' => 1 }.invert
147 assert_equal(2, h.length)
148 assert_include(%w[a c], h[1])
149 assert_equal('b', h[2])
150end
151
152assert("Hash#invert with sub class") do
153 sub_hash_class = Class.new(Hash)
154 sub_hash = sub_hash_class.new
155 assert_equal(sub_hash_class, sub_hash.invert.class)
156end
157
158assert("Hash#keep_if") do
159 h = { 1 => 2, 3 => 4, 5 => 6 }
160 assert_equal({3=>4,5=>6}, h.keep_if {|k, v| k + v >= 7 })
161 h = { 1 => 2, 3 => 4, 5 => 6 }
162 assert_equal({ 1 => 2, 3=> 4, 5 =>6} , h.keep_if { true })
163end
164
165assert("Hash#key") do
166 h = { "a" => 100, "b" => 200, "c" => 300, "d" => 300, nil => 'nil', 'nil' => nil }
167 assert_equal "b", h.key(200)
168 assert_equal "c", h.key(300)
169 assert_nil h.key(999)
170 assert_nil h.key('nil')
171 assert_equal 'nil', h.key(nil)
172end
173
174assert("Hash#to_h") do
175 h = { "a" => 100, "b" => 200 }
176 assert_equal Hash, h.to_h.class
177 assert_equal h, h.to_h
178end
179
180assert('Hash#<') do
181 h1 = {a:1, b:2}
182 h2 = {a:1, b:2, c:3}
183
184 assert_false(h1 < h1)
185 assert_true(h1 < h2)
186 assert_false(h2 < h1)
187 assert_false(h2 < h2)
188
189 h1 = {a:1}
190 h2 = {a:2}
191
192 assert_false(h1 < h1)
193 assert_false(h1 < h2)
194 assert_false(h2 < h1)
195 assert_false(h2 < h2)
196end
197
198assert('Hash#<=') do
199 h1 = {a:1, b:2}
200 h2 = {a:1, b:2, c:3}
201
202 assert_true(h1 <= h1)
203 assert_true(h1 <= h2)
204 assert_false(h2 <= h1)
205 assert_true(h2 <= h2)
206
207 h1 = {a:1}
208 h2 = {a:2}
209
210 assert_true(h1 <= h1)
211 assert_false(h1 <= h2)
212 assert_false(h2 <= h1)
213 assert_true(h2 <= h2)
214end
215
216assert('Hash#>=') do
217 h1 = {a:1, b:2}
218 h2 = {a:1, b:2, c:3}
219
220 assert_true(h1 >= h1)
221 assert_false(h1 >= h2)
222 assert_true(h2 >= h1)
223 assert_true(h2 >= h2)
224
225 h1 = {a:1}
226 h2 = {a:2}
227
228 assert_true(h1 >= h1)
229 assert_false(h1 >= h2)
230 assert_false(h2 >= h1)
231 assert_true(h2 >= h2)
232end
233
234assert('Hash#>') do
235 h1 = {a:1, b:2}
236 h2 = {a:1, b:2, c:3}
237
238 assert_false(h1 > h1)
239 assert_false(h1 > h2)
240 assert_true(h2 > h1)
241 assert_false(h2 > h2)
242
243 h1 = {a:1}
244 h2 = {a:2}
245
246 assert_false(h1 > h1)
247 assert_false(h1 > h2)
248 assert_false(h2 > h1)
249 assert_false(h2 > h2)
250end
251
252assert("Hash#dig") do
253 h = {a:{b:{c:1}}}
254 assert_equal(1, h.dig(:a, :b, :c))
255 assert_nil(h.dig(:d))
256end
Note: See TracBrowser for help on using the repository browser.