Skip to content

Commit

Permalink
Revert restriction on updating metadata by ID for orders (saleor#9179)
Browse files Browse the repository at this point in the history
  • Loading branch information
maarcingebala authored Feb 21, 2022
1 parent 098ff7b commit 79250bf
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 43 deletions.
3 changes: 1 addition & 2 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,12 +6,11 @@ All notable, unreleased changes to this project will be documented in this file.

## Breaking

- Do no allow using `id` for updating checkout and order metadata - #8906 by @IKarbowiak
- Use `token` instead
- Remove `graphene-django` dependency - #9170 by @rafalp
- Don't run plugins when calculating checkout's total price for available shipping methods resolution - #9121 by @rafalp
- Use either net or gross price depending on store configuration.


## Other

- Extend app by `AppExtension` - #7701 by @korycins
Expand Down
10 changes: 0 additions & 10 deletions saleor/graphql/meta/mutations.py
Original file line number Diff line number Diff line change
Expand Up @@ -57,16 +57,6 @@ def get_instance(cls, info, **data):

try:
type_name, _ = from_global_id_or_error(object_id)
if type_name == "Order":
raise ValidationError(
{
"id": ValidationError(
"Changing order metadata with `Order.id` is forbidden. "
"Use `Order.token` as an identifier instead.",
code=MetadataErrorCode.GRAPHQL_ERROR.value,
)
}
)
# ShippingMethodType represents the ShippingMethod model
if type_name == "ShippingMethodType":
qs = shipping_models.ShippingMethod.objects
Expand Down
59 changes: 28 additions & 31 deletions saleor/graphql/meta/tests/test_meta_mutations.py
Original file line number Diff line number Diff line change
Expand Up @@ -124,16 +124,6 @@ def item_contains_multiple_proper_public_metadata(
)


def invalid_id_graphql_error_raised(errors_from_respone):
return all(
[
len(errors_from_respone) == 1,
errors_from_respone[0]["code"] == MetadataErrorCode.GRAPHQL_ERROR.name,
errors_from_respone[0]["field"] == "id",
]
)


@patch("saleor.plugins.manager.PluginsManager.checkout_updated")
def test_base_metadata_mutation_handles_errors_from_extra_action(
mock_checkout_updated, api_client, checkout
Expand All @@ -142,10 +132,11 @@ def test_base_metadata_mutation_handles_errors_from_extra_action(
error_field = "field"
error_msg = "boom"
mock_checkout_updated.side_effect = ValidationError({error_field: error_msg})
checkout_id = graphene.Node.to_global_id("Checkout", checkout.pk)

# when
response = execute_update_public_metadata_for_item(
api_client, None, checkout.token, "Checkout"
api_client, None, checkout_id, "Checkout"
)

# then
Expand Down Expand Up @@ -396,8 +387,9 @@ def test_add_public_metadata_for_order_by_id(api_client, order):
)

# then
errors = response["data"]["updateMetadata"]["errors"]
assert invalid_id_graphql_error_raised(errors)
assert item_contains_proper_public_metadata(
response["data"]["updateMetadata"]["item"], order, order_id
)


def test_add_public_metadata_for_order_by_token(api_client, order):
Expand Down Expand Up @@ -425,8 +417,9 @@ def test_add_public_metadata_for_draft_order_by_id(api_client, draft_order):
)

# then
errors = response["data"]["updateMetadata"]["errors"]
assert invalid_id_graphql_error_raised(errors)
assert item_contains_proper_public_metadata(
response["data"]["updateMetadata"]["item"], draft_order, draft_order_id
)


def test_add_public_metadata_for_draft_order_by_token(api_client, draft_order):
Expand Down Expand Up @@ -1172,8 +1165,9 @@ def test_delete_public_metadata_for_order_by_id(api_client, order):
)

# then
errors = response["data"]["deleteMetadata"]["errors"]
assert invalid_id_graphql_error_raised(errors)
assert item_without_public_metadata(
response["data"]["deleteMetadata"]["item"], order, order_id
)


def test_delete_public_metadata_for_order_by_token(api_client, order):
Expand Down Expand Up @@ -1205,10 +1199,9 @@ def test_delete_public_metadata_for_draft_order_by_id(api_client, draft_order):
)

# then
errors = response["data"]["deleteMetadata"]["errors"]
assert len(errors) == 1
assert errors[0]["code"] == MetadataErrorCode.GRAPHQL_ERROR.name
assert errors[0]["field"] == "id"
assert item_without_public_metadata(
response["data"]["deleteMetadata"]["item"], draft_order, draft_order_id
)


def test_delete_public_metadata_for_draft_order_by_token(api_client, draft_order):
Expand Down Expand Up @@ -1600,7 +1593,7 @@ def test_delete_public_metadata_for_not_exist_key(api_client, checkout):

# when
response = execute_clear_public_metadata_for_item(
api_client, None, checkout.token, "Checkout", key="Not-exits"
api_client, None, checkout_id, "Checkout", key="Not-exits"
)

# then
Expand All @@ -1619,7 +1612,7 @@ def test_delete_public_metadata_for_one_key(api_client, checkout):

# when
response = execute_clear_public_metadata_for_item(
api_client, None, checkout.token, "Checkout", key="to_clear"
api_client, None, checkout_id, "Checkout", key="to_clear"
)

# then
Expand Down Expand Up @@ -1979,8 +1972,9 @@ def test_add_private_metadata_for_order_by_id(
)

# then
errors = response["data"]["updatePrivateMetadata"]["errors"]
assert invalid_id_graphql_error_raised(errors)
assert item_contains_proper_private_metadata(
response["data"]["updatePrivateMetadata"]["item"], order, order_id
)


def test_add_private_metadata_for_order_by_token(
Expand Down Expand Up @@ -2012,8 +2006,9 @@ def test_add_private_metadata_for_draft_order_by_id(
)

# then
errors = response["data"]["updatePrivateMetadata"]["errors"]
assert invalid_id_graphql_error_raised(errors)
assert item_contains_proper_private_metadata(
response["data"]["updatePrivateMetadata"]["item"], draft_order, draft_order_id
)


def test_add_private_metadata_for_draft_order_by_token(
Expand Down Expand Up @@ -2828,8 +2823,9 @@ def test_delete_private_metadata_for_order_by_id(
)

# then
errors = response["data"]["deletePrivateMetadata"]["errors"]
assert invalid_id_graphql_error_raised(errors)
assert item_without_private_metadata(
response["data"]["deletePrivateMetadata"]["item"], order, order_id
)


def test_delete_private_metadata_for_order_by_token(
Expand Down Expand Up @@ -2865,8 +2861,9 @@ def test_delete_private_metadata_for_draft_order_by_id(
)

# then
errors = response["data"]["deletePrivateMetadata"]["errors"]
assert invalid_id_graphql_error_raised(errors)
assert item_without_private_metadata(
response["data"]["deletePrivateMetadata"]["item"], draft_order, draft_order_id
)


def test_delete_private_metadata_for_draft_order_by_token(
Expand Down

0 comments on commit 79250bf

Please sign in to comment.