mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
fb2008a73a
* test/lib/find_executable.rb: Ditto. * test/lib/memory_status.rb: Ditto. * test/lib/test/unit.rb: require envutil. * test/: Don't require envutil in test files. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@48409 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
111 lines
2.7 KiB
Ruby
111 lines
2.7 KiB
Ruby
module Memory
|
|
keys = []
|
|
vals = []
|
|
|
|
case
|
|
when File.exist?(procfile = "/proc/self/status") && (pat = /^Vm(\w+):\s+(\d+)/) =~ File.binread(procfile)
|
|
PROC_FILE = procfile
|
|
VM_PAT = pat
|
|
def self.read_status
|
|
IO.foreach(PROC_FILE, encoding: Encoding::ASCII_8BIT) do |l|
|
|
yield($1.downcase.intern, $2.to_i * 1024) if VM_PAT =~ l
|
|
end
|
|
end
|
|
|
|
read_status {|k, v| keys << k; vals << v}
|
|
|
|
when /mswin|mingw/ =~ RUBY_PLATFORM
|
|
require 'fiddle/import'
|
|
require 'fiddle/types'
|
|
|
|
module Win32
|
|
extend Fiddle::Importer
|
|
dlload "kernel32.dll", "psapi.dll"
|
|
include Fiddle::Win32Types
|
|
typealias "SIZE_T", "size_t"
|
|
|
|
PROCESS_MEMORY_COUNTERS = struct [
|
|
"DWORD cb",
|
|
"DWORD PageFaultCount",
|
|
"SIZE_T PeakWorkingSetSize",
|
|
"SIZE_T WorkingSetSize",
|
|
"SIZE_T QuotaPeakPagedPoolUsage",
|
|
"SIZE_T QuotaPagedPoolUsage",
|
|
"SIZE_T QuotaPeakNonPagedPoolUsage",
|
|
"SIZE_T QuotaNonPagedPoolUsage",
|
|
"SIZE_T PagefileUsage",
|
|
"SIZE_T PeakPagefileUsage",
|
|
]
|
|
|
|
typealias "PPROCESS_MEMORY_COUNTERS", "PROCESS_MEMORY_COUNTERS*"
|
|
|
|
extern "HANDLE GetCurrentProcess()", :stdcall
|
|
extern "BOOL GetProcessMemoryInfo(HANDLE, PPROCESS_MEMORY_COUNTERS, DWORD)", :stdcall
|
|
|
|
module_function
|
|
def memory_info
|
|
size = PROCESS_MEMORY_COUNTERS.size
|
|
data = PROCESS_MEMORY_COUNTERS.malloc
|
|
data.cb = size
|
|
data if GetProcessMemoryInfo(GetCurrentProcess(), data, size)
|
|
end
|
|
end
|
|
|
|
keys << :peak << :size
|
|
def self.read_status
|
|
if info = Win32.memory_info
|
|
yield :peak, info.PeakPagefileUsage
|
|
yield :size, info.PagefileUsage
|
|
end
|
|
end
|
|
else
|
|
PAT = /^\s*(\d+)\s+(\d+)$/
|
|
require_relative '../lib/find_executable'
|
|
if PSCMD = EnvUtil.find_executable("ps", "-ovsz=", "-orss=", "-p", $$.to_s) {|out| PAT =~ out}
|
|
PSCMD.pop
|
|
end
|
|
raise MiniTest::Skip, "ps command not found" unless PSCMD
|
|
|
|
keys << :size << :rss
|
|
def self.read_status
|
|
if PAT =~ IO.popen(PSCMD + [$$.to_s], "r", err: [:child, :out], &:read)
|
|
yield :size, $1.to_i*1024
|
|
yield :rss, $2.to_i*1024
|
|
end
|
|
end
|
|
end
|
|
|
|
Status = Struct.new(*keys)
|
|
|
|
class Status
|
|
def _update
|
|
Memory.read_status do |key, val|
|
|
self[key] = val
|
|
end
|
|
end
|
|
end
|
|
|
|
class Status
|
|
Header = members.map {|k| k.to_s.upcase.rjust(6)}.join('')
|
|
Format = "%6d"
|
|
|
|
def initialize
|
|
_update
|
|
end
|
|
|
|
def to_s
|
|
status = each_pair.map {|n,v|
|
|
"#{n}:#{v}"
|
|
}
|
|
"{#{status.join(",")}}"
|
|
end
|
|
|
|
def self.parse(str)
|
|
status = allocate
|
|
str.scan(/(?:\A\{|\G,)(#{members.join('|')}):(\d+)(?=,|\}\z)/) do
|
|
status[$1] = $2.to_i
|
|
end
|
|
status
|
|
end
|
|
end
|
|
end
|