Skip to content

Instantly share code, notes, and snippets.

@dpsk
Created December 7, 2011 10:55
Show Gist options
  • Save dpsk/1442395 to your computer and use it in GitHub Desktop.
Save dpsk/1442395 to your computer and use it in GitHub Desktop.
speed up RSpec tests by patcihng Ruby GC. 600 specs, time fall from 490 secs to 240(ruby 1.9.3)
RSpec.configure do |config|
config.before(:all) do
DeferredGarbageCollection.start
end
config.after(:all) do
DeferredGarbageCollection.reconsider
end
end
class DeferredGarbageCollection
DEFERRED_GC_THRESHOLD = (ENV['DEFER_GC'] || 15.0).to_f
@@last_gc_run = Time.now
def self.start
GC.disable if DEFERRED_GC_THRESHOLD > 0
end
def self.reconsider
if DEFERRED_GC_THRESHOLD > 0 && Time.now - @@last_gc_run >= DEFERRED_GC_THRESHOLD
GC.enable
GC.start
GC.disable
@@last_gc_run = Time.now
end
end
end
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment