Skip to content

Commit

Permalink
Merge pull request #67 from JoeMcB/flush-class-memoizations
Browse files Browse the repository at this point in the history
Add support for class-level cache flushing.
  • Loading branch information
matthewrudy authored Jun 20, 2017
2 parents fb82fd1 + 111b6c4 commit 9d29d19
Show file tree
Hide file tree
Showing 2 changed files with 60 additions and 3 deletions.
3 changes: 2 additions & 1 deletion lib/memoist.rb
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,8 @@ def unmemoize_all
end

def memoized_structs(names)
structs = self.class.all_memoized_structs
ref_obj = self.class.respond_to?(:class_eval) ? self.singleton_class : self
structs = ref_obj.all_memoized_structs
return structs if names.empty?

structs.select { |s| names.include?(s.memoized_method) }
Expand Down
60 changes: 58 additions & 2 deletions test/memoist_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -181,6 +181,33 @@ def counter
memoize :counter
end

class Book
extend Memoist
STATUSES = %w(new used)
CLASSIFICATION = %w(fiction nonfiction)
GENRES = %w(humor romance reference sci-fi classic philosophy)

attr_reader :title, :author
def initialize(title, author)
@title = title
@author = author
end

def full_title
"#{@title} by #{@author}"
end
memoize :full_title

class << self
extend Memoist

def all_types
STATUSES.product(CLASSIFICATION).product(GENRES).collect { |a| a.flatten }
end
memoize :all_types
end
end

class Abb
extend Memoist

Expand All @@ -206,11 +233,10 @@ def some_method
memoize :some_method
end



def setup
@person = Person.new
@calculator = Calculator.new
@book = Book.new("My Life", "Brian 'Fudge' Turmuck")
end

def test_memoization
Expand Down Expand Up @@ -283,6 +309,26 @@ def test_flush_cache
assert_equal 2, @calculator.counter
end

def test_class_flush_cache
@book.memoize_all
assert_equal "My Life by Brian 'Fudge' Turmuck", @book.full_title

Book.memoize_all
assert_instance_of Array, Book.instance_variable_get(:@_memoized_all_types)
Book.flush_cache
assert_equal false, Book.instance_variable_defined?(:@_memoized_all_types)
end

def test_class_flush_cache_preserves_instances
@book.memoize_all
Book.memoize_all
assert_equal "My Life by Brian 'Fudge' Turmuck", @book.full_title

Book.flush_cache
assert_equal false, Book.instance_variable_defined?(:@_memoized_all_types)
assert_equal "My Life by Brian 'Fudge' Turmuck", @book.full_title
end

def test_flush_cache_in_child_class
x = Bbb.new

Expand Down Expand Up @@ -376,6 +422,16 @@ def test_memoization_cache_is_different_for_each_instance
assert_equal 1, Calculator.new.counter
end

def test_memoization_class_variables
@book.memoize_all
assert_equal "My Life by Brian 'Fudge' Turmuck", @book.instance_variable_get(:@_memoized_full_title)
assert_equal "My Life by Brian 'Fudge' Turmuck", @book.full_title

Book.memoize_all
assert_instance_of Array, Book.instance_variable_get(:@_memoized_all_types)
assert_equal 24, Book.all_types.count
end

def test_memoized_is_not_affected_by_freeze
@person.freeze
assert_equal "Josh", @person.name
Expand Down

0 comments on commit 9d29d19

Please sign in to comment.