shopify_api 9.0.3 → 9.4.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.github/ISSUE_TEMPLATE.md +36 -0
- data/.github/workflows/build.yml +41 -0
- data/.gitignore +2 -1
- data/.rubocop.yml +23 -3
- data/.rubocop_todo.yml +75 -0
- data/CHANGELOG.md +36 -0
- data/CONTRIBUTING.md +1 -1
- data/Gemfile +5 -0
- data/Gemfile.lock +151 -0
- data/Gemfile_ar51 +1 -1
- data/README.md +41 -31
- data/RELEASING +10 -6
- data/Rakefile +16 -5
- data/SECURITY.md +59 -0
- data/docs/_config.yml +1 -0
- data/docs/_includes/footer.html +28 -0
- data/docs/_includes/head.html +28 -0
- data/docs/_layouts/index.html +57 -0
- data/docs/graphql.md +47 -2
- data/docs/index.md +639 -0
- data/lib/active_resource/connection_ext.rb +1 -0
- data/lib/active_resource/detailed_log_subscriber.rb +6 -7
- data/lib/active_resource/json_errors.rb +8 -2
- data/lib/shopify_api.rb +8 -1
- data/lib/shopify_api/api_access.rb +57 -0
- data/lib/shopify_api/api_version.rb +6 -5
- data/lib/shopify_api/connection.rb +1 -0
- data/lib/shopify_api/countable.rb +3 -2
- data/lib/shopify_api/disable_prefix_check.rb +2 -2
- data/lib/shopify_api/events.rb +2 -1
- data/lib/shopify_api/graphql.rb +28 -8
- data/lib/shopify_api/limits.rb +3 -2
- data/lib/shopify_api/message_enricher.rb +11 -9
- data/lib/shopify_api/meta.rb +0 -1
- data/lib/shopify_api/metafields.rb +5 -4
- data/lib/shopify_api/pagination_link_headers.rb +5 -4
- data/lib/shopify_api/resources.rb +1 -0
- data/lib/shopify_api/resources/access_scope.rb +1 -1
- data/lib/shopify_api/resources/access_token.rb +1 -0
- data/lib/shopify_api/resources/address.rb +1 -0
- data/lib/shopify_api/resources/announcement.rb +2 -1
- data/lib/shopify_api/resources/application_charge.rb +1 -0
- data/lib/shopify_api/resources/application_credit.rb +1 -0
- data/lib/shopify_api/resources/article.rb +3 -2
- data/lib/shopify_api/resources/asset.rb +6 -5
- data/lib/shopify_api/resources/assigned_fulfillment_order.rb +1 -1
- data/lib/shopify_api/resources/base.rb +12 -8
- data/lib/shopify_api/resources/billing_address.rb +1 -0
- data/lib/shopify_api/resources/blog.rb +2 -1
- data/lib/shopify_api/resources/carrier_service.rb +1 -0
- data/lib/shopify_api/resources/cart.rb +2 -1
- data/lib/shopify_api/resources/collect.rb +1 -0
- data/lib/shopify_api/resources/collection_listing.rb +1 -0
- data/lib/shopify_api/resources/comment.rb +20 -5
- data/lib/shopify_api/resources/country.rb +1 -0
- data/lib/shopify_api/resources/custom_collection.rb +4 -3
- data/lib/shopify_api/resources/customer.rb +2 -1
- data/lib/shopify_api/resources/customer_group.rb +1 -0
- data/lib/shopify_api/resources/customer_invite.rb +1 -0
- data/lib/shopify_api/resources/customer_saved_search.rb +2 -1
- data/lib/shopify_api/resources/discount_code.rb +1 -0
- data/lib/shopify_api/resources/discount_code_batch.rb +4 -2
- data/lib/shopify_api/resources/draft_order.rb +1 -0
- data/lib/shopify_api/resources/draft_order_invoice.rb +1 -0
- data/lib/shopify_api/resources/event.rb +1 -0
- data/lib/shopify_api/resources/fulfillment.rb +12 -3
- data/lib/shopify_api/resources/fulfillment_event.rb +1 -0
- data/lib/shopify_api/resources/fulfillment_order.rb +30 -16
- data/lib/shopify_api/resources/fulfillment_order_locations_for_move.rb +1 -0
- data/lib/shopify_api/resources/fulfillment_request.rb +1 -0
- data/lib/shopify_api/resources/fulfillment_service.rb +1 -0
- data/lib/shopify_api/resources/fulfillment_v2.rb +3 -2
- data/lib/shopify_api/resources/gift_card.rb +1 -0
- data/lib/shopify_api/resources/image.rb +2 -1
- data/lib/shopify_api/resources/inventory_level.rb +3 -4
- data/lib/shopify_api/resources/line_item.rb +4 -3
- data/lib/shopify_api/resources/location.rb +1 -1
- data/lib/shopify_api/resources/marketing_event.rb +1 -0
- data/lib/shopify_api/resources/metafield.rb +1 -0
- data/lib/shopify_api/resources/note_attribute.rb +1 -0
- data/lib/shopify_api/resources/option.rb +1 -0
- data/lib/shopify_api/resources/order.rb +2 -1
- data/lib/shopify_api/resources/order_risk.rb +1 -0
- data/lib/shopify_api/resources/page.rb +1 -0
- data/lib/shopify_api/resources/payment_details.rb +1 -0
- data/lib/shopify_api/resources/policy.rb +1 -0
- data/lib/shopify_api/resources/price_rule.rb +1 -1
- data/lib/shopify_api/resources/product.rb +12 -9
- data/lib/shopify_api/resources/product_listing.rb +1 -0
- data/lib/shopify_api/resources/province.rb +1 -0
- data/lib/shopify_api/resources/receipt.rb +1 -0
- data/lib/shopify_api/resources/recurring_application_charge.rb +4 -1
- data/lib/shopify_api/resources/redirect.rb +1 -0
- data/lib/shopify_api/resources/refund.rb +2 -1
- data/lib/shopify_api/resources/report.rb +1 -0
- data/lib/shopify_api/resources/resource_feedback.rb +1 -1
- data/lib/shopify_api/resources/rule.rb +1 -0
- data/lib/shopify_api/resources/script_tag.rb +1 -0
- data/lib/shopify_api/resources/shipping_address.rb +1 -0
- data/lib/shopify_api/resources/shipping_line.rb +1 -0
- data/lib/shopify_api/resources/shipping_zone.rb +1 -0
- data/lib/shopify_api/resources/shop.rb +2 -1
- data/lib/shopify_api/resources/smart_collection.rb +4 -8
- data/lib/shopify_api/resources/storefront_access_token.rb +1 -0
- data/lib/shopify_api/resources/tax_line.rb +1 -0
- data/lib/shopify_api/resources/tax_service.rb +1 -0
- data/lib/shopify_api/resources/theme.rb +1 -0
- data/lib/shopify_api/resources/transaction.rb +1 -0
- data/lib/shopify_api/resources/usage_charge.rb +1 -0
- data/lib/shopify_api/resources/user.rb +1 -0
- data/lib/shopify_api/resources/variant.rb +15 -11
- data/lib/shopify_api/resources/webhook.rb +1 -0
- data/lib/shopify_api/session.rb +50 -15
- data/lib/shopify_api/version.rb +2 -1
- data/lib/verify_docs.rb +8 -0
- data/service.yml +1 -1
- data/shopify_api.gemspec +11 -6
- data/test/access_token_test.rb +6 -5
- data/test/active_resource/json_errors_test.rb +6 -6
- data/test/api_access_test.rb +153 -0
- data/test/api_version_test.rb +3 -3
- data/test/application_charge_test.rb +30 -27
- data/test/application_credit_test.rb +10 -9
- data/test/article_test.rb +34 -35
- data/test/asset_test.rb +14 -6
- data/test/assigned_fulfillment_order_test.rb +5 -4
- data/test/base_test.rb +64 -49
- data/test/blog_test.rb +4 -3
- data/test/carrier_service_test.rb +7 -6
- data/test/cart_test.rb +2 -1
- data/test/collect_test.rb +4 -3
- data/test/collection_listing_test.rb +21 -16
- data/test/collection_publication_test.rb +8 -8
- data/test/collection_test.rb +20 -19
- data/test/countable_test.rb +3 -2
- data/test/currency_test.rb +5 -5
- data/test/custom_collection_test.rb +4 -3
- data/test/customer_saved_search_test.rb +18 -8
- data/test/customer_test.rb +22 -14
- data/test/detailed_log_subscriber_test.rb +15 -11
- data/test/discount_code_batch_test.rb +11 -10
- data/test/discount_code_test.rb +21 -15
- data/test/draft_order_test.rb +68 -52
- data/test/fixtures/assigned_fulfillment_orders.json +2 -0
- data/test/fixtures/fulfillment_order.json +1 -0
- data/test/fixtures/fulfillment_orders.json +2 -0
- data/test/fulfillment_event_test.rb +31 -26
- data/test/fulfillment_order_test.rb +215 -147
- data/test/fulfillment_order_test_helper.rb +1 -0
- data/test/fulfillment_request_test.rb +10 -8
- data/test/fulfillment_service_test.rb +13 -12
- data/test/fulfillment_test.rb +81 -66
- data/test/fulfillment_v2_test.rb +16 -12
- data/test/gift_card_test.rb +6 -4
- data/test/graphql_test.rb +55 -23
- data/test/image_test.rb +19 -17
- data/test/inventory_level_test.rb +24 -15
- data/test/lib/webmock_extensions/last_request.rb +1 -1
- data/test/limits_test.rb +2 -1
- data/test/location_test.rb +2 -1
- data/test/marketing_event_test.rb +20 -20
- data/test/message_enricher_test.rb +6 -6
- data/test/meta_test.rb +7 -9
- data/test/metafield_test.rb +30 -20
- data/test/order_risk_test.rb +17 -16
- data/test/order_test.rb +43 -28
- data/test/pagination_test.rb +89 -56
- data/test/policy_test.rb +6 -5
- data/test/price_rule_test.rb +20 -15
- data/test/product_listing_test.rb +20 -20
- data/test/product_publication_test.rb +8 -8
- data/test/product_test.rb +44 -32
- data/test/publication_test.rb +3 -3
- data/test/recurring_application_charge_test.rb +104 -42
- data/test/redirect_test.rb +4 -3
- data/test/refund_test.rb +22 -17
- data/test/report_test.rb +12 -10
- data/test/resource_feedback_test.rb +14 -13
- data/test/script_tag_test.rb +10 -9
- data/test/session_test.rb +297 -43
- data/test/shipping_zone_test.rb +4 -3
- data/test/shop_test.rb +47 -33
- data/test/smart_collection_test.rb +5 -29
- data/test/storefront_access_token_test.rb +13 -15
- data/test/tax_service_test.rb +7 -4
- data/test/tender_transaction_test.rb +3 -3
- data/test/test_helper.rb +15 -13
- data/test/transaction_test.rb +4 -3
- data/test/usage_charge_test.rb +12 -8
- data/test/user_test.rb +4 -3
- data/test/variant_test.rb +29 -91
- data/test/webhook_test.rb +10 -7
- metadata +24 -14
- data/.rubocop-https---shopify-github-io-ruby-style-guide-rubocop-yml +0 -1027
- data/.travis.yml +0 -23
- data/bin/shopify +0 -3
data/test/image_test.rb
CHANGED
@@ -1,39 +1,41 @@
|
|
1
|
+
# frozen_string_literal: true
|
1
2
|
require 'test_helper'
|
2
3
|
|
3
4
|
class ImageTest < Test::Unit::TestCase
|
4
5
|
def test_create_image
|
5
|
-
fake
|
6
|
-
image = ShopifyAPI::Image.new(:
|
6
|
+
fake("products/632910392/images", method: :post, body: load_fixture('image'))
|
7
|
+
image = ShopifyAPI::Image.new(product_id: 632910392)
|
7
8
|
image.position = 1
|
8
|
-
image.attachment = "R0lGODlhbgCMAPf/APbr48VySrxTO7IgKt2qmKQdJeK8lsFjROG5p/
|
9
|
+
image.attachment = "R0lGODlhbgCMAPf/APbr48VySrxTO7IgKt2qmKQdJeK8lsFjROG5p/nz7Zg3MN" \
|
10
|
+
"mnd7Q1MLNVS9GId71hSJMZIuzTu4UtKbeEeakhKMl8U8WYjfr18YQaIbAf=="
|
9
11
|
image.save
|
10
12
|
|
11
|
-
assert_equal
|
12
|
-
assert_equal
|
13
|
+
assert_equal('http://cdn.shopify.com/s/files/1/0006/9093/3842/products/ipod-nano.png?v=1389388540', image.src)
|
14
|
+
assert_equal(850703190, image.id)
|
13
15
|
end
|
14
16
|
|
15
17
|
def test_get_images
|
16
|
-
fake
|
17
|
-
image = ShopifyAPI::Image.find(:all, :
|
18
|
-
assert_equal
|
18
|
+
fake("products/632910392/images", method: :get, body: load_fixture('images'))
|
19
|
+
image = ShopifyAPI::Image.find(:all, params: { product_id: 632910392 })
|
20
|
+
assert_equal(2, image.size)
|
19
21
|
end
|
20
22
|
|
21
23
|
def test_get_image
|
22
|
-
fake
|
23
|
-
image = ShopifyAPI::Image.find(850703190, :
|
24
|
-
assert_equal
|
24
|
+
fake("products/632910392/images/850703190", method: :get, body: load_fixture('image'))
|
25
|
+
image = ShopifyAPI::Image.find(850703190, params: { product_id: 632910392 })
|
26
|
+
assert_equal(850703190, image.id)
|
25
27
|
end
|
26
28
|
|
27
29
|
def test_delete_image
|
28
|
-
fake
|
29
|
-
fake
|
30
|
-
image = ShopifyAPI::Image.find(850703190, :
|
31
|
-
assert
|
30
|
+
fake("products/632910392/images/850703190", method: :get, body: load_fixture('image'))
|
31
|
+
fake("products/632910392/images/850703190", method: :delete, body: "destroyed")
|
32
|
+
image = ShopifyAPI::Image.find(850703190, params: { product_id: 632910392 })
|
33
|
+
assert(image.destroy)
|
32
34
|
end
|
33
35
|
|
34
36
|
def test_delete_image_without_fetching
|
35
|
-
fake
|
37
|
+
fake("products/632910392/images/850703190", method: :delete, body: "destroyed")
|
36
38
|
image = ShopifyAPI::Image.new(product_id: 632910392, id: 850703190)
|
37
|
-
assert
|
39
|
+
assert(image.destroy)
|
38
40
|
end
|
39
41
|
end
|
@@ -1,22 +1,31 @@
|
|
1
|
+
# frozen_string_literal: true
|
1
2
|
require 'test_helper'
|
2
3
|
|
3
4
|
class InventoryLevelTest < Test::Unit::TestCase
|
4
5
|
def setup
|
5
6
|
super
|
6
|
-
@inventory_level_response = ActiveSupport::JSON.decode
|
7
|
+
@inventory_level_response = ActiveSupport::JSON.decode(load_fixture('inventory_level'))
|
7
8
|
@inventory_level = ShopifyAPI::InventoryLevel.new(@inventory_level_response['inventory_level'])
|
8
9
|
end
|
9
10
|
|
10
11
|
test ".find with inventory_item_ids and location_ids returns expected inventory levels" do
|
11
12
|
params = { inventory_item_ids: [808950810, 39072856], location_ids: [905684977, 487838322] }
|
12
|
-
fake
|
13
|
-
|
13
|
+
fake(
|
14
|
+
"inventory_levels.json?#{params.to_param}",
|
15
|
+
extension: false,
|
16
|
+
method: :get,
|
17
|
+
status: 200,
|
18
|
+
body: load_fixture('inventory_levels')
|
19
|
+
)
|
14
20
|
inventory_levels = ShopifyAPI::InventoryLevel.find(:all, params: params)
|
15
21
|
|
16
|
-
assert
|
17
|
-
|
18
|
-
|
19
|
-
|
22
|
+
assert(
|
23
|
+
inventory_levels.all? do |item|
|
24
|
+
params[:location_ids].include?(item.location_id) &&
|
25
|
+
params[:inventory_item_ids].include?(item.inventory_item_id)
|
26
|
+
end,
|
27
|
+
message: 'Response contained inventory_items or locations not requested.'
|
28
|
+
)
|
20
29
|
end
|
21
30
|
|
22
31
|
test '#adjust with adjustment value returns inventory_level with available increased by adjustment value' do
|
@@ -24,9 +33,9 @@ class InventoryLevelTest < Test::Unit::TestCase
|
|
24
33
|
updated_available = @inventory_level.available + adjustment
|
25
34
|
@inventory_level_response[:available] = updated_available
|
26
35
|
|
27
|
-
fake
|
36
|
+
fake('inventory_levels/adjust', method: :post, body: ActiveSupport::JSON.encode(@inventory_level_response))
|
28
37
|
@inventory_level.adjust(adjustment)
|
29
|
-
assert_equal
|
38
|
+
assert_equal(updated_available, @inventory_level.available)
|
30
39
|
end
|
31
40
|
|
32
41
|
test '#connect saves an inventory_level associated with inventory_item and location_id' do
|
@@ -34,16 +43,16 @@ class InventoryLevelTest < Test::Unit::TestCase
|
|
34
43
|
response = params.clone
|
35
44
|
response[:available] = 0
|
36
45
|
|
37
|
-
fake
|
46
|
+
fake('inventory_levels/connect', method: :post, body: ActiveSupport::JSON.encode(response))
|
38
47
|
inventory_level = ShopifyAPI::InventoryLevel.new(params)
|
39
48
|
inventory_level.connect
|
40
|
-
assert_equal
|
49
|
+
assert_equal(0, inventory_level.available, message: 'expected newly connected location to have 0 inventory')
|
41
50
|
end
|
42
51
|
|
43
52
|
test '#destroy removes inventory_level and returns nil' do
|
44
53
|
params = { inventory_item_id: @inventory_level.inventory_item_id, location_id: @inventory_level.location_id }
|
45
|
-
fake
|
46
|
-
assert_nil
|
54
|
+
fake("inventory_levels.json?#{params.to_param}", extension: false, method: :delete, status: 204, body: nil)
|
55
|
+
assert_nil(@inventory_level.destroy)
|
47
56
|
end
|
48
57
|
|
49
58
|
test '#set with available value returns inventory_level with available as the available value' do
|
@@ -51,9 +60,9 @@ class InventoryLevelTest < Test::Unit::TestCase
|
|
51
60
|
response = @inventory_level_response.clone
|
52
61
|
response['inventory_level']['available'] = available
|
53
62
|
|
54
|
-
fake
|
63
|
+
fake('inventory_levels/set', method: :post, body: ActiveSupport::JSON.encode(response))
|
55
64
|
@inventory_level.set(available)
|
56
65
|
|
57
|
-
assert_equal
|
66
|
+
assert_equal(available, @inventory_level.available)
|
58
67
|
end
|
59
68
|
end
|
data/test/limits_test.rb
CHANGED
@@ -1,3 +1,4 @@
|
|
1
|
+
# frozen_string_literal: true
|
1
2
|
require 'test_helper'
|
2
3
|
|
3
4
|
class LimitsTest < Test::Unit::TestCase
|
@@ -30,7 +31,7 @@ class LimitsTest < Test::Unit::TestCase
|
|
30
31
|
should "raise error when header doesn't exist" do
|
31
32
|
@header_hash = {}
|
32
33
|
ShopifyAPI::Base.connection.expects(:response).at_least(1).returns(@header_hash)
|
33
|
-
assert_raises
|
34
|
+
assert_raises(ShopifyAPI::Limits::LimitUnavailable) do
|
34
35
|
ShopifyAPI.credit_left
|
35
36
|
end
|
36
37
|
end
|
data/test/location_test.rb
CHANGED
@@ -1,10 +1,11 @@
|
|
1
|
+
# frozen_string_literal: true
|
1
2
|
require 'test_helper'
|
2
3
|
|
3
4
|
class LocationTest < Test::Unit::TestCase
|
4
5
|
test '#inventory_levels returns all inventory_levels associated with this location' do
|
5
6
|
location = ShopifyAPI::Location.new(id: 487838322)
|
6
7
|
expected_body = JSON.parse(load_fixture('inventory_levels'))
|
7
|
-
expected_body['inventory_levels'].delete_if {|level| level['location_id'] != location.id }
|
8
|
+
expected_body['inventory_levels'].delete_if { |level| level['location_id'] != location.id }
|
8
9
|
fake "locations/#{location.id}/inventory_levels", method: :get, status: 200, body: JSON(expected_body).to_s
|
9
10
|
inventory_levels = location.inventory_levels
|
10
11
|
|
@@ -1,56 +1,56 @@
|
|
1
|
+
# frozen_string_literal: true
|
1
2
|
require 'test_helper'
|
2
3
|
|
3
4
|
class MarketingEventTest < Test::Unit::TestCase
|
4
|
-
|
5
5
|
def test_get_marketing_events
|
6
|
-
fake
|
6
|
+
fake("marketing_events", method: :get, body: load_fixture('marketing_events'))
|
7
7
|
marketing_events = ShopifyAPI::MarketingEvent.all
|
8
|
-
assert_equal
|
8
|
+
assert_equal(2, marketing_events.size)
|
9
9
|
end
|
10
10
|
|
11
11
|
def test_get_marketing_event
|
12
|
-
fake
|
12
|
+
fake("marketing_events/1", method: :get, body: load_fixture('marketing_event'))
|
13
13
|
marketing_event = ShopifyAPI::MarketingEvent.find(1)
|
14
|
-
assert_equal
|
14
|
+
assert_equal(1, marketing_event.id)
|
15
15
|
end
|
16
16
|
|
17
17
|
def test_create_marketing_event
|
18
|
-
fake
|
18
|
+
fake("marketing_events", method: :post, body: load_fixture('marketing_event'))
|
19
19
|
marketing_event = ShopifyAPI::MarketingEvent.new
|
20
20
|
marketing_event.currency_code = 'GBP'
|
21
21
|
marketing_event.event_target = 'facebook'
|
22
22
|
marketing_event.event_type = 'post'
|
23
23
|
marketing_event.save
|
24
24
|
|
25
|
-
assert_equal
|
26
|
-
assert_equal
|
25
|
+
assert_equal('facebook', marketing_event.event_target)
|
26
|
+
assert_equal(1, marketing_event.id)
|
27
27
|
end
|
28
28
|
|
29
29
|
def test_delete_marketing_event
|
30
|
-
fake
|
31
|
-
fake
|
30
|
+
fake("marketing_events/1", method: :get, body: load_fixture('marketing_event'))
|
31
|
+
fake("marketing_events/1", method: :delete, body: "destroyed")
|
32
32
|
marketing_event = ShopifyAPI::MarketingEvent.find(1)
|
33
|
-
assert
|
33
|
+
assert(marketing_event.destroy)
|
34
34
|
end
|
35
35
|
|
36
36
|
def test_update_marketing_event
|
37
|
-
fake
|
37
|
+
fake('marketing_events/1', method: :get, status: 200, body: load_fixture('marketing_event'))
|
38
38
|
marketing_event = ShopifyAPI::MarketingEvent.find(1)
|
39
39
|
marketing_event.currency = 'USD'
|
40
|
-
fake
|
41
|
-
assert
|
40
|
+
fake('marketing_events/1', method: :put, status: 200, body: load_fixture('marketing_event'))
|
41
|
+
assert(marketing_event.save)
|
42
42
|
end
|
43
43
|
|
44
44
|
def test_count_marketing_events
|
45
|
-
fake
|
45
|
+
fake("marketing_events/count", method: :get, body: '{"count": 2}')
|
46
46
|
marketing_events_count = ShopifyAPI::MarketingEvent.count
|
47
|
-
assert_equal
|
47
|
+
assert_equal(2, marketing_events_count)
|
48
48
|
end
|
49
49
|
|
50
50
|
def test_add_engagements
|
51
|
-
fake
|
51
|
+
fake("marketing_events/1", method: :get, body: load_fixture('marketing_event'))
|
52
52
|
marketing_event = ShopifyAPI::MarketingEvent.find(1)
|
53
|
-
fake
|
53
|
+
fake("marketing_events/1/engagements", method: :post, status: 201, body: load_fixture('engagement'))
|
54
54
|
engagement = {
|
55
55
|
occurred_on: "2017-04-20",
|
56
56
|
impressions_count: nil,
|
@@ -60,9 +60,9 @@ class MarketingEventTest < Test::Unit::TestCase
|
|
60
60
|
favorites_count: nil,
|
61
61
|
comments_count: nil,
|
62
62
|
ad_spend: nil,
|
63
|
-
is_cumulative: true
|
63
|
+
is_cumulative: true,
|
64
64
|
}
|
65
65
|
marketing_event.add_engagements(engagement)
|
66
|
-
assert
|
66
|
+
assert("2017-04-20", engagement[:occurred_on])
|
67
67
|
end
|
68
68
|
end
|
@@ -1,35 +1,35 @@
|
|
1
|
+
# frozen_string_literal: true
|
1
2
|
require 'test_helper'
|
2
3
|
|
3
4
|
class MessageEnricherTest < Test::Unit::TestCase
|
4
|
-
|
5
5
|
def test_enriches_initial_message_when_body_contains_error
|
6
6
|
response = enriched_response(422, 'InitialMessage', { error: 'My Error' })
|
7
7
|
|
8
|
-
assert_equal
|
8
|
+
assert_equal('InitialMessage (My Error)', response.message)
|
9
9
|
end
|
10
10
|
|
11
11
|
def test_enriches_initial_message_when_body_contains_errors_array
|
12
12
|
response = enriched_response(422, 'InitialMessage', { errors: ['My Error1', 'My Error2'] })
|
13
13
|
|
14
|
-
assert_equal
|
14
|
+
assert_equal('InitialMessage (My Error1; My Error2)', response.message)
|
15
15
|
end
|
16
16
|
|
17
17
|
def test_enriches_initial_message_when_body_contains_errors_single_value
|
18
18
|
response = enriched_response(422, 'InitialMessage', { errors: 'My Error1' })
|
19
19
|
|
20
|
-
assert_equal
|
20
|
+
assert_equal('InitialMessage (My Error1)', response.message)
|
21
21
|
end
|
22
22
|
|
23
23
|
def test_returns_initial_message_when_code_is_200
|
24
24
|
response = enriched_response(200, 'InitialMessage', { result: 'Success' })
|
25
25
|
|
26
|
-
assert_equal
|
26
|
+
assert_equal('InitialMessage', response.message)
|
27
27
|
end
|
28
28
|
|
29
29
|
def test_returns_initial_message_when_body_cant_be_parsed
|
30
30
|
response = enriched_response(422, 'InitialMessage', 'not a json')
|
31
31
|
|
32
|
-
assert_equal
|
32
|
+
assert_equal('InitialMessage', response.message)
|
33
33
|
end
|
34
34
|
|
35
35
|
private
|
data/test/meta_test.rb
CHANGED
@@ -8,42 +8,40 @@ class ApiVersionTest < Test::Unit::TestCase
|
|
8
8
|
"handle": "2019-01",
|
9
9
|
"display_name": "2019-01",
|
10
10
|
"supported": true,
|
11
|
-
"latest_supported": false
|
11
|
+
"latest_supported": false,
|
12
12
|
},
|
13
13
|
{
|
14
14
|
"handle": "2019-04",
|
15
15
|
"latest_supported": false,
|
16
16
|
"display_name": "2019-04",
|
17
|
-
"supported": true
|
17
|
+
"supported": true,
|
18
18
|
},
|
19
19
|
{
|
20
20
|
"handle": "2019-07",
|
21
21
|
"latest_supported": false,
|
22
22
|
"display_name": "2019-07",
|
23
|
-
"supported": true
|
23
|
+
"supported": true,
|
24
24
|
},
|
25
25
|
{
|
26
26
|
"handle": "2019-10",
|
27
27
|
"latest_supported": false,
|
28
28
|
"display_name": "2019-10",
|
29
|
-
"supported": true
|
29
|
+
"supported": true,
|
30
30
|
},
|
31
31
|
{
|
32
32
|
"handle": "2020-01",
|
33
33
|
"latest_supported": true,
|
34
34
|
"display_name": "2020-01 (Latest)",
|
35
|
-
"supported": true
|
35
|
+
"supported": true,
|
36
36
|
},
|
37
37
|
{
|
38
38
|
"handle": "unstable",
|
39
39
|
"latest_supported": false,
|
40
40
|
"display_name": "unstable",
|
41
|
-
"supported": false
|
42
|
-
}
|
41
|
+
"supported": false,
|
42
|
+
},
|
43
43
|
].to_json
|
44
44
|
|
45
|
-
|
46
45
|
assert_equal versions, ShopifyAPI::Meta.admin_versions.to_json
|
47
|
-
|
48
46
|
end
|
49
47
|
end
|
data/test/metafield_test.rb
CHANGED
@@ -1,46 +1,56 @@
|
|
1
|
+
# frozen_string_literal: true
|
1
2
|
require 'test_helper'
|
2
3
|
|
3
4
|
class MetafieldTest < Test::Unit::TestCase
|
4
5
|
def test_get_metafields
|
5
|
-
fake
|
6
|
-
|
6
|
+
fake("metafields", method: :get, body: load_fixture('metafields'))
|
7
|
+
ShopifyAPI::Metafield.find(:all)
|
7
8
|
end
|
8
9
|
|
9
10
|
def test_get_metafield
|
10
|
-
fake
|
11
|
-
assert
|
11
|
+
fake("metafields/721389482", method: :get, body: load_fixture('metafield'))
|
12
|
+
assert(ShopifyAPI::Metafield.find(721389482))
|
12
13
|
end
|
13
14
|
|
14
15
|
def test_get_metafield_of_a_blog
|
15
|
-
fake
|
16
|
-
metafield = ShopifyAPI::Metafield.find(721389482, :
|
17
|
-
assert_equal
|
16
|
+
fake("blogs/1008414260/metafields/721389482", method: :get, body: load_fixture('metafield'))
|
17
|
+
metafield = ShopifyAPI::Metafield.find(721389482, params: { resource: "blogs", resource_id: 1008414260 })
|
18
|
+
assert_equal(1008414260, metafield.prefix_options[:resource_id])
|
18
19
|
end
|
19
20
|
|
20
21
|
def test_create_metafield_for_a_blog
|
21
|
-
fake
|
22
|
-
fake
|
22
|
+
fake("blogs/1008414260", method: :get, body: load_fixture('blog'))
|
23
|
+
fake("blogs/1008414260/metafields", method: :post, status: 201, body: load_fixture('metafield'))
|
23
24
|
|
24
25
|
blog = ShopifyAPI::Blog.find(1008414260)
|
25
|
-
metafield = blog.add_metafield(
|
26
|
-
|
27
|
-
|
28
|
-
|
26
|
+
metafield = blog.add_metafield(
|
27
|
+
ShopifyAPI::Metafield.new(
|
28
|
+
namespace: "summaries", key: "First Summary", value: "Make commerce better", value_type: "string"
|
29
|
+
)
|
30
|
+
)
|
31
|
+
|
32
|
+
assert_equal(
|
33
|
+
ActiveSupport::JSON.decode(
|
34
|
+
'{"metafield":{"namespace":"summaries","key":"First Summary",' \
|
35
|
+
'"value":"Make commerce better","value_type":"string"}}'
|
36
|
+
),
|
37
|
+
ActiveSupport::JSON.decode(WebMock.last_request.body)
|
38
|
+
)
|
39
|
+
assert(!metafield.new_record?)
|
29
40
|
end
|
30
41
|
|
31
42
|
def test_update_metafield
|
32
|
-
fake
|
33
|
-
fake
|
43
|
+
fake("metafields/721389482", method: :get, body: load_fixture('metafield'))
|
44
|
+
fake("metafields/721389482", method: :put, status: 200, body: load_fixture('metafield'))
|
34
45
|
metafield = ShopifyAPI::Metafield.find(721389482)
|
35
46
|
metafield.namespace = "teaser"
|
36
|
-
assert
|
47
|
+
assert(metafield.save)
|
37
48
|
end
|
38
49
|
|
39
50
|
def test_delete_metafield
|
40
|
-
fake
|
41
|
-
fake
|
51
|
+
fake("metafields/721389482", method: :get, body: load_fixture('metafield'))
|
52
|
+
fake("metafields/721389482", method: :delete, body: 'destroyed')
|
42
53
|
metafield = ShopifyAPI::Metafield.find(721389482)
|
43
|
-
assert
|
54
|
+
assert(metafield.destroy)
|
44
55
|
end
|
45
56
|
end
|
46
|
-
|
data/test/order_risk_test.rb
CHANGED
@@ -1,9 +1,10 @@
|
|
1
|
+
# frozen_string_literal: true
|
1
2
|
require 'test_helper'
|
2
3
|
|
3
4
|
class OrderRiskTest < Test::Unit::TestCase
|
4
5
|
def test_create_order_risk
|
5
|
-
fake
|
6
|
-
v = ShopifyAPI::OrderRisk.new(:
|
6
|
+
fake("orders/450789469/risks", method: :post, body: load_fixture('order_risk'))
|
7
|
+
v = ShopifyAPI::OrderRisk.new(order_id: 450789469)
|
7
8
|
v.message = "This order was placed from a proxy IP"
|
8
9
|
v.recommendation = "cancel"
|
9
10
|
v.score = "1.0"
|
@@ -13,33 +14,33 @@ class OrderRiskTest < Test::Unit::TestCase
|
|
13
14
|
v.cause_cancel = true
|
14
15
|
v.save
|
15
16
|
|
16
|
-
assert_equal
|
17
|
+
assert_equal(284138680, v.id)
|
17
18
|
end
|
18
19
|
|
19
20
|
def test_get_order_risks
|
20
|
-
fake
|
21
|
-
v = ShopifyAPI::OrderRisk.find(:all, :
|
22
|
-
assert_equal
|
21
|
+
fake("orders/450789469/risks", method: :get, body: load_fixture('order_risks'))
|
22
|
+
v = ShopifyAPI::OrderRisk.find(:all, params: { order_id: 450789469 })
|
23
|
+
assert_equal(2, v.size)
|
23
24
|
end
|
24
25
|
|
25
26
|
def test_get_order_risk
|
26
|
-
fake
|
27
|
-
v = ShopifyAPI::OrderRisk.find(284138680, :
|
28
|
-
assert_equal
|
27
|
+
fake("orders/450789469/risks/284138680", method: :get, body: load_fixture('order_risk'))
|
28
|
+
v = ShopifyAPI::OrderRisk.find(284138680, params: { order_id: 450789469 })
|
29
|
+
assert_equal(284138680, v.id)
|
29
30
|
end
|
30
31
|
|
31
32
|
def test_delete_order_risk
|
32
|
-
fake
|
33
|
-
fake
|
34
|
-
v = ShopifyAPI::OrderRisk.find(284138680, :
|
35
|
-
assert
|
33
|
+
fake("orders/450789469/risks/284138680", method: :get, body: load_fixture('order_risk'))
|
34
|
+
fake("orders/450789469/risks/284138680", method: :delete, body: "destroyed")
|
35
|
+
v = ShopifyAPI::OrderRisk.find(284138680, params: { order_id: 450789469 })
|
36
|
+
assert(v.destroy)
|
36
37
|
end
|
37
38
|
|
38
39
|
def test_update_order_risk
|
39
|
-
fake
|
40
|
-
fake
|
40
|
+
fake("orders/450789469/risks/284138680", method: :get, body: load_fixture('order_risk'))
|
41
|
+
fake("orders/450789469/risks/284138680", method: :put, body: load_fixture('order_risk'))
|
41
42
|
|
42
|
-
v = ShopifyAPI::OrderRisk.find(284138680, :
|
43
|
+
v = ShopifyAPI::OrderRisk.find(284138680, params: { order_id: 450789469 })
|
43
44
|
v.position = 3
|
44
45
|
v.save
|
45
46
|
end
|