Skip to content

Commit

Permalink
Merge pull request #1298 from bf4/better_poro_test
Browse files Browse the repository at this point in the history
RFC: Better Poro Resource Test
  • Loading branch information
lgebhardt authored Dec 11, 2019
2 parents 52e52d2 + 95393cd commit 08edbc8
Showing 1 changed file with 90 additions and 17 deletions.
107 changes: 90 additions & 17 deletions test/fixtures/active_record.rb
Original file line number Diff line number Diff line change
Expand Up @@ -1546,37 +1546,118 @@ class PoroResource < JSONAPI::BasicResource
root_resource

class << self
def find_records(filters, options)
fail NotImplementedError, <<~EOF
Should be something like
def find_records(filters, options)
breeds = []
id_filter = filters[:id]
id_filter = [id_filter] unless id_filter.nil? || id_filter.is_a?(Array)
$breed_data.breeds.values.each do |breed|
breeds.push(breed) unless id_filter && !id_filter.include?(breed.id)
end
breeds
end
EOF
end

def find_record_by_key(key, options = {})
fail NotImplementedError, <<~EOF
Should be something like
def find_record_by_key(key, options = {})
$breed_data.breeds[key.to_i]
end
EOF
end

def find_records_by_keys(keys, options = {})
fail NotImplementedError, <<~EOF
Should be something like
def find_records_by_keys(keys, options = {})
breeds = []
keys.each do |key|
breeds.push($breed_data.breeds[key.to_i])
end
breeds
end
EOF
end

# Finds Resources using the `filters`. Pagination and sort options are used when provided
#
# @param filters [Hash] the filters hash
# @option options [Hash] :context The context of the request, set in the controller
# @option options [Hash] :sort_criteria The `sort criteria`
# @option options [Hash] :include_directives The `include_directives`
#
# @return [Array<Resource>] the Resource instances matching the filters, sorting and pagination rules.
def find(filters, options = {})
records = find_breeds(filters, options)
records = find_records(filters, options)
resources_for(records, options[:context])
end

# Records
def find_fragments(filters, options = {})
fragments = {}
find_breeds(filters, options).each do |breed|
rid = JSONAPI::ResourceIdentity.new(BreedResource, breed.id)
find_records(filters, options).each do |record|
rid = JSONAPI::ResourceIdentity.new(resource_klass, record.id)
fragments[rid] = JSONAPI::ResourceFragment.new(rid)
end
fragments
end

def resource_klass
self
end

# Counts Resources found using the `filters`
#
# @param filters [Hash] the filters hash
# @option options [Hash] :context The context of the request, set in the controller
#
# @return [Integer] the count
def count(filters, options = {})
fail NotImplementedError, <<~EOF
Should be something like
def count(filters, options)
0
end
EOF
end

# Returns the single Resource identified by `key`
#
# @param key the primary key of the resource to find
# @option options [Hash] :context The context of the request, set in the controller
def find_by_key(key, options = {})
record = find_breed_by_key(key, options)
record = find_record_by_key(key, options)
resource_for(record, options[:context])
end

def find_to_populate_by_keys(keys, options = {})
find_by_keys(keys, options)
end

# Returns an array of Resources identified by the `keys` array
#
# @param keys [Array<key>] Array of primary keys to find resources for
# @option options [Hash] :context The context of the request, set in the controller
def find_by_keys(keys, options = {})
records = find_breeds_by_keys(keys, options)
records = find_records_by_keys(keys, options)
resources_for(records, options[:context])
end
end
end

#
def find_breeds(filters, options = {})
class BreedResource < PoroResource

attribute :name, format: :title

# This is unneeded, just here for testing
routing_options param: :id

class << self
def find_records(filters, options = {})
breeds = []
id_filter = filters[:id]
id_filter = [id_filter] unless id_filter.nil? || id_filter.is_a?(Array)
Expand All @@ -1586,26 +1667,18 @@ def find_breeds(filters, options = {})
breeds
end

def find_breed_by_key(key, options = {})
def find_record_by_key(key, options = {})
$breed_data.breeds[key.to_i]
end

def find_breeds_by_keys(keys, options = {})
def find_records_by_keys(keys, options = {})
breeds = []
keys.each do |key|
breeds.push($breed_data.breeds[key.to_i])
end
breeds
end
end
end

class BreedResource < PoroResource

attribute :name, format: :title

# This is unneeded, just here for testing
routing_options param: :id

def _save
super
Expand Down

0 comments on commit 08edbc8

Please sign in to comment.