1
0
Fork 0
mirror of https://github.com/maybe-finance/maybe.git synced 2025-07-24 07:39:39 +02:00
Maybe/test/models/category_test.rb
Zach Gollwitzer da18c3d850
Account namespace updates: part 6 (transactions) (#904)
* Move Transaction to Account namespace

* Fix improper routes, improve separation of concerns

* Replace account transactions list partial with view

* Remove logs

* Consolidate transaction views

* Remove unused code

* Transfer style tweaks

* Remove more unused code

* Add back totals by currency helper
2024-06-24 11:58:39 -04:00

51 lines
1.6 KiB
Ruby

require "test_helper"
class CategoryTest < ActiveSupport::TestCase
def setup
@family = families(:dylan_family)
end
test "create_default_categories should generate categories if none exist" do
@family.accounts.destroy_all
@family.categories.destroy_all
assert_difference "Category.count", Category::DEFAULT_CATEGORIES.size do
Category.create_default_categories(@family)
end
end
test "create_default_categories should raise when there are existing categories" do
assert_raises(ArgumentError) do
Category.create_default_categories(@family)
end
end
test "updating name should clear the internal_category field" do
category = Category.take
assert_changes "category.reload.internal_category", to: nil do
category.update_attribute(:name, "new name")
end
end
test "updating other field than name should not clear the internal_category field" do
category = Category.take
assert_no_changes "category.reload.internal_category" do
category.update_attribute(:color, "#000")
end
end
test "replacing and destroying" do
transactions = categories(:food_and_drink).transactions.to_a
categories(:food_and_drink).replace_and_destroy!(categories(:income))
assert_equal categories(:income), transactions.map { |t| t.reload.category }.uniq.first
end
test "replacing with nil should nullify the category" do
transactions = categories(:food_and_drink).transactions.to_a
categories(:food_and_drink).replace_and_destroy!(nil)
assert_nil transactions.map { |t| t.reload.category }.uniq.first
end
end