Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions method/resource.py
Original file line number Diff line number Diff line change
Expand Up @@ -238,6 +238,10 @@ def _update_with_id(self, _id: str, data: Dict) -> MethodResponse[T]:
def _update(self, data: Dict) -> MethodResponse[T]:
return self._make_request('PUT', data=data)

@MethodError.catch
def _patch_with_id(self, _id: str, data: Dict) -> MethodResponse[T]:
return self._make_request('PATCH', path=_id, data=data)

@MethodError.catch
def _update_with_sub_path(self, path: str, data: Dict) -> MethodResponse[T]:
return self._make_request('PUT', path=path, data=data)
Expand Down
2 changes: 1 addition & 1 deletion method/resources/Accounts/Products.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,11 +13,11 @@


class AccountProduct(TypedDict):
id: str
name: str
status: AccountProductTypeStatusLiterals
status_error: Optional[ResourceError]
latest_request_id: str
latest_successful_request_id: str
is_subscribable: bool
created_at: str
updated_at: str
Expand Down
2 changes: 2 additions & 0 deletions method/resources/Entities/Connect.py
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,8 @@ class EntityConnect(TypedDict):
id: str
status: EntityConnectResponseStatusLiterals
accounts: Optional[List[str]]
requested_products: Optional[List[str]]
requested_subscriptions: Optional[List[str]]
error: Optional[ResourceError]
created_at: str
updated_at: str
Expand Down
2 changes: 1 addition & 1 deletion method/resources/Entities/Products.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,11 +13,11 @@


class EntityProduct(TypedDict):
id: str
name: str
status: EntityProductTypeStatusLiterals
status_error: Optional[ResourceError]
latest_request_id: str
latest_successful_request_id: str
is_subscribable: bool
created_at: str
updated_at: str
Expand Down
7 changes: 7 additions & 0 deletions method/resources/Webhook.py
Original file line number Diff line number Diff line change
Expand Up @@ -89,6 +89,10 @@ class WebhookCreateOpts(TypedDict):
expand_event: Optional[bool]


class WebhookUpdateOpts(TypedDict):
status: Optional[str]


class WebhookResource(Resource):
def __init__(self, config: Configuration):
super(WebhookResource, self).__init__(config.add_path('webhooks'))
Expand All @@ -105,3 +109,6 @@ def list(self) -> MethodResponse[List[Webhook]]:

def create(self, opts: WebhookCreateOpts, request_opts: Optional[RequestOpts] = None) -> MethodResponse[Webhook]:
return super(WebhookResource, self)._create(opts, request_opts)

def update(self, _id: str, opts: WebhookUpdateOpts) -> MethodResponse[Webhook]:
return super(WebhookResource, self)._patch_with_id(_id, opts)
2 changes: 1 addition & 1 deletion setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

