bleak_house 4.6 → 5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,30 @@
1
+ Index: gc.c
2
+ ===================================================================
3
+ RCS file: /src/ruby/gc.c,v
4
+ retrieving revision 1.168.2.45
5
+ diff -p -u -r1.168.2.45 gc.c
6
+ --- gc.c 25 Aug 2006 08:12:46 -0000 1.168.2.45
7
+ +++ gc.c 31 Aug 2006 18:47:55 -0000
8
+ @@ -323,6 +323,22 @@ static struct heaps_slot {
9
+ static int heaps_length = 0;
10
+ static int heaps_used = 0;
11
+
12
+ +struct heaps_slot *
13
+ +rb_gc_heap_slots()
14
+ +{
15
+ + return heaps;
16
+ +}
17
+ +
18
+ +int
19
+ +rb_gc_heaps_used() {
20
+ + return heaps_used;
21
+ +}
22
+ +
23
+ +int
24
+ +rb_gc_heaps_length() {
25
+ + return heaps_length;
26
+ +}
27
+ +
28
+ #define HEAP_MIN_SLOTS 10000
29
+ static int heap_slots = HEAP_MIN_SLOTS;
30
+
@@ -0,0 +1,14 @@
1
+
2
+ namespace :bleak_house do
3
+ desc 'Analyze and chart all data'
4
+ task :analyze do
5
+ begin
6
+ gem 'gruff', '= 0.2.8'
7
+ require "#{File.dirname(__FILE__)}/../lib/bleak_house/analyze"
8
+ rescue LoadError
9
+ require 'bleak_house/analyze'
10
+ end
11
+ BleakHouse::Analyze.build_all("#{RAILS_ROOT}/log/bleak_house_#{RAILS_ENV}.dump")
12
+ end
13
+ end
14
+
@@ -1,58 +1,48 @@
1
1
 
2
- $LOAD_PATH.unshift(File.dirname(__FILE__) + "/../../lib")
2
+ DIR = File.dirname(__FILE__) + "/../../"
3
3
 
4
- ENV['NO_EXIT_HANDLER'] = "1"
5
-
6
- require 'bleak_house'
7
4
  require 'rubygems'
8
- require 'echoe'
9
5
  require 'test/unit'
10
-
6
+ require 'yaml'
7
+
11
8
  class BleakHouseTest < Test::Unit::TestCase
9
+ require "#{DIR}lib/bleak_house/mem_logger"
10
+ require "#{DIR}lib/bleak_house/c"
11
+ require "#{DIR}lib/bleak_house/ruby"
12
12
 
13
- # Match the default hook filename, for convenience
14
- FILE = "/tmp/bleak.#{Process.pid}.000.dump"
13
+ SNAPSHOT_FILE = "/tmp/bleak_house"
14
+ SNAPS = {:c => SNAPSHOT_FILE + ".c.yaml",
15
+ :ruby => SNAPSHOT_FILE + ".rb.yaml"}
15
16
 
16
17
  def setup
17
- File.delete FILE rescue nil
18
- end
19
-
20
- def test_snapshot
21
- BleakHouse.snapshot(FILE)
22
- assert File.exist?(FILE)
23
- assert BleakHouse.heaps_used > 0
24
- assert BleakHouse.heaps_length > 0
25
18
  end
26
19
 
27
- def test_snapshot_gc_runs
28
- BleakHouse.snapshot(FILE, 0)
29
- assert File.exist?(FILE)
30
- assert BleakHouse.heaps_used > 0
31
- assert BleakHouse.heaps_length > 0
20
+ def test_mem_inspect
21
+ assert `ruby-bleak-house -rrubygems -e "require 'mem_inspect'; puts 'ok'"` == "ok\n"
32
22
  end
33
-
34
- def test_exception
35
- assert_raises(RuntimeError) do
36
- BleakHouse.snapshot("/")
23
+
24
+ def test_ruby_snapshot
25
+ File.delete SNAPS[:ruby] rescue nil
26
+ ::BleakHouse::RubyLogger.new.snapshot(SNAPS[:ruby], "ruby_test", true)
27
+ assert File.exist?(SNAPS[:ruby])
28
+ assert_nothing_raised do
29
+ assert YAML.load_file(SNAPS[:ruby]).is_a?(Array)
37
30
  end
38
31
  end
39
-
40
- def test_analyze
41
- BleakHouse.snapshot(FILE)
42
- Dir.chdir(File.dirname(__FILE__) + "/../../bin") do
43
- output = `./bleak #{FILE}`.split("\n")
44
- # require 'ruby-debug/debugger'
45
- assert_match(/top 20 most common/, output[0])
46
- assert_match(/free heap/, output[3])
47
- assert_match(/\d+ __null__:__null__:__node__/, output[5])
32
+
33
+ def test_c_snapshot
34
+ File.delete SNAPS[:c] rescue nil
35
+ ::BleakHouse::CLogger.new.snapshot(SNAPS[:c], "c_test", true)
36
+ assert File.exist?(SNAPS[:c])
37
+ assert_nothing_raised do
38
+ assert YAML.load_file(SNAPS[:c]).is_a?(Array)
48
39
  end
49
40
  end
50
-
51
- def test_signal
52
- Echoe.silence do
53
- system("kill -s SIGUSR2 #{Process.pid}")
54
- end
55
- assert File.exist?(FILE)
41
+
42
+ def test_c_raises
43
+ assert_raises(RuntimeError) do
44
+ ::BleakHouse::CLogger.new.snapshot("/", "c_test", true)
45
+ end
56
46
  end
57
-
47
+
58
48
  end
metadata CHANGED
@@ -1,112 +1,92 @@
1
1
  --- !ruby/object:Gem::Specification
2
+ rubygems_version: 0.9.2
3
+ specification_version: 1
2
4
  name: bleak_house
3
5
  version: !ruby/object:Gem::Version
4
- version: "4.6"
5
- platform: ruby
6
- authors:
7
- - Evan Weaver
6
+ version: "5"
7
+ date: 2007-05-06 00:00:00 -04:00
8
+ summary: BleakHouse is a Rails plugin for finding memory leaks. It tracks ObjectSpace for your entire app, and produces charts of references by controller, by action, and by object class.
9
+ require_paths:
10
+ - lib
11
+ email: evan at cloudbur dot st
12
+ homepage: http://blog.evanweaver.com
13
+ rubyforge_project: fauna
14
+ description: BleakHouse is a Rails plugin for finding memory leaks. It tracks ObjectSpace for your entire app, and produces charts of references by controller, by action, and by object class.
8
15
  autorequire:
9
- bindir: bin
10
- cert_chain:
11
- - |
12
- -----BEGIN CERTIFICATE-----
13
- MIIDLjCCAhagAwIBAgIBADANBgkqhkiG9w0BAQUFADA9MQ0wCwYDVQQDDARldmFu
14
- MRgwFgYKCZImiZPyLGQBGRYIY2xvdWRidXIxEjAQBgoJkiaJk/IsZAEZFgJzdDAe
15
- Fw0wNzA5MTYxMDMzMDBaFw0wODA5MTUxMDMzMDBaMD0xDTALBgNVBAMMBGV2YW4x
16
- GDAWBgoJkiaJk/IsZAEZFghjbG91ZGJ1cjESMBAGCgmSJomT8ixkARkWAnN0MIIB
17
- IjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA5C0Io89nyApnr+PvbNFge9Vs
18
- yRWAlGBUEMahpXp28VrrfXZT0rAW7JBo4PlCE3jl4nE4dzE6gAdItSycjTosrw7A
19
- Ir5+xoyl4Vb35adv56TIQQXvNz+BzlqnkAY5JN0CSBRTQb6mxS3hFyD/h4qgDosj
20
- R2RFVzHqSxCS8xq4Ny8uzOwOi+Xyu4w67fI5JvnPvMxqrlR1eaIQHmxnf76RzC46
21
- QO5QhufjAYGGXd960XzbQsQyTDUYJzrvT7AdOfiyZzKQykKt8dEpDn+QPjFTnGnT
22
- QmgJBX5WJN0lHF2l1sbv3gh4Kn1tZu+kTUqeXY6ShAoDTyvZRiFqQdwh8w2lTQID
23
- AQABozkwNzAJBgNVHRMEAjAAMAsGA1UdDwQEAwIEsDAdBgNVHQ4EFgQU+WqJz3xQ
24
- XSea1hRvvHWcIMgeeC4wDQYJKoZIhvcNAQEFBQADggEBAGLZ75jfOEW8Nsl26CTt
25
- JFrWxQTcQT/UljeefVE3xYr7lc9oQjbqO3FOyued3qW7TaNEtZfSHoYeUSMYbpw1
26
- XAwocIPuSRFDGM4B+hgQGVDx8PMGiJKom4qLXjO40UZsR7QyN/u869Vj45LURm6h
27
- MBcPeqCASI+WNprj9+uZa2kmHiitrFqqfMBNlm5IFbn9XeYSta9AHVvs5QQqV2m5
28
- hIPfLqCyxsn/YgOGvo6iwyQTWyTswamaAC3HRWZxIS1sfn/Ssqa7E7oQMkv5FAXr
29
- x5rKePfXINf8XTJczkl9OBEYdE9aNdJsJpXD0asLgGVwBICS5Bjohp6mizJcDC1+
30
- yZ0=
31
- -----END CERTIFICATE-----
32
-
33
- date: 2009-10-02 00:00:00 -07:00
34
16
  default_executable:
35
- dependencies: []
36
-
37
- description: A library for finding memory leaks.
38
- email: ""
39
- executables:
40
- - bleak
41
- extensions:
42
- - ext/extconf.rb
43
- extra_rdoc_files:
44
- - CHANGELOG
45
- - LICENSE
46
- - LICENSE_BSD
47
- - README
48
- - TODO
49
- - ext/snapshot.c
50
- - lib/bleak_house.rb
51
- - lib/bleak_house/analyzer.rb
52
- - lib/bleak_house/hook.rb
53
- files:
54
- - CHANGELOG
55
- - LICENSE
56
- - LICENSE_BSD
57
- - Manifest
58
- - README
59
- - Rakefile
60
- - TODO
61
- - bin/bleak
62
- - ext/build_ruby.rb
63
- - ext/build_snapshot.rb
64
- - ext/extconf.rb
65
- - ext/snapshot.c
66
- - ext/snapshot.h
67
- - lib/bleak_house.rb
68
- - lib/bleak_house/analyzer.rb
69
- - lib/bleak_house/hook.rb
70
- - ruby/ruby-1.8.7-p174.tar.bz2
71
- - ruby/ruby-1.8.7.patch
72
- - test/benchmark/bench.rb
73
- - test/test_helper.rb
74
- - test/unit/test_bleak_house.rb
75
- - bleak_house.gemspec
17
+ bindir: bin
76
18
  has_rdoc: true
77
- homepage: http://blog.evanweaver.com/files/doc/fauna/bleak_house/
78
- licenses: []
79
-
80
- post_install_message:
81
- rdoc_options:
82
- - --line-numbers
83
- - --inline-source
84
- - --title
85
- - Bleak_house
86
- - --main
87
- - README
88
- require_paths:
89
- - lib
90
- - ext
91
- required_ruby_version: !ruby/object:Gem::Requirement
19
+ required_ruby_version: !ruby/object:Gem::Version::Requirement
92
20
  requirements:
93
- - - ">="
21
+ - - ">"
94
22
  - !ruby/object:Gem::Version
95
- version: "0"
96
- version:
97
- required_rubygems_version: !ruby/object:Gem::Requirement
98
- requirements:
99
- - - ">="
100
- - !ruby/object:Gem::Version
101
- version: "1.2"
23
+ version: 0.0.0
102
24
  version:
25
+ platform: ruby
26
+ signing_key:
27
+ cert_chain:
28
+ post_install_message: |+
29
+
30
+ Thanks for installing Bleak House 5.
31
+
32
+ For each Rails app you want to profile, you will need to add the following
33
+ rake task in RAILS_ROOT/lib/tasks/bleak_house_tasks.rake to be able to run
34
+ the analyzer:
35
+
36
+ namespace :bleak_house do
37
+ desc 'Analyze and chart all data'
38
+ task :analyze do
39
+ rescue LoadError
40
+ end
41
+ BleakHouse::Analyze.build_all("#{RAILS_ROOT}/log/bleak_house_#{RAILS_ENV}.dump")
42
+ end
43
+ end
44
+
45
+
46
+ authors:
47
+ - Evan Weaver
48
+ files:
49
+ - ./CHANGELOG
50
+ - ./LICENSE_AFL
51
+ - ./Manifest
52
+ - ./README
53
+ - ./Rakefile
54
+ - ./init.rb
55
+ - ./install.rb
56
+ - ./lib/bleak_house/LICENSE_BSD
57
+ - ./lib/bleak_house/action_controller.rb
58
+ - ./lib/bleak_house/analyze.rb
59
+ - ./lib/bleak_house/bleak_house.rb
60
+ - ./lib/bleak_house/c.rb
61
+ - ./lib/bleak_house/dispatcher.rb
62
+ - ./lib/bleak_house/gruff_hacks.rb
63
+ - ./lib/bleak_house/mem_logger.rb
64
+ - ./lib/bleak_house/rake_task_redefine_task.rb
65
+ - ./lib/bleak_house/ruby.rb
66
+ - ./lib/bleak_house/support_methods.rb
67
+ - ./lib/bleak_house.rb
68
+ - ./patches/gc.c.patch
69
+ - ./tasks/bleak_house_tasks.rake
70
+ - ./test/unit/test_bleak_house.rb
71
+ test_files: []
72
+
73
+ rdoc_options: []
74
+
75
+ extra_rdoc_files: []
76
+
77
+ executables: []
78
+
79
+ extensions: []
80
+
103
81
  requirements: []
104
82
 
105
- rubyforge_project: fauna
106
- rubygems_version: 1.3.4
107
- signing_key:
108
- specification_version: 3
109
- summary: A library for finding memory leaks.
110
- test_files:
111
- - test/test_helper.rb
112
- - test/unit/test_bleak_house.rb
83
+ dependencies:
84
+ - !ruby/object:Gem::Dependency
85
+ name: RubyInline
86
+ version_requirement:
87
+ version_requirements: !ruby/object:Gem::Version::Requirement
88
+ requirements:
89
+ - - ">"
90
+ - !ruby/object:Gem::Version
91
+ version: 0.0.0
92
+ version:
data.tar.gz.sig DELETED
Binary file
data/TODO DELETED
@@ -1,10 +0,0 @@
1
-
2
- * Figure out why Rubygems 1.2.0 is a hard requirement
3
-
4
- * Override Kernel#eval to always include sourceline macros.
5
- * Mimic Valgrind's output format as much as possible
6
- * Log remaining heap reference traces
7
- * Add some kind of start/end delta support
8
- * Log entire backtrace by allocating pointer arrays on the heap
9
- - Add some kind of hashing procedure to avoid duplicating identical backtrace pointer arrays
10
- * Report individual types of nodes
data/bin/bleak DELETED
@@ -1,13 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- require 'rubygems'
4
-
5
- if !ARGV[0]
6
- puts "Please specify up to two BleakHouse logfiles"
7
- exit
8
- else
9
- $LOAD_PATH << "#{File.dirname(__FILE__)}/../lib/"
10
- require 'bleak_house/analyzer'
11
- require 'ruby-debug' if ENV['DEBUG']
12
- BleakHouse::Analyzer.run(*ARGV)
13
- end
@@ -1,36 +0,0 @@
1
- # -*- encoding: utf-8 -*-
2
-
3
- Gem::Specification.new do |s|
4
- s.name = %q{bleak_house}
5
- s.version = "4.6"
6
-
7
- s.required_rubygems_version = Gem::Requirement.new(">= 1.2") if s.respond_to? :required_rubygems_version=
8
- s.authors = ["Evan Weaver"]
9
- s.cert_chain = ["/Users/eweaver/p/configuration/gem_certificates/evan_weaver-original-public_cert.pem"]
10
- s.date = %q{2009-10-02}
11
- s.default_executable = %q{bleak}
12
- s.description = %q{A library for finding memory leaks.}
13
- s.email = %q{}
14
- s.executables = ["bleak"]
15
- s.extensions = ["ext/extconf.rb"]
16
- s.extra_rdoc_files = ["CHANGELOG", "LICENSE", "LICENSE_BSD", "README", "TODO", "ext/snapshot.c", "lib/bleak_house.rb", "lib/bleak_house/analyzer.rb", "lib/bleak_house/hook.rb"]
17
- s.files = ["CHANGELOG", "LICENSE", "LICENSE_BSD", "Manifest", "README", "Rakefile", "TODO", "bin/bleak", "ext/build_ruby.rb", "ext/build_snapshot.rb", "ext/extconf.rb", "ext/snapshot.c", "ext/snapshot.h", "lib/bleak_house.rb", "lib/bleak_house/analyzer.rb", "lib/bleak_house/hook.rb", "ruby/ruby-1.8.7-p174.tar.bz2", "ruby/ruby-1.8.7.patch", "test/benchmark/bench.rb", "test/test_helper.rb", "test/unit/test_bleak_house.rb", "bleak_house.gemspec"]
18
- s.homepage = %q{http://blog.evanweaver.com/files/doc/fauna/bleak_house/}
19
- s.rdoc_options = ["--line-numbers", "--inline-source", "--title", "Bleak_house", "--main", "README"]
20
- s.require_paths = ["lib", "ext"]
21
- s.rubyforge_project = %q{fauna}
22
- s.rubygems_version = %q{1.3.4}
23
- s.signing_key = %q{/Users/eweaver/p/configuration/gem_certificates/evan_weaver-original-private_key.pem}
24
- s.summary = %q{A library for finding memory leaks.}
25
- s.test_files = ["test/test_helper.rb", "test/unit/test_bleak_house.rb"]
26
-
27
- if s.respond_to? :specification_version then
28
- current_version = Gem::Specification::CURRENT_SPECIFICATION_VERSION
29
- s.specification_version = 3
30
-
31
- if Gem::Version.new(Gem::RubyGemsVersion) >= Gem::Version.new('1.2.0') then
32
- else
33
- end
34
- else
35
- end
36
- end
@@ -1,114 +0,0 @@
1
-
2
- # Extension abuse in order to build our patched binary as part of the gem install process.
3
-
4
- raise "Windows is not supported." if RUBY_PLATFORM =~ /win32|windows/
5
-
6
- source_dir = File.expand_path(File.dirname(__FILE__)) + "/../ruby"
7
- tmp = "/tmp/"
8
-
9
- require 'fileutils'
10
- require 'rbconfig'
11
-
12
- def execute(command)
13
- puts command
14
- unless system(command)
15
- puts "Failed: #{command.inspect}"
16
- exit -1
17
- end
18
- end
19
-
20
- def which(basename)
21
- # execute('which') is not compatible across Linux and BSD
22
- ENV['PATH'].split(File::PATH_SEPARATOR).detect do |directory|
23
- path = File.join(directory, basename.to_s)
24
- path if File.exist? path
25
- end
26
- end
27
-
28
- if which('ruby-bleak-house') and
29
- (patchlevel = `ruby-bleak-house -e "puts RUBY_PATCHLEVEL"`.to_i) >= 905
30
- puts "** Binary `ruby-bleak-house` is already available (patchlevel #{patchlevel})"
31
- else
32
- # Build
33
- Dir.chdir(tmp) do
34
- build_dir = "bleak_house"
35
-
36
- FileUtils.rm_rf(build_dir) rescue nil
37
- if File.exist? build_dir
38
- raise "Could not delete previous build dir #{Dir.pwd}/#{build_dir}"
39
- end
40
-
41
- Dir.mkdir(build_dir)
42
-
43
- begin
44
- Dir.chdir(build_dir) do
45
-
46
- puts "** Copy Ruby source"
47
- bz2 = "ruby-1.8.7-p174.tar.bz2"
48
- FileUtils.copy "#{source_dir}/#{bz2}", bz2
49
-
50
- puts "** Extract"
51
- execute("tar xjf #{bz2}")
52
- File.delete bz2
53
-
54
- Dir.chdir("ruby-1.8.7-p174") do
55
-
56
- puts "** Patch Ruby"
57
- execute("patch -p1 < '#{source_dir}/ruby-1.8.7.patch'")
58
-
59
- env = Config::CONFIG.map do |key, value|
60
- "#{key}=#{value.inspect}" if key.upcase == key and value
61
- end.compact.join(" ")
62
-
63
- puts "** Configure"
64
-
65
- args = Config::CONFIG['configure_args']
66
- args.sub("'--enable-shared'", "")
67
- args << " --disable-shared"
68
- args << " --enable-valgrind" if which("valgrind")
69
- execute("env #{env} ./configure #{args}")
70
-
71
- puts "Patch Makefile"
72
- # FIXME Why is this necessary?
73
- makefile = File.read('Makefile')
74
- %w{arch sitearch sitedir}.each do | key |
75
- makefile.gsub!(/#{key} = .*/, "#{key} = #{Config::CONFIG[key]}")
76
- end
77
- File.open('Makefile', 'w'){|f| f.puts(makefile)}
78
-
79
- puts "Patch config.h"
80
- constants = {
81
- 'RUBY_LIB' => 'rubylibdir',
82
- 'RUBY_SITE_LIB' => 'sitedir',
83
- 'RUBY_SITE_LIB2' => 'sitelibdir',
84
- 'RUBY_PLATFORM' => 'arch',
85
- 'RUBY_ARCHLIB' => 'topdir',
86
- 'RUBY_SITE_ARCHLIB' => 'sitearchdir'
87
- }
88
- config_h = File.read('config.h')
89
- constants.each do | const, key |
90
- config_h.gsub!(/#define #{const} .*/, "#define #{const} \"#{Config::CONFIG[key]}\"")
91
- end
92
- File.open('config.h', 'w') do |f|
93
- f.puts(config_h)
94
- end
95
-
96
- puts "** Make"
97
- execute("env #{env} make")
98
-
99
- bleak_binary = "#{Config::CONFIG['bindir']}/ruby-bleak-house"
100
- ruby_binary = Config::CONFIG["RUBY_INSTALL_NAME"] || "ruby"
101
-
102
- puts "** Install binary"
103
- raise unless File.exist? ruby_binary
104
- File.delete bleak_binary if File.exist? bleak_binary # Avoid "Text file busy" error
105
- exec("cp ./#{ruby_binary} #{bleak_binary}; chmod 755 #{bleak_binary}")
106
- end
107
-
108
- end
109
- end
110
-
111
- puts "Success"
112
- end
113
-
114
- end