-
Notifications
You must be signed in to change notification settings - Fork 66
/
Copy pathfixtures.rb
173 lines (141 loc) · 3.78 KB
/
fixtures.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
require 'multi_json'
# Dummy api
class JSONParser < Faraday::Middleware
def on_complete(env)
json = MultiJson.load(env.body, symbolize_keys: true)
env.body = {
data: json[:result],
metadata: json[:metadata],
errors: json[:errors]
}
rescue MultiJson::ParseError => exception
env.body = { errors: { base: [ error: exception.message ] } }
end
end
Spyke::Base.connection = Faraday.new(url: 'http://sushi.com') do |faraday|
faraday.request :multipart
faraday.request :json
faraday.use JSONParser
faraday.adapter Faraday.default_adapter
end
# Test classes
class Recipe < Spyke::Base
has_many :groups
has_many :gallery_images, class_name: 'Image'
has_one :image
has_many :step_images
has_one :background_image, class_name: 'Image', uri: nil
has_one :alternate, class_name: 'Recipe', uri: 'recipes/:recipe_id/alternates/recipe'
belongs_to :user
scope :published, -> { where(status: 'published') }
scope :approved, -> { where(approved: true) }
attributes :title, :description
before_save :before_save_callback
before_create :before_create_callback
before_update :before_update_callback
accepts_nested_attributes_for :image, :user, :groups
def self.page(number = nil)
result = all
result = result.where(page: number) if number
result
end
def description
super
end
def ingredients
groups.flat_map(&:ingredients)
end
private
def before_create_callback; end
def before_update_callback; end
def before_save_callback; end
end
class Image < Spyke::Base
method_for :create, :put
attributes :description, :caption
end
class StepImage < Image
include_root_in_json 'step_image_root'
attributes :note
end
class RecipeImage < Image
uri 'recipes/:recipe_id/image'
validates :url, presence: true
attributes :url
include_root_in_json false
end
class Group < Spyke::Base
has_many :ingredients, uri: nil
has_many :featured_ingredients, uri: 'featured_ingredients?filter[group_id]=:group_id', class_name: "Ingredient"
accepts_nested_attributes_for :ingredients
def self.build_default
group_1 = build(name: 'Condiments')
group_1.ingredients.build(name: 'Salt')
group_2 = build(name: 'Tools')
group_2.ingredients.build(name: 'Spoon')
end
end
class Ingredient < Spyke::Base
uri 'recipes/:recipe_id/ingredients/(:id)'
end
class User < Spyke::Base
self.primary_key = :uuid
has_many :recipes
end
class Photo < Spyke::Base
uri 'images/photos/(:id)'
end
class Comment < Spyke::Base
belongs_to :user
has_many :users
scope :approved, -> { where(comment_approved: true) }
accepts_nested_attributes_for :users
end
class OtherApi < Spyke::Base
self.connection = Faraday.new(url: 'http://sashimi.com') do |faraday|
faraday.use JSONParser
faraday.adapter Faraday.default_adapter
end
end
class OtherRecipe < OtherApi
uri 'recipes/(:id)'
def self.request(method, path, params)
super
rescue Spyke::ConnectionError
Recipe.request(method, path, params)
end
end
class Search
def initialize(query)
@query = query
end
def recipes
@recipes ||= Recipe.where(query: @query)
end
def suggestions
recipes.metadata[:suggestions]
end
end
module Cookbook
class Tip < Spyke::Base
uri 'tips/(:id)'
has_many :likes, class_name: 'Cookbook::Like'
has_many :favorites
has_many :votes
has_many :photos, class_name: 'Photo'
end
class Like < Spyke::Base
belongs_to :tip
end
class Favorite < Spyke::Base
end
class Photo < Spyke::Base
include_root_in_json :foto
end
end
class RecipeWithDirty < Recipe
# NOTE: Simply including ActiveModel::Dirty doesn't provide all the dirty
# functionality. This is left intentionally incomplete as it's all we need
# for testing compatibility.
include ActiveModel::Dirty
end