workarea-api-storefront 4.4.6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (203) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +12 -0
  3. data/README.md +58 -0
  4. data/Rakefile +10 -0
  5. data/app/controllers/workarea/api/storefront/accounts_controller.rb +31 -0
  6. data/app/controllers/workarea/api/storefront/analytics_controller.rb +41 -0
  7. data/app/controllers/workarea/api/storefront/application_controller.rb +65 -0
  8. data/app/controllers/workarea/api/storefront/assets_controller.rb +11 -0
  9. data/app/controllers/workarea/api/storefront/authentication.rb +30 -0
  10. data/app/controllers/workarea/api/storefront/authentication_tokens_controller.rb +50 -0
  11. data/app/controllers/workarea/api/storefront/cart_items_controller.rb +100 -0
  12. data/app/controllers/workarea/api/storefront/carts_controller.rb +47 -0
  13. data/app/controllers/workarea/api/storefront/categories_controller.rb +25 -0
  14. data/app/controllers/workarea/api/storefront/checkouts_controller.rb +117 -0
  15. data/app/controllers/workarea/api/storefront/contacts_controller.rb +20 -0
  16. data/app/controllers/workarea/api/storefront/current_checkout.rb +60 -0
  17. data/app/controllers/workarea/api/storefront/email_signups_controller.rb +15 -0
  18. data/app/controllers/workarea/api/storefront/menus_controller.rb +19 -0
  19. data/app/controllers/workarea/api/storefront/orders_controller.rb +32 -0
  20. data/app/controllers/workarea/api/storefront/pages_controller.rb +14 -0
  21. data/app/controllers/workarea/api/storefront/password_resets_controller.rb +17 -0
  22. data/app/controllers/workarea/api/storefront/products_controller.rb +17 -0
  23. data/app/controllers/workarea/api/storefront/recent_views_controller.rb +46 -0
  24. data/app/controllers/workarea/api/storefront/recommendations_controller.rb +22 -0
  25. data/app/controllers/workarea/api/storefront/saved_addresses_controller.rb +38 -0
  26. data/app/controllers/workarea/api/storefront/saved_credit_cards_controller.rb +54 -0
  27. data/app/controllers/workarea/api/storefront/searches_controller.rb +29 -0
  28. data/app/controllers/workarea/api/storefront/system_content_controller.rb +16 -0
  29. data/app/controllers/workarea/api/storefront/taxons_controller.rb +20 -0
  30. data/app/controllers/workarea/api/storefront/user_activity.rb +36 -0
  31. data/app/controllers/workarea/storefront/application_controller.decorator +12 -0
  32. data/app/helpers/workarea/api/storefront/application_helper.rb +15 -0
  33. data/app/helpers/workarea/api/storefront/checkouts_helper.rb +11 -0
  34. data/app/helpers/workarea/api/storefront/content_blocks_helper.rb +38 -0
  35. data/app/models/workarea/catalog/category.decorator +7 -0
  36. data/app/models/workarea/user/authentication_token.rb +33 -0
  37. data/app/models/workarea/user.decorator +8 -0
  38. data/app/view_models/workarea/api/storefront/search_suggestion_view_model.rb +21 -0
  39. data/app/views/workarea/api/storefront/accounts/_account.json.jbuilder +7 -0
  40. data/app/views/workarea/api/storefront/accounts/create.json.jbuilder +7 -0
  41. data/app/views/workarea/api/storefront/accounts/show.json.jbuilder +1 -0
  42. data/app/views/workarea/api/storefront/assets/show.json.jbuilder +4 -0
  43. data/app/views/workarea/api/storefront/authentication_tokens/_authentication_token.json.jbuilder +2 -0
  44. data/app/views/workarea/api/storefront/authentication_tokens/create.json.jbuilder +1 -0
  45. data/app/views/workarea/api/storefront/authentication_tokens/update.json.jbuilder +1 -0
  46. data/app/views/workarea/api/storefront/cart_items/item.json.jbuilder +9 -0
  47. data/app/views/workarea/api/storefront/carts/index.json.jbuilder +4 -0
  48. data/app/views/workarea/api/storefront/carts/show.json.jbuilder +1 -0
  49. data/app/views/workarea/api/storefront/categories/_category.json.jbuilder +4 -0
  50. data/app/views/workarea/api/storefront/categories/index.json.jbuilder +3 -0
  51. data/app/views/workarea/api/storefront/categories/show.json.jbuilder +30 -0
  52. data/app/views/workarea/api/storefront/checkouts/_shipping_options.json.jbuilder +4 -0
  53. data/app/views/workarea/api/storefront/checkouts/show.json.jbuilder +17 -0
  54. data/app/views/workarea/api/storefront/checkouts/steps/_addresses.json.jbuilder +19 -0
  55. data/app/views/workarea/api/storefront/checkouts/steps/_payment.json.jbuilder +9 -0
  56. data/app/views/workarea/api/storefront/checkouts/steps/_shipping.json.jbuilder +9 -0
  57. data/app/views/workarea/api/storefront/content_blocks/_block.json.jbuilder +7 -0
  58. data/app/views/workarea/api/storefront/email_signups/create.json.jbuilder +2 -0
  59. data/app/views/workarea/api/storefront/email_signups/show.json.jbuilder +4 -0
  60. data/app/views/workarea/api/storefront/facets/_range.json.jbuilder +8 -0
  61. data/app/views/workarea/api/storefront/facets/_terms.json.jbuilder +8 -0
  62. data/app/views/workarea/api/storefront/fulfillments/_fulfillment.json.jbuilder +18 -0
  63. data/app/views/workarea/api/storefront/menus/_menu.json.jbuilder +11 -0
  64. data/app/views/workarea/api/storefront/menus/index.json.jbuilder +3 -0
  65. data/app/views/workarea/api/storefront/menus/show.json.jbuilder +1 -0
  66. data/app/views/workarea/api/storefront/orders/_item.json.jbuilder +26 -0
  67. data/app/views/workarea/api/storefront/orders/_order.json.jbuilder +42 -0
  68. data/app/views/workarea/api/storefront/orders/index.json.jbuilder +4 -0
  69. data/app/views/workarea/api/storefront/orders/show.json.jbuilder +7 -0
  70. data/app/views/workarea/api/storefront/orders/tenders/_credit_card.json.jbuilder +6 -0
  71. data/app/views/workarea/api/storefront/orders/tenders/_store_credit.json.jbuilder +2 -0
  72. data/app/views/workarea/api/storefront/pages/show.json.jbuilder +16 -0
  73. data/app/views/workarea/api/storefront/products/_image_urls.json.jbuilder +5 -0
  74. data/app/views/workarea/api/storefront/products/_product.json.jbuilder +41 -0
  75. data/app/views/workarea/api/storefront/products/show.json.jbuilder +9 -0
  76. data/app/views/workarea/api/storefront/recent_views/show.json.jbuilder +8 -0
  77. data/app/views/workarea/api/storefront/recommendations/show.json.jbuilder +3 -0
  78. data/app/views/workarea/api/storefront/saved_addresses/_saved_address.json.jbuilder +2 -0
  79. data/app/views/workarea/api/storefront/saved_addresses/index.json.jbuilder +4 -0
  80. data/app/views/workarea/api/storefront/saved_addresses/show.json.jbuilder +2 -0
  81. data/app/views/workarea/api/storefront/saved_credit_cards/_card.json.jbuilder +9 -0
  82. data/app/views/workarea/api/storefront/saved_credit_cards/index.json.jbuilder +4 -0
  83. data/app/views/workarea/api/storefront/saved_credit_cards/show.json.jbuilder +2 -0
  84. data/app/views/workarea/api/storefront/searches/index.json.jbuilder +1 -0
  85. data/app/views/workarea/api/storefront/searches/show.json.jbuilder +19 -0
  86. data/app/views/workarea/api/storefront/shared/_address.json.jbuilder +12 -0
  87. data/app/views/workarea/api/storefront/shared/_pagination.json.jbuilder +11 -0
  88. data/app/views/workarea/api/storefront/system_content/show.json.jbuilder +12 -0
  89. data/app/views/workarea/api/storefront/taxons/_taxon.json.jbuilder +10 -0
  90. data/app/views/workarea/api/storefront/taxons/show.json.jbuilder +7 -0
  91. data/app/workers/workarea/remove_authentication_tokens_on_password_changes.rb +19 -0
  92. data/bin/rails +18 -0
  93. data/config/initializers/config.rb +2 -0
  94. data/config/locales/en.yml +13 -0
  95. data/config/routes.rb +41 -0
  96. data/lib/workarea/api/storefront/engine.rb +10 -0
  97. data/lib/workarea/api/storefront.rb +15 -0
  98. data/test/documentation/workarea/api/storefront/accounts_documentation_test.rb +70 -0
  99. data/test/documentation/workarea/api/storefront/analytics_documentation_test.rb +51 -0
  100. data/test/documentation/workarea/api/storefront/assets_documentation_test.rb +32 -0
  101. data/test/documentation/workarea/api/storefront/authentication_documentation_test.rb +84 -0
  102. data/test/documentation/workarea/api/storefront/cart_items_documentation_test.rb +104 -0
  103. data/test/documentation/workarea/api/storefront/carts_documentation_test.rb +121 -0
  104. data/test/documentation/workarea/api/storefront/categories_documentation_test.rb +90 -0
  105. data/test/documentation/workarea/api/storefront/checkouts_documentation_test.rb +142 -0
  106. data/test/documentation/workarea/api/storefront/contacts_documentation_test.rb +39 -0
  107. data/test/documentation/workarea/api/storefront/email_signups_documentation_test.rb +53 -0
  108. data/test/documentation/workarea/api/storefront/menus_documentation_test.rb +67 -0
  109. data/test/documentation/workarea/api/storefront/orders_documentation_test.rb +127 -0
  110. data/test/documentation/workarea/api/storefront/pages_documentation_test.rb +66 -0
  111. data/test/documentation/workarea/api/storefront/password_resets_documentation_test.rb +30 -0
  112. data/test/documentation/workarea/api/storefront/products_documentation_test.rb +64 -0
  113. data/test/documentation/workarea/api/storefront/recent_views_documentation_test.rb +116 -0
  114. data/test/documentation/workarea/api/storefront/recommendations_documentation_test.rb +68 -0
  115. data/test/documentation/workarea/api/storefront/saved_addresses_documentation_test.rb +129 -0
  116. data/test/documentation/workarea/api/storefront/saved_credit_cards_documentation_test.rb +129 -0
  117. data/test/documentation/workarea/api/storefront/searches_documentation_test.rb +88 -0
  118. data/test/documentation/workarea/api/storefront/system_content_documentation_test.rb +66 -0
  119. data/test/documentation/workarea/api/storefront/taxons_documentation_test.rb +37 -0
  120. data/test/documentation/workarea/api/storefront/validation_documentation_test.rb +81 -0
  121. data/test/dummy/Rakefile +7 -0
  122. data/test/dummy/app/assets/config/manifest.js +4 -0
  123. data/test/dummy/app/assets/images/.keep +0 -0
  124. data/test/dummy/app/assets/javascripts/application.js +13 -0
  125. data/test/dummy/app/assets/stylesheets/application.css +15 -0
  126. data/test/dummy/app/controllers/application_controller.rb +3 -0
  127. data/test/dummy/app/controllers/concerns/.keep +0 -0
  128. data/test/dummy/app/helpers/application_helper.rb +2 -0
  129. data/test/dummy/app/jobs/application_job.rb +2 -0
  130. data/test/dummy/app/mailers/.keep +0 -0
  131. data/test/dummy/app/mailers/application_mailer.rb +4 -0
  132. data/test/dummy/app/models/.keep +0 -0
  133. data/test/dummy/app/models/concerns/.keep +0 -0
  134. data/test/dummy/app/views/layouts/application.html.erb +14 -0
  135. data/test/dummy/app/views/layouts/mailer.html.erb +13 -0
  136. data/test/dummy/app/views/layouts/mailer.text.erb +1 -0
  137. data/test/dummy/bin/bundle +3 -0
  138. data/test/dummy/bin/rails +4 -0
  139. data/test/dummy/bin/rake +4 -0
  140. data/test/dummy/bin/setup +34 -0
  141. data/test/dummy/bin/update +29 -0
  142. data/test/dummy/config/application.rb +25 -0
  143. data/test/dummy/config/boot.rb +5 -0
  144. data/test/dummy/config/cable.yml +9 -0
  145. data/test/dummy/config/environment.rb +5 -0
  146. data/test/dummy/config/environments/development.rb +55 -0
  147. data/test/dummy/config/environments/production.rb +86 -0
  148. data/test/dummy/config/environments/test.rb +43 -0
  149. data/test/dummy/config/initializers/application_controller_renderer.rb +6 -0
  150. data/test/dummy/config/initializers/assets.rb +11 -0
  151. data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
  152. data/test/dummy/config/initializers/cookies_serializer.rb +5 -0
  153. data/test/dummy/config/initializers/filter_parameter_logging.rb +4 -0
  154. data/test/dummy/config/initializers/inflections.rb +16 -0
  155. data/test/dummy/config/initializers/mime_types.rb +4 -0
  156. data/test/dummy/config/initializers/new_framework_defaults.rb +21 -0
  157. data/test/dummy/config/initializers/session_store.rb +3 -0
  158. data/test/dummy/config/initializers/workarea.rb +8 -0
  159. data/test/dummy/config/initializers/wrap_parameters.rb +14 -0
  160. data/test/dummy/config/locales/en.yml +23 -0
  161. data/test/dummy/config/puma.rb +47 -0
  162. data/test/dummy/config/routes.rb +6 -0
  163. data/test/dummy/config/secrets.yml +22 -0
  164. data/test/dummy/config/spring.rb +6 -0
  165. data/test/dummy/config.ru +4 -0
  166. data/test/dummy/db/seeds.rb +2 -0
  167. data/test/dummy/log/.keep +0 -0
  168. data/test/dummy/public/404.html +67 -0
  169. data/test/dummy/public/422.html +67 -0
  170. data/test/dummy/public/500.html +66 -0
  171. data/test/dummy/public/apple-touch-icon-precomposed.png +0 -0
  172. data/test/dummy/public/apple-touch-icon.png +0 -0
  173. data/test/dummy/public/favicon.ico +1 -0
  174. data/test/integration/workarea/api/storefront/accounts_integration_test.rb +49 -0
  175. data/test/integration/workarea/api/storefront/analytics_integration_test.rb +36 -0
  176. data/test/integration/workarea/api/storefront/assets_integration_test.rb +24 -0
  177. data/test/integration/workarea/api/storefront/authentication_integration_test.rb +50 -0
  178. data/test/integration/workarea/api/storefront/authentication_tokens_integration_test.rb +87 -0
  179. data/test/integration/workarea/api/storefront/cart_items_integration_test.rb +149 -0
  180. data/test/integration/workarea/api/storefront/carts_integration_test.rb +114 -0
  181. data/test/integration/workarea/api/storefront/categories_integration_test.rb +84 -0
  182. data/test/integration/workarea/api/storefront/checkouts_integration_test.rb +203 -0
  183. data/test/integration/workarea/api/storefront/contacts_integration_test.rb +28 -0
  184. data/test/integration/workarea/api/storefront/email_signups_integration_test.rb +35 -0
  185. data/test/integration/workarea/api/storefront/menus_integration_test.rb +53 -0
  186. data/test/integration/workarea/api/storefront/orders_integration_test.rb +115 -0
  187. data/test/integration/workarea/api/storefront/pages_integration_test.rb +57 -0
  188. data/test/integration/workarea/api/storefront/password_resets_integration_test.rb +20 -0
  189. data/test/integration/workarea/api/storefront/products_integration_test.rb +50 -0
  190. data/test/integration/workarea/api/storefront/recent_views_integration_test.rb +118 -0
  191. data/test/integration/workarea/api/storefront/recommendations_integration_test.rb +51 -0
  192. data/test/integration/workarea/api/storefront/saved_addresses_integration_test.rb +100 -0
  193. data/test/integration/workarea/api/storefront/saved_credit_cards_integration_test.rb +107 -0
  194. data/test/integration/workarea/api/storefront/searches_integration_test.rb +128 -0
  195. data/test/integration/workarea/api/storefront/system_content_integration_test.rb +35 -0
  196. data/test/integration/workarea/api/storefront/taxons_integration_test.rb +44 -0
  197. data/test/integration/workarea/api/storefront/user_carts_integration_test.rb +55 -0
  198. data/test/models/workarea/user/authentication_token_test.rb +30 -0
  199. data/test/support/authentication_test.rb +25 -0
  200. data/test/support/orders_test.rb +18 -0
  201. data/test/test_helper.rb +10 -0
  202. data/workarea-api-storefront.gemspec +18 -0
  203. metadata +277 -0
