mirror of
https://github.com/maybe-finance/maybe.git
synced 2025-07-24 07:39:39 +02:00
* PlaidConnectable concern * Remove bad abstraction * Put sync implementations in own concerns * Sync strategies * Move sync orchestration to Sync class * Clean up sync class, add state machine * Basic market data sync cron * Fix price sync * Improve sync window column names, add timestamps * 30 day syncs by default * Clean up market data methods * Report high duplicate sync counts to Sentry * Add sync states throughout app * account tab session * Persistent account tab selections * Remove manual sleep * Add migration to clear stale syncs on self hosted apps * Tweak sync states * Sync completion event broadcasts * Fix timezones in tests * Cleanup * More cleanup * Plaid item UI broadcasts for sync * Fix account ID namespace conflict * Sync broadcasters * Smoother account sync refreshes * Remove test sync delay
87 lines
2.7 KiB
Ruby
87 lines
2.7 KiB
Ruby
require "test_helper"
|
|
|
|
class EntryTest < ActiveSupport::TestCase
|
|
include EntriesTestHelper
|
|
|
|
setup do
|
|
@entry = entries :transaction
|
|
end
|
|
|
|
test "entry cannot be older than 10 years ago" do
|
|
assert_raises ActiveRecord::RecordInvalid do
|
|
@entry.update! date: 50.years.ago.to_date
|
|
end
|
|
end
|
|
|
|
test "valuations cannot have more than one entry per day" do
|
|
existing_valuation = entries :valuation
|
|
|
|
new_valuation = Entry.new \
|
|
entryable: Valuation.new,
|
|
account: existing_valuation.account,
|
|
date: existing_valuation.date, # invalid
|
|
currency: existing_valuation.currency,
|
|
amount: existing_valuation.amount
|
|
|
|
assert new_valuation.invalid?
|
|
end
|
|
|
|
test "triggers sync with correct start date when transaction is set to prior date" do
|
|
prior_date = @entry.date - 1
|
|
@entry.update! date: prior_date
|
|
|
|
@entry.account.expects(:sync_later).with(window_start_date: prior_date)
|
|
@entry.sync_account_later
|
|
end
|
|
|
|
test "triggers sync with correct start date when transaction is set to future date" do
|
|
prior_date = @entry.date
|
|
@entry.update! date: @entry.date + 1
|
|
|
|
@entry.account.expects(:sync_later).with(window_start_date: prior_date)
|
|
@entry.sync_account_later
|
|
end
|
|
|
|
test "triggers sync with correct start date when transaction deleted" do
|
|
@entry.destroy!
|
|
|
|
@entry.account.expects(:sync_later).with(window_start_date: nil)
|
|
@entry.sync_account_later
|
|
end
|
|
|
|
test "can search entries" do
|
|
family = families(:empty)
|
|
account = family.accounts.create! name: "Test", balance: 0, currency: "USD", accountable: Depository.new
|
|
category = family.categories.first
|
|
merchant = family.merchants.first
|
|
|
|
create_transaction(account: account, name: "a transaction")
|
|
create_transaction(account: account, name: "ignored")
|
|
create_transaction(account: account, name: "third transaction", category: category, merchant: merchant)
|
|
|
|
params = { search: "a" }
|
|
|
|
assert_equal 2, family.entries.search(params).size
|
|
|
|
params = { search: "%" }
|
|
assert_equal 0, family.entries.search(params).size
|
|
end
|
|
|
|
test "active scope only returns entries from active accounts" do
|
|
# Create transactions for all account types
|
|
active_transaction = create_transaction(account: accounts(:depository), name: "Active transaction")
|
|
inactive_transaction = create_transaction(account: accounts(:credit_card), name: "Inactive transaction")
|
|
|
|
# Update account statuses
|
|
accounts(:credit_card).update!(is_active: false)
|
|
|
|
# Test the scope
|
|
active_entries = Entry.active
|
|
|
|
# Should include entry from active account
|
|
assert_includes active_entries, active_transaction
|
|
|
|
# Should not include entry from inactive account
|
|
assert_not_includes active_entries, inactive_transaction
|
|
end
|
|
end
|