setup(
name='method-python',
version='1.2.5',
version='1.2.6',
description='Python library for the Method API',
long_description='Python library for the Method API',
long_description_content_type='text/x-rst',
Expand Down
129 changes: 12 additions & 117 deletions test/resources/Account_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -169,6 +169,7 @@ def test_create_liability_account(setup):
'attribute': accounts_create_liability_response['attribute'],
'card_brand': None,
'payment_instrument': None,
'payoff': None,
'products': accounts_create_liability_response['products'],
'restricted_products': accounts_create_liability_response['restricted_products'],
'subscriptions': accounts_create_liability_response['subscriptions'],
Expand Down Expand Up @@ -339,7 +340,7 @@ def test_retrieve_card_brands(setup):
assert card_retrieve_response[k] == v

brand = card_retrieve_response['brands'][0]
assert brand['id'] == 'brand_UBwVzXjpP4PJ6'
assert brand['id'] == 'pdt_15_brd_1'
assert brand['name'] == 'Chase Sapphire Reserve'
assert brand['url'] == 'https://static.methodfi.com/card_brands/1b7ccaba6535cb837f802d968add4700.png'
assert isinstance(brand['art_id'], str) and brand['art_id'].startswith('art_')
Expand All @@ -364,7 +365,7 @@ async def test_list_card_brands(setup):
assert result['updated_at'] == result['updated_at']

brand = result['brands'][0]
assert brand['id'] == 'brand_UBwVzXjpP4PJ6'
assert brand['id'] == 'pdt_15_brd_1'
assert brand['name'] == 'Chase Sapphire Reserve'
assert brand['url'] == 'https://static.methodfi.com/card_brands/1b7ccaba6535cb837f802d968add4700.png'
assert isinstance(brand['art_id'], str) and brand['art_id'].startswith('art_')
Expand Down Expand Up @@ -1011,91 +1012,91 @@ def test_list_account_products(setup):

expect_results: AccountProductListResponse = {
'balance': {
'id': account_products_list_response.get('balance', {}).get('id', ''),
'name': 'balance',
'status': 'available',
'status_error': None,
'latest_request_id': account_products_list_response.get('balance', {}).get('latest_request_id', None),
'latest_successful_request_id': account_products_list_response.get('balance', {}).get('latest_successful_request_id', None),
'is_subscribable': False,
'created_at': account_products_list_response.get('balance', {}).get('created_at', ''),
'updated_at': account_products_list_response.get('balance', {}).get('updated_at', ''),
},
'payment': {
'id': account_products_list_response.get('payment', {}).get('id', ''),
'name': 'payment',
'status': 'available',
'status_error': None,
'latest_request_id': account_products_list_response.get('payment', {}).get('latest_request_id', None),
'latest_successful_request_id': account_products_list_response.get('payment', {}).get('latest_successful_request_id', None),
'is_subscribable': False,
'created_at': account_products_list_response.get('payment', {}).get('created_at', ''),
'updated_at': account_products_list_response.get('payment', {}).get('updated_at', ''),
},
'sensitive': {
'id': account_products_list_response.get('sensitive', {}).get('id', ''),
'name': 'sensitive',
'status': 'available',
'status_error': None,
'latest_request_id': account_products_list_response.get('sensitive', {}).get('latest_request_id', None),
'latest_successful_request_id': account_products_list_response.get('sensitive', {}).get('latest_successful_request_id', None),
'is_subscribable': False,
'created_at': account_products_list_response.get('sensitive', {}).get('created_at', ''),
'updated_at': account_products_list_response.get('sensitive', {}).get('updated_at', ''),
},
'update': {
'id': account_products_list_response.get('update', {}).get('id', ''),
'name': 'update',
'status': 'available',
'status_error': None,
'latest_request_id': account_products_list_response.get('update', {}).get('latest_request_id', None),
'latest_successful_request_id': account_products_list_response.get('update', {}).get('latest_successful_request_id', None),
'is_subscribable': True,
'created_at': account_products_list_response.get('update', {}).get('created_at', ''),
'updated_at': account_products_list_response.get('update', {}).get('updated_at', ''),
},
'attribute': {
'id': account_products_list_response.get('attribute', {}).get('id', ''),
'name': 'attribute',
'status': 'available',
'status_error': None,
'latest_request_id': account_products_list_response.get('attribute', {}).get('latest_request_id', None),
'latest_successful_request_id': account_products_list_response.get('attribute', {}).get('latest_successful_request_id', None),
'is_subscribable': False,
'created_at': account_products_list_response.get('attribute', {}).get('created_at', ''),
'updated_at': account_products_list_response.get('attribute', {}).get('updated_at', ''),
},
'transaction': {
'id': account_products_list_response.get('transaction', {}).get('id', ''),
'name': 'transaction',
'status': 'unavailable',
'status_error': account_products_list_response.get('transaction', {}).get('status_error', None),
'latest_request_id': account_products_list_response.get('transaction', {}).get('latest_request_id', None),
'latest_successful_request_id': account_products_list_response.get('transaction', {}).get('latest_successful_request_id', None),
'is_subscribable': True,
'created_at': account_products_list_response.get('transaction', {}).get('created_at', ''),
'updated_at': account_products_list_response.get('transaction', {}).get('updated_at', ''),
},
'payoff': {
'id': account_products_list_response.get('payoff', {}).get('id', ''),
'name': 'payoff',
'status': 'unavailable',
'status_error': account_products_list_response.get('payoff', {}).get('status_error', None),
'latest_request_id': account_products_list_response.get('payoff', {}).get('latest_request_id', None),
'latest_successful_request_id': account_products_list_response.get('payoff', {}).get('latest_successful_request_id', None),
'is_subscribable': False,
'created_at': account_products_list_response.get('payoff', {}).get('created_at', ''),
'updated_at': account_products_list_response.get('payoff', {}).get('updated_at', ''),
},
'card_brand': {
'id': account_products_list_response.get('card_brand', {}).get('id', ''),
'name': 'card_brand',
'status': 'available',
'status_error': None,
'latest_request_id': account_products_list_response.get('card_brand', {}).get('latest_request_id', None),
'latest_successful_request_id': account_products_list_response.get('card_brand', {}).get('latest_successful_request_id', None),
'is_subscribable': True,
'created_at': account_products_list_response.get('card_brand', {}).get('created_at', ''),
'updated_at': account_products_list_response.get('card_brand', {}).get('updated_at', ''),
},
'payment_instrument': {
'id': account_products_list_response.get('payment_instrument', {}).get('id', ''),
'name': 'payment_instrument',
'status': 'restricted',
'status_error': account_products_list_response.get('payment_instrument', {}).get('status_error', None),
'latest_request_id': account_products_list_response.get('payment_instrument', {}).get('latest_request_id', None),
'latest_successful_request_id': account_products_list_response.get('payment_instrument', {}).get('latest_successful_request_id', None),
'is_subscribable': True,
'created_at': account_products_list_response.get('payment_instrument', {}).get('created_at', ''),
'updated_at': account_products_list_response.get('payment_instrument', {}).get('updated_at', ''),
Expand All @@ -1104,112 +1105,6 @@ def test_list_account_products(setup):

assert account_products_list_response == expect_results


def test_retrieve_account_product(setup):
test_credit_card_account = setup['test_credit_card_account']
account_products_list_response = method.accounts(test_credit_card_account['id']).products.list()

balance_product_id = account_products_list_response.get('balance', {}).get('id', '')
payment_product_id = account_products_list_response.get('payment', {}).get('id', '')
sensitive_product_id = account_products_list_response.get('sensitive', {}).get('id', '')
update_product_id = account_products_list_response.get('update', {}).get('id', '')
attribute_product_id = account_products_list_response.get('attribute', {}).get('id', '')
transaction_product_id = account_products_list_response.get('transaction', {}).get('id', '')
payment_instrument_product_id = account_products_list_response.get('payment_instrument', {}).get('id', '')

balance_product_response = method.accounts(test_credit_card_account['id']).products.retrieve(balance_product_id)
payment_product_response = method.accounts(test_credit_card_account['id']).products.retrieve(payment_product_id)
sensitive_product_response = method.accounts(test_credit_card_account['id']).products.retrieve(sensitive_product_id)
update_product_response = method.accounts(test_credit_card_account['id']).products.retrieve(update_product_id)
attribute_product_response = method.accounts(test_credit_card_account['id']).products.retrieve(attribute_product_id)
transaction_product_response = method.accounts(test_credit_card_account['id']).products.retrieve(transaction_product_id)
payment_instrument_product_response = method.accounts(test_credit_card_account['id']).products.retrieve(payment_instrument_product_id)

expect_balance_results: AccountProduct = {
'id': balance_product_id,
'name': 'balance',
'status': 'available',
'status_error': None,
'latest_request_id': balance_product_response['latest_request_id'],
'is_subscribable': False,
'created_at': balance_product_response['created_at'],
'updated_at': balance_product_response['updated_at']
}

expect_payment_results: AccountProduct = {
'id': payment_product_id,
'name': 'payment',
'status': 'available',
'status_error': None,
'latest_request_id': payment_product_response['latest_request_id'],
'is_subscribable': False,
'created_at': payment_product_response['created_at'],
'updated_at': payment_product_response['updated_at']
}

expect_sensitive_results: AccountProduct = {
'id': sensitive_product_id,
'name': 'sensitive',
'status': 'available',
'status_error': None,
'latest_request_id': sensitive_product_response['latest_request_id'],
'is_subscribable': False,
'created_at': sensitive_product_response['created_at'],
'updated_at': sensitive_product_response['updated_at']
}

expect_update_results: AccountProduct = {
'id': update_product_id,
'name': 'update',
'status': 'available',
'status_error': None,
'latest_request_id': update_product_response['latest_request_id'],
'is_subscribable': True,
'created_at': update_product_response['created_at'],
'updated_at': update_product_response['updated_at']
}

expect_attribute_results: AccountProduct = {
'id': attribute_product_id,
'name': 'attribute',
'status': 'available',
'status_error': None,
'latest_request_id': attribute_product_response['latest_request_id'],
'is_subscribable': False,
'created_at': attribute_product_response['created_at'],
'updated_at': attribute_product_response['updated_at']
}

expect_transaction_results: AccountProduct = {
'id': transaction_product_id,
'name': 'transaction',
'status': 'unavailable',
'status_error': transaction_product_response['status_error'],
'latest_request_id': transaction_product_response['latest_request_id'],
'is_subscribable': True,
'created_at': transaction_product_response['created_at'],
'updated_at': transaction_product_response['updated_at']
}

expect_payment_instrument_results: AccountProduct = {
'id': payment_instrument_product_id,
'name': 'payment_instrument',
'status': 'restricted',
'status_error': payment_instrument_product_response['status_error'],
'latest_request_id': payment_instrument_product_response['latest_request_id'],
'is_subscribable': True,
'created_at': payment_instrument_product_response['created_at'],
'updated_at': payment_instrument_product_response['updated_at']
}

assert balance_product_response == expect_balance_results
assert payment_product_response == expect_payment_results
assert sensitive_product_response == expect_sensitive_results
assert update_product_response == expect_update_results
assert attribute_product_response == expect_attribute_results
assert transaction_product_response == expect_transaction_results
assert payment_instrument_product_response == expect_payment_instrument_results

def test_withdraw_account_consent(setup):
test_credit_card_account = setup['test_credit_card_account']
holder_1_response = setup['holder_1_response']
Expand Down
Loading