forked from norman/friendly_id
/
bench.rb
59 lines (45 loc) · 1.68 KB
/
bench.rb
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
#!/usr/bin/env ruby -KU
require File.dirname(__FILE__) + '/extras'
require 'rbench'
FACTOR = 100
RBench.run(TIMES) do
column :times
column :ar
report 'find model using id', (TIMES * FACTOR).ceil do
ar { User.find(get_id) }
end
report 'find model using array of ids', (TIMES * FACTOR).ceil do
ar { User.find([get_id, get_id]) }
end
report 'find unslugged model using friendly id', (TIMES * FACTOR).ceil do
ar { User.find(USERS.rand) }
end
report 'find unslugged model using array of friendly ids', (TIMES * FACTOR).ceil do
ar { User.find([USERS.rand, USERS.rand]) }
end
report 'find slugged model using friendly id', (TIMES * FACTOR).ceil do
ar { Post.find(POSTS.rand) }
end
report 'find slugged model using array of friendly ids', (TIMES * FACTOR).ceil do
ar { Post.find([POSTS.rand, POSTS.rand]) }
end
report 'find cached slugged model using friendly id', (TIMES * FACTOR).ceil do
ar { District.find(DISTRICTS.rand) }
end
report 'find cached slugged model using array of friendly ids', (TIMES * FACTOR).ceil do
ar { District.find([DISTRICTS.rand, DISTRICTS.rand]) }
end
report 'find model using id, then to_param', (TIMES * FACTOR).ceil do
ar { User.find(get_id).to_param }
end
report 'find unslugged model using friendly id, then to_param', (TIMES * FACTOR).ceil do
ar { User.find(USERS.rand).to_param }
end
report 'find slugged model using friendly id, then to_param', (TIMES * FACTOR).ceil do
ar { Post.find(POSTS.rand).to_param }
end
report 'find cached slugged model using friendly id, then to_param', (TIMES * FACTOR).ceil do
ar { District.find(DISTRICTS.rand).to_param }
end
summary 'Total'
end