1
0
Fork 0
mirror of https://github.com/maybe-finance/maybe.git synced 2025-08-04 04:55:20 +02:00

Implement transaction category management (#688)

* Singularize "transaction" in transaction-nested paths

* Refactor category badge partial

* Let modal content define its width

* Add contectual menu to transactions index

* Add null_category helper

* Implement category edits

* Fix inline transaction category badges

* Fix typos in system test paths

* Add missing translations

* Add decoration to color select controller

* Wire up transaction category creation

* Fix indent in color-select-controller

* Add button for clearing category from transaction

* Implement category deletions

* Fix existing modal sizes

* Use null_category in a single place

* Remove anemic method in category deletion controller

* reassign_and_destroy -> reassign_transactions_then_destroy

* Fix i18n

* Remove destroy action from CategoriesController callbacks

* transactions_merchant -> transaction_merchant

* reassign_transactions_then_destroy -> replace_and_destroy

* Add transaction category CRUD tests

* Add presence check for transaction_id

* Check replacement_category_id presence

* Test Transaction::Category#replace_and_destroy!
This commit is contained in:
Jose Farias 2024-05-02 07:24:31 -06:00 committed by GitHub
parent dc024d63b0
commit 4c5f8263bc
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
40 changed files with 580 additions and 145 deletions

View file

@ -7,33 +7,33 @@ class Transactions::MerchantsControllerTest < ActionDispatch::IntegrationTest
end
test "index" do
get transactions_merchants_path
get transaction_merchants_path
assert_response :success
end
test "new" do
get new_transactions_merchant_path
get new_transaction_merchant_path
assert_response :success
end
test "should create merchant" do
assert_difference("Transaction::Merchant.count") do
post transactions_merchants_url, params: { transaction_merchant: { name: "new merchant", color: "#000000" } }
post transaction_merchants_url, params: { transaction_merchant: { name: "new merchant", color: "#000000" } }
end
assert_redirected_to transactions_merchants_path
assert_redirected_to transaction_merchants_path
end
test "should update merchant" do
patch transactions_merchant_url(@merchant), params: { transaction_merchant: { name: "new name", color: "#000000" } }
assert_redirected_to transactions_merchants_path
patch transaction_merchant_url(@merchant), params: { transaction_merchant: { name: "new name", color: "#000000" } }
assert_redirected_to transaction_merchants_path
end
test "should destroy merchant" do
assert_difference("Transaction::Merchant.count", -1) do
delete transactions_merchant_url(@merchant)
delete transaction_merchant_url(@merchant)
end
assert_redirected_to transactions_merchants_path
assert_redirected_to transaction_merchants_path
end
end