File: bench_getlogin.rb

package info (click to toggle)
ruby-ffi 1.0.11debian-5
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 1,488 kB
  • sloc: ansic: 6,608; ruby: 6,167; xml: 151; sh: 74; makefile: 12
file content (28 lines) | stat: -rw-r--r-- 510 bytes parent folder | download | duplicates (6)
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
require 'benchmark'
require 'ffi'
require 'etc'

iter = 1000000

module Posix
  extend FFI::Library
  attach_function :getlogin, [], :string
end
if Posix.getlogin != Etc.getlogin
  raise ArgumentError, "FFI getlogin returned incorrect value"
end

puts "Benchmark FFI getlogin(2) performance, #{iter}x"

10.times {
  puts Benchmark.measure {
    iter.times { Posix.getlogin }
  }
}

puts "Benchmark Etc.getlogin performance, #{iter}x"
10.times {
  puts Benchmark.measure {
    iter.times { Etc.getlogin }
  }
}