@@ -0,0 +1,51 @@
1
+ require 'test_helper'
2
+ require 'workarea/api/documentation_test'
3
+
4
+ module Workarea
5
+ module Api
6
+ module Storefront
7
+ class AnalyticsDocumentationTest < DocumentationTest
8
+ resource 'Analytics'
9
+
10
+ def test_and_document_saving_a_category_view
11
+ description 'saving a category view'
12
+ route storefront_api.analytics_category_view_path(category_id: ':category_id')
13
+ explanation 'saving a category view will be reflected in admin reports'
14
+
15
+ record_request do
16
+ post storefront_api.analytics_category_view_path(category_id: '12345')
17
+ assert_equal(200, response.status)
18
+ end
19
+ end
20
+
21
+ def test_and_document_saving_a_product_view
22
+ description 'saving a product view'
23
+ route storefront_api.analytics_product_view_path(product_id: ':product_id')
24
+ explanation 'saving a product view will be reflected in admin reports'
25
+
26
+ record_request do
27
+ post storefront_api.analytics_product_view_path(product_id: '12345')
28
+ assert_equal(200, response.status)
29
+ end
30
+ end
31
+
32
+ def test_and_document_saving_a_search
33
+ description 'Saving a search'
34
+ route storefront_api.analytics_search_path
35
+ explanation <<-EOS
36
+ Saving a search will be reflected in admin reports. This is intended
37
+ to be called once per search performed by a customer.
38
+ EOS
39
+
40
+ record_request do
41
+ post storefront_api.analytics_search_path,
42
+ as: :json,
43
+ params: { q: 'foo', total_results: 5 }
44
+
45
+ assert_equal(200, response.status)
46
+ end
47
+ end
48
+ end
49
+ end
50
+ end
51
+ end
@@ -0,0 +1,32 @@
1
+ require 'test_helper'
2
+ require 'workarea/api/documentation_test'
3
+
4
+ module Workarea
5
+ module Api
6
+ module Storefront
7
+ class AssetsDocumentationTest < DocumentationTest
8
+ resource 'Assets'
9
+
10
+ setup :set_asset
11
+
12
+ def set_asset
13
+ @asset = create_asset(name: 'Summer Sale Callout')
14
+ end
15
+
16
+ def test_and_document_showing_assets
17
+ description 'Showing an asset'
18
+ route storefront_api.asset_path(':id')
19
+ explanation <<-EOS
20
+ Use this endpoint to look up assets stored in Workarea. Often times
21
+ these will be referenced in content blocks.
22
+ EOS
23
+
24
+ record_request do
25
+ get storefront_api.asset_path(@asset)
26
+ assert_equal(200, response.status)
27
+ end
28
+ end
29
+ end
30
+ end
31
+ end
32
+ end
@@ -0,0 +1,84 @@
1
+ require 'test_helper'
2
+ require 'workarea/api/documentation_test'
3
+
4
+ module Workarea
5
+ module Api
6
+ module Storefront
7
+ class AuthenticationDocumentationTest < DocumentationTest
8
+ include AuthenticationTest
9
+
10
+ resource 'Authentication'
11
+
12
+ setup :set_user
13
+
14
+ def set_user
15
+ @user = create_user(password: 'p@assword!')
16
+ end
17
+
18
+ def distance_of_time_in_words(*args)
19
+ ApplicationController.helpers.distance_of_time_in_words(*args)
20
+ end
21
+
22
+ def test_creating_an_authentication_token
23
+ description 'Creating an authentication token'
24
+ route storefront_api.authentication_tokens_path
25
+ explanation <<-EOS
26
+ Creating an authentication token is the first step in user
27
+ authentication. You will use this token to authenticate requests on
28
+ behalf of the user going forward. To get a token you can use to
29
+ authenticate an account, use this endpoint. You'll need the email
30
+ and password from the user, and we'll issue a token that can be used
31
+ to authenticate further requests for that customer. This token will
32
+ expire after #{distance_of_time_in_words(Workarea.config.authentication_token_expiration)}.
33
+ Tokens are also invalidated when a user changes their password. See
34
+ the "using an authentication token" example for how to use an
35
+ authentication token.
36
+ EOS
37
+
38
+ record_request do
39
+ post storefront_api.authentication_tokens_path,
40
+ params: { email: @user.email, password: 'p@assword!' },
41
+ as: :json
42
+
43
+ assert(response.ok?)
44
+ end
45
+ end
46
+
47
+ def test_using_an_authentication_token
48
+ description 'Using an authentication token'
49
+ route storefront_api.account_path
50
+ explanation <<-EOS
51
+ After obtaining an authentication token you can use it to request
52
+ authenticated endpoints by including it in the Authorization header
53
+ on the request, as demonstrated in this example.
54
+ EOS
55
+
56
+ auth = @user.authentication_tokens.create!
57
+
58
+ record_request do
59
+ get storefront_api.account_path,
60
+ headers: { 'HTTP_AUTHORIZATION' => encode_credentials(auth.token) }
61
+
62
+ assert(response.ok?)
63
+ end
64
+ end
65
+
66
+ def test_refreshing_an_authentication_token
67
+ description 'Refreshing an authentication token'
68
+ route storefront_api.authentication_tokens_path
69
+ explanation <<-EOS
70
+ Refreshing an authentication token extends its expiration so that it
71
+ can continue to be used.
72
+ EOS
73
+
74
+ auth = @user.authentication_tokens.create!
75
+
76
+ record_request do
77
+ patch storefront_api.authentication_tokens_path,
78
+ headers: { 'HTTP_AUTHORIZATION' => encode_credentials(auth.token) }
79
+ end
80
+ end
81
+ end
82
+ end
83
+ end
84
+ end
@@ -0,0 +1,104 @@
1
+ require 'test_helper'
2
+ require 'workarea/api/documentation_test'
3
+
4
+ module Workarea
5
+ module Api
6
+ module Storefront
7
+ class CartItemsDocumentationTest < DocumentationTest
8
+ include AuthenticationTest
9
+ include OrdersTest
10
+
11
+ resource 'Cart'
12
+
13
+ setup :set_user, :set_product, :set_order
14
+
15
+ def set_user
16
+ @user = create_user(first_name: 'Susan', last_name: 'Baker')
17
+ @auth = @user.authentication_tokens.create!
18
+ end
19
+
20
+ def set_product
21
+ @product = create_product(
22
+ id: 'VINTEE',
23
+ name: 'Vintage Tee',
24
+ variants: [
25
+ { sku: 'VT001', regular: 5.to_m },
26
+ { sku: 'VT002', regular: 6.to_m }
27
+ ]
28
+ )
29
+
30
+ create_inventory(id: 'VT001', policy: 'standard', available: 2)
31
+ end
32
+
33
+ def set_order
34
+ @order = create_order(user_id: @user.id)
35
+ end
36
+
37
+ def test_and_document_adding_an_item
38
+ description 'Adding an item'
39
+ route storefront_api.cart_items_path(':cart_id')
40
+ explanation <<-EOS
41
+ Adds an item to the cart. Use the create a cart endpoint to get a
42
+ cart_id to use with this endpoint.
43
+ EOS
44
+
45
+ record_request do
46
+ post storefront_api.cart_items_path(@order),
47
+ headers: { 'HTTP_AUTHORIZATION' => encode_credentials(@auth.token) },
48
+ as: :json,
49
+ params: {
50
+ product_id: @product.id,
51
+ sku: @product.skus.first,
52
+ quantity: 2
53
+ }
54
+
55
+ assert_equal(200, response.status)
56
+ end
57
+ end
58
+
59
+ def test_and_document_updating_an_item
60
+ add_item(@order, product_id: @product.id, sku: 'VT001', quantity: 2)
61
+
62
+ description 'Updating an item'
63
+ route storefront_api.cart_item_path(':cart_id', ':id')
64
+ explanation <<-EOS
65
+ Updates an item in the cart. Use the create a cart endpoint to get a
66
+ cart ID to use with this endpoint, and use the adding an item
67
+ endpoint to get an ID for an item.
68
+ EOS
69
+
70
+ record_request do
71
+ patch storefront_api.cart_item_path(@order, @order.items.first),
72
+ headers: { 'HTTP_AUTHORIZATION' => encode_credentials(@auth.token) },
73
+ as: :json,
74
+ params: {
75
+ sku: @product.skus.last,
76
+ quantity: 3
77
+ }
78
+
79
+ assert_equal(200, response.status)
80
+ end
81
+ end
82
+
83
+ def test_and_document_deleting_an_item
84
+ add_item(@order, product_id: @product.id, sku: 'VT001', quantity: 2)
85
+
86
+ description 'Delete an item'
87
+ route storefront_api.cart_item_path(':cart_id', ':id')
88
+ explanation <<-EOS
89
+ Removes an item in the cart. Use the create a cart endpoint to get a
90
+ cart ID to use with this endpoint, and use the adding an item
91
+ endpoint to get an ID for an item.
92
+ EOS
93
+
94
+ record_request do
95
+ delete storefront_api.cart_item_path(@order, @order.items.first),
96
+ headers: { 'HTTP_AUTHORIZATION' => encode_credentials(@auth.token) }
97
+
98
+ assert_equal(200, response.status)
99
+ end
100
+ end
101
+ end
102
+ end
103
+ end
104
+ end
@@ -0,0 +1,121 @@
1
+ require 'test_helper'
2
+ require 'workarea/api/documentation_test'
3
+
4
+ module Workarea
5
+ module Api
6
+ module Storefront
7
+ class CartsDocumentationTest < DocumentationTest
8
+ include AuthenticationTest
9
+ include OrdersTest
10
+
11
+ resource 'Cart'
12
+
13
+ setup :set_user, :set_product, :set_order
14
+
15
+ def set_user
16
+ @user = create_user(first_name: 'Susan', last_name: 'Baker')
17
+ @auth = @user.authentication_tokens.create!
18
+ end
19
+
20
+ def set_product
21
+ @product = create_product(
22
+ id: 'VINTEE',
23
+ name: 'Vintage Tee',
24
+ variants: [
25
+ { sku: 'VT001', regular: 5.to_m },
26
+ { sku: 'VT002', regular: 6.to_m }
27
+ ]
28
+ )
29
+
30
+ create_inventory(id: 'VT001', policy: 'standard', available: 2)
31
+ end
32
+
33
+ def set_order
34
+ @order = create_order(user_id: @user.id)
35
+ add_item(@order, product_id: @product.id, sku: 'VT001', quantity: 2)
36
+ end
37
+
38
+ def test_and_document_listing_carts
39
+ description "Listing user's carts"
40
+ route storefront_api.carts_path
41
+ explanation <<-EOS
42
+ You can get a listing of all of a user's open carts with this
43
+ endpoint. There will usually be one from the standard storefront,
44
+ but with the cart creation endpoint there is the potential to create
45
+ and manage multiple carts for a single user.
46
+ EOS
47
+
48
+ record_request do
49
+ get storefront_api.carts_path,
50
+ headers: { 'HTTP_AUTHORIZATION' => encode_credentials(@auth.token) }
51
+
52
+ assert_equal(200, response.status)
53
+ end
54
+ end
55
+
56
+ def test_and_document_creating_a_guest_cart
57
+ description 'Creating a new guest cart'
58
+ route storefront_api.carts_path
59
+ explanation <<-EOS
60
+ Use this endpoint to create a cart. This allows the possibility of
61
+ multiple carts for a user.
62
+ EOS
63
+
64
+ record_request do
65
+ post storefront_api.carts_path
66
+ assert_equal(200, response.status)
67
+ end
68
+ end
69
+
70
+ def test_and_document_creating_a_logged_in_cart
71
+ description 'Creating a new cart for a user'
72
+ route storefront_api.carts_path
73
+ explanation <<-EOS
74
+ Here's how to create a cart for a user. This endpoint allows the
75
+ possibility of multiple carts for a user.
76
+ EOS
77
+
78
+ record_request do
79
+ post storefront_api.carts_path,
80
+ headers: { 'HTTP_AUTHORIZATION' => encode_credentials(@auth.token) }
81
+
82
+ assert_equal(200, response.status)
83
+ end
84
+ end
85
+
86
+ def test_and_document_showing_a_cart
87
+ description 'Showing cart'
88
+ route storefront_api.cart_path(':id')
89
+ explanation <<-EOS
90
+ This will get details on a cart you've created with the cart
91
+ creation endpoint.
92
+ EOS
93
+
94
+ record_request do
95
+ get storefront_api.cart_path(@order),
96
+ headers: { 'HTTP_AUTHORIZATION' => encode_credentials(@auth.token) }
97
+
98
+ assert_equal(200, response.status)
99
+ end
100
+ end
101
+
102
+ def test_and_document_adding_a_promo_code
103
+ description 'Adding a promo code'
104
+ route storefront_api.add_promo_code_to_cart_path(':id')
105
+ explanation 'This endpoint will add promo codes to the cart'
106
+
107
+ create_order_total_discount(promo_codes: %w(10OFF))
108
+
109
+ record_request do
110
+ post storefront_api.add_promo_code_to_cart_path(@order),
111
+ as: :json,
112
+ headers: { 'HTTP_AUTHORIZATION' => encode_credentials(@auth.token) },
113
+ params: { promo_code: '10OFF' }
114
+
115
+ assert_equal(200, response.status)
116
+ end
117
+ end
118
+ end
119
+ end
120
+ end
121
+ end
@@ -0,0 +1,90 @@
1
+ require 'test_helper'
2
+ require 'workarea/api/documentation_test'
3
+
4
+ module Workarea
5
+ module Api
6
+ module Storefront
7
+ class CategoriesDocumentationTest < DocumentationTest
8
+ resource 'Categories'
9
+
10
+ setup :set_product
11
+ setup :set_category
12
+ setup :set_taxonomy
13
+ setup :set_content
14
+
15
+ def set_product
16
+ @product = create_product(
17
+ name: 'Sweet Shirt',
18
+ filters: { size: %w[Small Medium Large], color: 'Blue' },
19
+ variants: [{ sku: 'SKU', details: { color: 'Blue' }, regular: 2.to_m }],
20
+ details: { size: 'Small', color: 'Red' },
21
+ images: [{ image: product_image_file, option: 'Blue' }]
22
+ )
23
+ end
24
+
25
+ def set_category
26
+ @category = create_category(
27
+ name: 'Shirts',
28
+ product_ids: [@product.id],
29
+ terms_facets: %w(Size Color)
30
+ )
31
+ end
32
+
33
+ def set_taxonomy
34
+ first_level = create_taxon(name: 'Mens')
35
+ @taxon = first_level.children.create!(navigable: @category)
36
+ end
37
+
38
+ def set_content
39
+ content = Content.for(@category)
40
+ content.blocks.build(
41
+ area: :above_results,
42
+ type: :text,
43
+ data: { text: 'text' }
44
+ )
45
+ content.blocks.build(
46
+ area: :below_results,
47
+ type: :text,
48
+ data: { text: 'text' }
49
+ )
50
+ content.save!
51
+ end
52
+
53
+ def test_and_document_index
54
+ description 'Showing a listing of categories'
55
+ route storefront_api.categories_path
56
+ parameter 'page', 'Page number'
57
+ explanation <<-EOS
58
+ This endpoint will give you a paginated list of all active
59
+ categories, that is, all categories that could be shown on the
60
+ storefront.
61
+ EOS
62
+
63
+ create_category(name: 'Pants')
64
+
65
+ record_request do
66
+ get storefront_api.categories_path(page: '1')
67
+ assert_equal(200, response.status)
68
+ end
69
+ end
70
+
71
+ def test_and_document_show
72
+ description 'Showing a category'
73
+ route storefront_api.category_path(':slug')
74
+ parameter 'sort', 'Sort by'
75
+ parameter 'page', 'Page number'
76
+ parameter ':facet_name', 'Each facet setup on the category will have a corresponding parameter'
77
+ explanation <<-EOS
78
+ This endpoint includes everything you need to render a category,
79
+ including any associated content, products, and filters.
80
+ EOS
81
+
82
+ record_request do
83
+ get storefront_api.category_path(@category, page: '1', sort: 'price_desc')
84
+ assert_equal(200, response.status)
85
+ end
86
+ end
87
+ end
88
+ end
89
+ end
90
+ end
@@ -0,0 +1,142 @@
1
+ require 'test_helper'
2
+ require 'workarea/api/documentation_test'
3
+
4
+ module Workarea
5
+ module Api
6
+ module Storefront
7
+ class CheckoutsDocumentationTest < DocumentationTest
8
+ include OrdersTest
9
+
10
+ resource 'Checkout'
11
+
12
+ setup :set_product, :set_order, :set_checkout_data
13
+
14
+ def set_product
15
+ @product = create_product(
16
+ id: 'VINTEE',
17
+ name: 'Vintage Tee',
18
+ variants: [
19
+ { sku: 'VT001', regular: 5.to_m },
20
+ { sku: 'VT002', regular: 6.to_m }
21
+ ]
22
+ )
23
+
24
+ create_inventory(id: 'VT001', policy: 'standard', available: 2)
25
+ end
26
+
27
+ def set_order
28
+ @order = create_order(email: 'sbaker@workarea.com')
29
+ add_item(@order, product_id: @product.id, sku: 'VT001', quantity: 2)
30
+ end
31
+
32
+ def set_checkout_data
33
+ create_shipping_service(name: 'Standard', rates: [{ price: 5.to_m }])
34
+ create_shipping_service(name: 'Express', rates: [{ price: 10.to_m }])
35
+ create_shipping_service(name: 'Overnight', rates: [{ price: 20.to_m }])
36
+ end
37
+
38
+ def address
39
+ {
40
+ first_name: 'Susan',
41
+ last_name: 'Baker',
42
+ street: '350 Fifth Avenue',
43
+ city: 'New York',
44
+ region: 'NY',
45
+ country: 'US',
46
+ postal_code: '10118',
47
+ phone_number: '6465552390'
48
+ }
49
+ end
50
+
51
+ def test_and_document_show
52
+ description 'Showing a checkout'
53
+ route storefront_api.checkout_path(':id')
54
+ explanation <<-EOS
55
+ This will give you overview of the state of checkout for the
56
+ associated order ID. It includes full order information, as well
57
+ as summary information for each step of checkout.
58
+ EOS
59
+
60
+ record_request do
61
+ get storefront_api.checkout_path(@order)
62
+ assert_equal(200, response.status)
63
+ end
64
+ end
65
+
66
+ def test_and_document_update
67
+ description 'Updating a checkout'
68
+ route storefront_api.checkout_path(':id')
69
+ explanation <<-EOS
70
+ Use this endpoint to make updates to checkout. This will typically
71
+ mean setting addresses and shipping options for the checkout.
72
+ EOS
73
+
74
+ record_request do
75
+ patch storefront_api.checkout_path(@order),
76
+ as: :json,
77
+ params: {
78
+ email: 'susanb@workarea.com',
79
+ shipping_address: address,
80
+ billing_address: address,
81
+ shipping_service: 'Express'
82
+ }
83
+
84
+ assert_equal(200, response.status)
85
+ end
86
+ end
87
+
88
+ def test_and_document_complete
89
+ description 'Completing a checkout'
90
+ route storefront_api.complete_checkout_path(':id')
91
+ explanation <<-EOS
92
+ This endpoint completes checkout and places the order. Payment
93
+ tender information is required at this point, and should be included
94
+ with this request.
95
+ EOS
96
+
97
+ patch storefront_api.checkout_path(@order),
98
+ as: :json,
99
+ params: {
100
+ email: 'susanb@workarea.com',
101
+ shipping_address: address,
102
+ billing_address: address,
103
+ shipping_service: 'Express'
104
+ }
105
+
106
+ order = JSON.parse(response.body)['order']
107
+
108
+ record_request do
109
+ post storefront_api.complete_checkout_path(order['id']),
110
+ as: :json,
111
+ params: {
112
+ payment: 'new_card',
113
+ credit_card: {
114
+ number: '4111111111111111',
115
+ month: '3',
116
+ year: Time.now.year + 2,
117
+ cvv: '123'
118
+ }
119
+ }
120
+ assert_equal(200, response.status)
121
+ end
122
+ end
123
+
124
+ def test_and_document_reset
125
+ description 'Showing a checkout'
126
+ route storefront_api.reset_checkout_path(':id')
127
+ explanation <<-EOS
128
+ This endpoint resets the checkout by wiping all private information
129
+ from the order and it's associated models. Use it for handling
130
+ timeouts, logouts, and any other situation where you want to ensure
131
+ the safety of the customer's information.
132
+ EOS
133
+
134
+ record_request do
135
+ get storefront_api.reset_checkout_path(@order)
136
+ assert_equal(200, response.status)
137
+ end
138
+ end
139
+ end
140
+ end
141
+ end
142
+ end
@@ -0,0 +1,39 @@
1
+ require 'test_helper'
2
+ require 'workarea/api/documentation_test'
3
+
4
+ module Workarea
5
+ module Api
6
+ module Storefront
7
+ class ContactsDocumentationTest < DocumentationTest
8
+ resource 'Contacts'
9
+
10
+ setup :set_contact_params
11
+
12
+ def set_contact_params
13
+ @contact_params = {
14
+ name: 'Name',
15
+ email: 'email@example.com',
16
+ order_id: 'OrderID',
17
+ subject: :orders,
18
+ message: 'Message'
19
+ }
20
+ end
21
+
22
+ def test_and_document_create
23
+ description 'Creating a contact'
24
+ route storefront_api.contacts_path
25
+ explanation <<-EOS
26
+ This endpoints creates a customer service inquiry on behalf of the
27
+ customer, and will send an email to the address in
28
+ Workarea.config.email_to
29
+ EOS
30
+
31
+ record_request do
32
+ post storefront_api.contacts_path, params: @contact_params, as: :json
33
+ assert_equal(200, response.status)
34
+ end
35
+ end
36
+ end
37
+ end
38
+ end
39
+ end