mirror of
https://github.com/maybe-finance/maybe.git
synced 2025-07-18 20:59:39 +02:00
* Basic plaid data model and linking * Remove institutions, add plaid items * Improve schema and Plaid provider * Add webhook verification sketch * Webhook verification * Item accounts and balances sync setup * Provide test encryption keys * Fix test * Only provide encryption keys in prod * Try defining keys in test env * Consolidate account sync logic * Add back plaid account initialization * Plaid transaction sync * Sync UI overhaul for Plaid * Add liability and investment syncing * Handle investment webhooks and process current day holdings * Remove logs * Remove "all" period select for performance * fix amount calc * Remove todo comment * Coming soon for investment historical data * Document Plaid configuration * Listen for holding updates
65 lines
1.9 KiB
Ruby
65 lines
1.9 KiB
Ruby
require "test_helper"
|
|
|
|
class Account::EntriesControllerTest < ActionDispatch::IntegrationTest
|
|
setup do
|
|
sign_in @user = users(:family_admin)
|
|
@transaction = account_entries :transaction
|
|
@valuation = account_entries :valuation
|
|
@trade = account_entries :trade
|
|
end
|
|
|
|
# =================
|
|
# Shared
|
|
# =================
|
|
|
|
test "should destroy entry" do
|
|
[ @transaction, @valuation, @trade ].each do |entry|
|
|
assert_difference -> { Account::Entry.count } => -1, -> { entry.entryable_class.count } => -1 do
|
|
delete account_entry_url(entry.account, entry)
|
|
end
|
|
|
|
assert_redirected_to account_url(entry.account)
|
|
assert_enqueued_with(job: SyncJob)
|
|
end
|
|
end
|
|
|
|
test "gets show" do
|
|
[ @transaction, @valuation, @trade ].each do |entry|
|
|
get account_entry_url(entry.account, entry)
|
|
assert_response :success
|
|
end
|
|
end
|
|
|
|
test "gets edit" do
|
|
[ @valuation ].each do |entry|
|
|
get edit_account_entry_url(entry.account, entry)
|
|
assert_response :success
|
|
end
|
|
end
|
|
|
|
test "can update generic entry" do
|
|
[ @transaction, @valuation, @trade ].each do |entry|
|
|
assert_no_difference_in_entries do
|
|
patch account_entry_url(entry.account, entry), params: {
|
|
account_entry: {
|
|
name: "Name",
|
|
date: Date.current,
|
|
currency: "USD",
|
|
amount: 100
|
|
}
|
|
}
|
|
end
|
|
|
|
assert_redirected_to account_entry_url(entry.account, entry)
|
|
assert_enqueued_with(job: SyncJob)
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
# Simple guard to verify that nested attributes are passed the record ID to avoid new creation of record
|
|
# See `update_only` option of accepts_nested_attributes_for
|
|
def assert_no_difference_in_entries(&block)
|
|
assert_no_difference [ "Account::Entry.count", "Account::Transaction.count", "Account::Valuation.count" ], &block
|
|
end
|
|
end
|