1
0
Fork 0
mirror of https://github.com/maybe-finance/maybe.git synced 2025-07-19 13:19:39 +02:00
Maybe/test/controllers/plaid_items_controller_test.rb
Zach Gollwitzer 53f4b32c33
Fix EU plaid flow (#1761)
* Fix EU plaid flow

* Fix failing tests
2025-01-31 17:04:26 -05:00

49 lines
1.3 KiB
Ruby

require "test_helper"
require "ostruct"
class PlaidItemsControllerTest < ActionDispatch::IntegrationTest
setup do
sign_in @user = users(:family_admin)
end
test "create" do
@plaid_provider = mock
PlaidItem.expects(:plaid_provider_for_region).with("us").returns(@plaid_provider)
public_token = "public-sandbox-1234"
@plaid_provider.expects(:exchange_public_token).with(public_token).returns(
OpenStruct.new(access_token: "access-sandbox-1234", item_id: "item-sandbox-1234")
)
assert_difference "PlaidItem.count", 1 do
post plaid_items_url, params: {
plaid_item: {
public_token: public_token,
region: "us",
metadata: { institution: { name: "Plaid Item Name" } }
}
}
end
assert_equal "Account linked successfully. Please wait for accounts to sync.", flash[:notice]
assert_redirected_to accounts_path
end
test "destroy" do
delete plaid_item_url(plaid_items(:one))
assert_equal "Accounts scheduled for deletion.", flash[:notice]
assert_enqueued_with job: DestroyJob
assert_redirected_to accounts_path
end
test "sync" do
plaid_item = plaid_items(:one)
PlaidItem.any_instance.expects(:sync_later).once
post sync_plaid_item_url(plaid_item)
assert_redirected_to accounts_path
end
end