2024-05-17 09:09:32 -04:00
|
|
|
require "application_system_test_case"
|
|
|
|
|
|
|
|
class ImportsTest < ApplicationSystemTestCase
|
2024-10-01 10:47:59 -04:00
|
|
|
include ActiveJob::TestHelper
|
2024-05-17 09:09:32 -04:00
|
|
|
|
|
|
|
setup do
|
|
|
|
sign_in @user = users(:family_admin)
|
2025-03-17 11:54:53 -04:00
|
|
|
|
|
|
|
# Trade securities will be imported as "offline" tickers
|
|
|
|
Security.stubs(:provider).returns(nil)
|
2024-05-17 09:09:32 -04:00
|
|
|
end
|
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
test "transaction import" do
|
|
|
|
visit new_import_path
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
click_on "Import transactions"
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
fill_in "import[raw_file_str]", with: file_fixture("imports/transactions.csv").read
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
find('input[type="submit"][value="Upload CSV"]').click
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-23 11:20:55 -04:00
|
|
|
select "Date", from: "Date*"
|
2024-10-01 10:47:59 -04:00
|
|
|
select "YYYY-MM-DD", from: "Date format"
|
|
|
|
select "Amount", from: "Amount"
|
|
|
|
select "Account", from: "Account (optional)"
|
|
|
|
select "Name", from: "Name (optional)"
|
|
|
|
select "Category", from: "Category (optional)"
|
|
|
|
select "Tags", from: "Tags (optional)"
|
|
|
|
select "Notes", from: "Notes (optional)"
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
click_on "Apply configuration"
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
click_on "Next step"
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
assert_selector "h1", text: "Assign your categories"
|
|
|
|
click_on "Next"
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
assert_selector "h1", text: "Assign your tags"
|
|
|
|
click_on "Next"
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
assert_selector "h1", text: "Assign your accounts"
|
|
|
|
click_on "Next"
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
click_on "Publish import"
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
assert_text "Import in progress"
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
perform_enqueued_jobs
|
2024-07-16 15:23:45 +02:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
click_on "Check status"
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
assert_text "Import successful"
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
click_on "Back to dashboard"
|
|
|
|
end
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
test "trade import" do
|
|
|
|
visit new_import_path
|
2024-07-16 15:23:45 +02:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
click_on "Import investments"
|
2024-07-16 15:23:45 +02:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
fill_in "import[raw_file_str]", with: file_fixture("imports/trades.csv").read
|
2024-07-16 15:23:45 +02:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
find('input[type="submit"][value="Upload CSV"]').click
|
2024-07-16 15:23:45 +02:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
select "YYYY-MM-DD", from: "Date format"
|
2024-07-16 15:23:45 +02:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
click_on "Apply configuration"
|
2024-07-16 15:23:45 +02:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
click_on "Next step"
|
2024-07-16 15:23:45 +02:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
assert_selector "h1", text: "Assign your accounts"
|
|
|
|
click_on "Next"
|
2024-07-16 15:23:45 +02:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
click_on "Publish import"
|
2024-07-16 15:23:45 +02:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
assert_text "Import in progress"
|
2024-07-16 15:23:45 +02:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
perform_enqueued_jobs
|
2024-07-16 15:23:45 +02:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
click_on "Check status"
|
2024-07-16 15:23:45 +02:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
assert_text "Import successful"
|
|
|
|
|
|
|
|
click_on "Back to dashboard"
|
|
|
|
end
|
|
|
|
|
|
|
|
test "account import" do
|
|
|
|
visit new_import_path
|
|
|
|
|
|
|
|
click_on "Import accounts"
|
2024-07-16 15:23:45 +02:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
fill_in "import[raw_file_str]", with: file_fixture("imports/accounts.csv").read
|
2024-07-16 15:23:45 +02:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
find('input[type="submit"][value="Upload CSV"]').click
|
2024-07-16 15:23:45 +02:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
click_on "Apply configuration"
|
2024-07-16 15:23:45 +02:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
click_on "Next step"
|
2024-07-16 15:23:45 +02:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
assert_selector "h1", text: "Assign your account types"
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
all("form").each do |form|
|
|
|
|
within(form) do
|
|
|
|
select = form.find("select")
|
|
|
|
select "Depository", from: select["id"]
|
2024-10-21 11:13:55 -03:00
|
|
|
sleep 0.5
|
2024-10-01 10:47:59 -04:00
|
|
|
end
|
2024-05-17 09:09:32 -04:00
|
|
|
end
|
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
click_on "Next"
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
click_on "Publish import"
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
assert_text "Import in progress"
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
perform_enqueued_jobs
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
click_on "Check status"
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
assert_text "Import successful"
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
click_on "Back to dashboard"
|
2024-05-17 09:09:32 -04:00
|
|
|
end
|
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
test "mint import" do
|
|
|
|
visit new_import_path
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
click_on "Import from Mint"
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
fill_in "import[raw_file_str]", with: file_fixture("imports/mint.csv").read
|
2024-05-17 09:09:32 -04:00
|
|
|
|
2024-10-01 10:47:59 -04:00
|
|
|
find('input[type="submit"][value="Upload CSV"]').click
|
|
|
|
|
|
|
|
click_on "Apply configuration"
|
|
|
|
|
|
|
|
click_on "Next step"
|
|
|
|
|
|
|
|
assert_selector "h1", text: "Assign your categories"
|
|
|
|
click_on "Next"
|
|
|
|
|
|
|
|
assert_selector "h1", text: "Assign your tags"
|
|
|
|
click_on "Next"
|
|
|
|
|
|
|
|
assert_selector "h1", text: "Assign your accounts"
|
|
|
|
click_on "Next"
|
|
|
|
|
|
|
|
click_on "Publish import"
|
|
|
|
|
|
|
|
assert_text "Import in progress"
|
|
|
|
|
|
|
|
perform_enqueued_jobs
|
|
|
|
|
|
|
|
click_on "Check status"
|
|
|
|
|
|
|
|
assert_text "Import successful"
|
|
|
|
|
|
|
|
click_on "Back to dashboard"
|
|
|
|
end
|
2024-05-17 09:09:32 -04:00
|
|
|
end
|