firefly-iii/tests/functional/TransactionControllerCest.php

342 lines
13 KiB
PHP
Raw Normal View History

<?php
/**
* Class TransactionControllerCest
*/
class TransactionControllerCest
{
/**
* @param FunctionalTester $I
*/
public function _after(FunctionalTester $I)
{
}
/**
* @param FunctionalTester $I
*/
public function _before(FunctionalTester $I)
{
$I->amLoggedAs(['email' => 'thegrumpydictator@gmail.com', 'password' => 'james']);
}
public function create(FunctionalTester $I)
{
$I->wantTo('create a transaction');
$I->amOnPage('/transactions/create/withdrawal?account_id=1');
$I->see('Add a new withdrawal');
}
2015-01-01 12:35:10 -06:00
public function deleteWithdrawal(FunctionalTester $I)
{
// get withdrawal transaction type id:
$type = TransactionType::whereType('Withdrawal')->first();
// get a journal
$journal = TransactionJournal::where('transaction_type_id', $type->id)->first();
$I->wantTo('delete a transaction');
2015-01-01 12:35:10 -06:00
$I->amOnPage('/transaction/delete/' . $journal->id);
$I->see('Delete withdrawal "' . $journal->description . '"');
}
public function destroyDeposit(FunctionalTester $I)
{
// get withdrawal transaction type id:
$type = TransactionType::whereType('Deposit')->first();
// get a journal
$journal = TransactionJournal::where('transaction_type_id', $type->id)->first();
$I->wantTo('destroy a deposit');
2015-01-01 12:35:10 -06:00
$I->amOnPage('/transaction/delete/' . $journal->id);
$I->submitForm('#destroy', []);
2015-01-01 12:35:10 -06:00
$I->see('Transaction &quot;' . $journal->description . '&quot; destroyed.');
}
public function destroyTransfer(FunctionalTester $I)
{
// get withdrawal transaction type id:
$type = TransactionType::whereType('Transfer')->first();
// get a journal
$journal = TransactionJournal::where('transaction_type_id', $type->id)->first();
$I->wantTo('destroy a transfer');
$I->amOnPage('/transaction/delete/' . $journal->id);
$I->submitForm('#destroy', []);
2015-01-01 12:35:10 -06:00
$I->see('Transaction &quot;' . $journal->description . '&quot; destroyed.');
}
2014-12-30 17:25:17 -06:00
public function destroyWithdrawal(FunctionalTester $I)
{
// get withdrawal transaction type id:
$type = TransactionType::whereType('Withdrawal')->first();
// get a journal
$journal = TransactionJournal::where('transaction_type_id', $type->id)->first();
2014-12-30 17:25:17 -06:00
$I->wantTo('destroy a withdrawal');
2015-01-01 12:35:10 -06:00
$I->amOnPage('/transaction/delete/' . $journal->id);
2014-12-30 17:25:17 -06:00
$I->submitForm('#destroy', []);
2015-01-01 12:35:10 -06:00
$I->see('Transaction &quot;' . $journal->description . '&quot; destroyed.');
2014-12-30 17:25:17 -06:00
}
public function edit(FunctionalTester $I)
{
// get withdrawal transaction type id:
$type = TransactionType::whereType('Transfer')->first();
// get a journal
$journal = TransactionJournal::where('transaction_type_id', $type->id)->first();
$I->wantTo('edit a transaction');
$I->amOnPage('/transaction/edit/' . $journal->id);
$I->see('Edit transfer &quot;' . $journal->description . '&quot;');
}
public function index(FunctionalTester $I)
{
$I->wantTo('see all withdrawals');
$I->amOnPage('/transactions/withdrawal');
$I->see('Expenses');
}
public function indexExpenses(FunctionalTester $I)
{
$I->wantTo('see all expenses');
$I->amOnPage('/transactions/deposit');
$I->see('Revenue, income and deposits');
}
public function indexTransfers(FunctionalTester $I)
{
$I->wantTo('see all transfers');
$I->amOnPage('/transactions/transfers');
$I->see('Transfers');
}
public function show(FunctionalTester $I)
{
// get withdrawal transaction type id:
$type = TransactionType::whereType('Withdrawal')->first();
// get a journal
$journal = TransactionJournal::where('transaction_type_id', $type->id)->first();
$I->wantTo('see a transaction');
$I->amOnPage('/transaction/show/' . $journal->id);
2015-01-01 12:35:10 -06:00
$I->see($journal->description);
$I->see(intval($journal->getAmount()));
}
/**
* @param FunctionalTester $I
*/
2015-01-02 06:57:40 -06:00
public function showGroupedJournal(FunctionalTester $I)
{
$groupRow = DB::table('transaction_group_transaction_journal')->select('transaction_journal_id')->first(['transaction_journal_id']);
$id = $groupRow->transaction_journal_id;
// get a grouped journal:
$journal = TransactionJournal::find($id);
2015-01-02 06:57:40 -06:00
$I->wantTo('see a grouped transaction');
$I->amOnPage('/transaction/show/' . $journal->id);
$I->see($journal->description);
}
public function store(FunctionalTester $I)
{
$I->wantTo('store a transaction');
$I->amOnPage('/transactions/create/withdrawal');
2014-12-30 17:25:17 -06:00
$I->submitForm(
'#store', [
'reminder' => '',
'description' => 'Test',
'account_id' => 1,
'expense_account' => 'Zomaar',
'amount' => 100,
'date' => '2014-12-30',
'budget_id' => 3,
'category' => 'Categorrr',
'post_submit_action' => 'store'
]
);
$I->see('Transaction &quot;Test&quot; stored.');
}
public function storeAndFail(FunctionalTester $I)
2015-01-25 08:29:09 -06:00
{
$I->wantTo('store a transaction and fail');
2015-01-25 08:29:09 -06:00
$I->amOnPage('/transactions/create/withdrawal');
$I->submitForm(
'#store', [
'reminder' => '',
'description' => '',
2015-01-25 08:29:09 -06:00
'account_id' => 1,
'expense_account' => 'Zomaar',
'amount' => 100,
'date' => '2014-12-30',
'budget_id' => 3,
'category' => 'Categorrr',
'post_submit_action' => 'store'
2015-01-25 08:29:09 -06:00
]
);
$I->see('Could not store transaction: The description field is required.');
2015-01-25 08:29:09 -06:00
}
public function storeAndReturn(FunctionalTester $I)
2014-12-30 17:25:17 -06:00
{
$I->wantTo('store a transaction');
2014-12-30 17:25:17 -06:00
$I->amOnPage('/transactions/create/withdrawal');
$I->submitForm(
'#store', [
'reminder' => '',
'description' => 'Test',
2014-12-30 17:25:17 -06:00
'account_id' => 1,
'expense_account' => 'Zomaar',
'amount' => 100,
'date' => '2014-12-30',
'budget_id' => 3,
'category' => 'Categorrr',
'post_submit_action' => 'create_another'
2014-12-30 17:25:17 -06:00
]
);
$I->see('Transaction &quot;Test&quot; stored.');
2014-12-30 17:25:17 -06:00
}
public function storeValidate(FunctionalTester $I)
2014-12-30 17:25:17 -06:00
{
$I->wantTo('validate a transaction');
2014-12-30 17:25:17 -06:00
$I->amOnPage('/transactions/create/withdrawal');
$I->submitForm(
'#store', [
'reminder' => '',
'description' => 'TestValidateMe',
2014-12-30 17:25:17 -06:00
'account_id' => 1,
'expense_account' => 'Zomaar',
'amount' => 100,
'date' => '2014-12-30',
'budget_id' => 3,
'category' => 'CategorrXXXXr',
'post_submit_action' => 'validate_only'
2014-12-30 17:25:17 -06:00
]
);
$I->see('OK');
$I->seeInSession('successes');
$I->dontSeeRecord('transaction_journals', ['description' => 'TestValidateMe']);
}
public function update(FunctionalTester $I)
{
// get withdrawal transaction type id:
$type = TransactionType::whereType('Deposit')->first();
// get a journal
$journal = TransactionJournal::where('transaction_type_id', $type->id)->first();
2015-01-01 12:35:10 -06:00
$I->wantTo('update a transaction');
2015-01-01 12:35:10 -06:00
$I->amOnPage('/transaction/edit/' . $journal->id);
$I->see($journal->description);
$I->submitForm(
'#update', [
2015-01-01 12:35:10 -06:00
'description' => $journal->description . '!',
'account_id' => 1,
'expense_account' => 'Portaal',
'amount' => 500,
2015-01-01 12:35:10 -06:00
'date' => $journal->date->format('Y-m-d'),
'budget_id' => is_null($journal->budgets()->first()) ? 0 : $journal->budgets()->first()->id,
'category' => is_null($journal->categories()->first()) ? '' : $journal->categories()->first()->id,
'post_submit_action' => 'update'
]
);
2015-01-01 12:35:10 -06:00
$I->see($journal->description . '!');
}
2014-12-30 17:25:17 -06:00
public function updateAndFail(FunctionalTester $I)
{
// get withdrawal transaction type id:
$type = TransactionType::whereType('Deposit')->first();
// get a journal
$journal = TransactionJournal::where('transaction_type_id', $type->id)->first();
2015-01-01 12:35:10 -06:00
2014-12-30 17:25:17 -06:00
$I->wantTo('update a transaction and fail');
2015-01-01 12:35:10 -06:00
$I->amOnPage('/transaction/edit/' . $journal->id);
$I->see($journal->description);
2014-12-30 17:25:17 -06:00
$I->submitForm(
'#update', [
'description' => '',
'account_id' => 1,
'expense_account' => 'Portaal',
'amount' => 500,
'date' => '2014-01-01',
'budget_id' => 2,
'category' => 'House',
'post_submit_action' => 'update'
]
);
2014-12-31 09:45:12 -06:00
$I->see('Could not update transaction: The description field is required.');
2014-12-30 17:25:17 -06:00
}
public function updateAndReturn(FunctionalTester $I)
{
// get withdrawal transaction type id:
$type = TransactionType::whereType('Deposit')->first();
// get a journal
$journal = TransactionJournal::where('transaction_type_id', $type->id)->first();
2014-12-30 17:25:17 -06:00
$I->wantTo('update a transaction and return to the edit screen');
2015-01-01 12:35:10 -06:00
$I->amOnPage('/transaction/edit/' . $journal->id);
$I->see($journal->description);
2014-12-30 17:25:17 -06:00
$I->submitForm(
'#update', [
2015-01-01 12:35:10 -06:00
'description' => $journal->description . '!',
2014-12-30 17:25:17 -06:00
'account_id' => 1,
'expense_account' => 'Portaal',
'amount' => 500,
2015-01-01 12:35:10 -06:00
'date' => $journal->date->format('Y-m-d'),
'budget_id' => is_null($journal->budgets()->first()) ? 0 : $journal->budgets()->first()->id,
'category' => is_null($journal->categories()->first()) ? '' : $journal->categories()->first()->id,
2014-12-30 17:25:17 -06:00
'post_submit_action' => 'return_to_edit'
]
);
2015-01-01 12:35:10 -06:00
$I->see($journal->description . '!');
2014-12-30 17:25:17 -06:00
}
public function updateValidate(FunctionalTester $I)
{
// get withdrawal transaction type id:
$type = TransactionType::whereType('Deposit')->first();
// get a journal
$journal = TransactionJournal::where('transaction_type_id', $type->id)->first();
$I->wantTo('validate an updated transaction');
$I->amOnPage('/transaction/edit/' . $journal->id);
$I->see($journal->description);
$I->submitForm(
'#update', [
'description' => $journal->description . 'XYZ',
'account_id' => 1,
'expense_account' => 'Portaal',
'amount' => 500,
'date' => $journal->date->format('Y-m-d'),
'budget_id' => is_null($journal->budgets()->first()) ? 0 : $journal->budgets()->first()->id,
'category' => is_null($journal->categories()->first()) ? '' : $journal->categories()->first()->id,
'post_submit_action' => 'validate_only'
]
);
$I->see($journal->description . 'XYZ');
$I->see('OK');
$I->seeInSession('successes');
}
2015-01-01 23:16:49 -06:00
}