import { request, expect, create, login } from '~/testInit'; import knex from '@/database/knex'; import Account from '@/models/Account'; let loginRes; describe('routes: /accounts/', () => { beforeEach(async () => { loginRes = await login(); }); afterEach(() => { loginRes = null; }); describe('POST `/accounts`', () => { it('Should `name` be required.', async () => { const res = await request() .post('/api/accounts') .set('x-access-token', loginRes.body.token) .send(); expect(res.status).equals(422); expect(res.body.code).equals('validation_error'); }); it('Should `account_type_id` be required.', async () => { const res = await request() .post('/api/accounts') .set('x-access-token', loginRes.body.token) .send(); expect(res.status).equals(422); expect(res.body.code).equals('validation_error'); }); it('Should max length of `code` be limited.', async () => { const res = await request() .post('/api/accounts') .set('x-access-token', loginRes.body.token) .send(); expect(res.status).equals(422); expect(res.body.code).equals('validation_error'); }); it('Should response type not found in case `account_type_id` was not exist.', async () => { const account = await create('account'); const res = await request() .post('/api/accounts') .set('x-access-token', loginRes.body.token) .send({ name: 'Account Name', description: account.description, account_type_id: 22, // not found. code: 123, }); expect(res.status).equals(400); expect(res.body.errors).include.something.that.deep.equals({ type: 'NOT_EXIST_ACCOUNT_TYPE', code: 200, }); }); it('Should account code be unique in the storage.', async () => { const account = await create('account'); const res = await request() .post('/api/accounts') .set('x-access-token', loginRes.body.token) .send({ name: account.name, description: account.description, account_type_id: account.accountTypeId, code: account.code, }); expect(res.status).equals(400); expect(res.body.errors).include.something.that.deep.equals({ type: 'NOT_UNIQUE_CODE', code: 100, }); }); it('Should response success with correct data form.', async () => { const account = await create('account'); const res = await request() .post('/api/accounts') .set('x-access-token', loginRes.body.token) .send({ name: 'Name', description: 'description here', code: 100, account_type_id: account.accountTypeId, parent_account_id: account.id, }); console.log(res.body); expect(res.status).equals(200); }); it('Should store account data in the storage.', async () => { const account = await create('account'); await request().post('/api/accounts') .set('x-access-token', loginRes.body.token) .send({ name: 'Account Name', description: 'desc here', account_type: account.account_type_id, parent_account_id: account.id, }); const accountModel = await Account.query().where('name', 'Account Name'); expect(accountModel.description).equals('desc here'); expect(accountModel.account_type_id).equals(account.account_type_id); expect(accountModel.parent_account_id).equals(account.parent_account_id); }); }); describe('POST `/accounts/:id`', () => { it('Should `name` be required.', async () => { const account = await create('account'); const res = await request() .post(`/api/accounts/${account.id}`) .set('x-access-token', loginRes.body.token) .send(); expect(res.status).equals(422); expect(res.body.code).equals('validation_error'); }); it('Should `account_type_id` be required.', async () => { const account = await create('account'); const res = await request() .post(`/api/accounts/${account.id}`) .set('x-access-token', loginRes.body.token) .send(); expect(res.status).equals(422); expect(res.body.code).equals('validation_error'); }); it('Should max length of `code` be limited.', async () => { const account = await create('account'); const res = await request() .post(`/api/accounts/${account.id}`) .set('x-access-token', loginRes.body.token) .send(); expect(res.status).equals(422); expect(res.body.code).equals('validation_error'); }); it('Should response type not found in case `account_type_id` was not exist.', async () => { const res = await request() .post('/api/accounts') .set('x-access-token', loginRes.body.token) .send(); expect(res.status).equals(422); }); it('Should account code be unique in the storage.', async () => { await create('account', { code: 'ABCD' }); const account = await create('account'); const res = await request() .post(`/api/accounts/${account.id}`) .set('x-access-token', loginRes.body.token) .send({ name: 'name', code: 'ABCD', account_type_id: account.accountTypeId, }); expect(res.status).equals(400); expect(res.body.errors).include.something.that.deep.equals({ type: 'NOT_UNIQUE_CODE', code: 100, }); }); it('Should response success with correct data form.', async () => { const account = await create('account'); const res = await request() .post('/api/accounts') .set('x-access-token', loginRes.body.token) .send({ name: 'Name', description: 'description here', account_type_id: account.accountTypeId, parent_account_id: account.id, code: '123', }); expect(res.status).equals(200); }); }); describe('GET: `/accounts`', () => { it('Should retrieve chart of accounts', async () => { const account = await create('account'); const account2 = await create('account', { parent_account_id: account.id }); const res = await request() .get('/api/accounts') .set('x-access-token', loginRes.body.token) .send() console.log(res.body); }); }); describe('DELETE: `/accounts`', () => { it('Should response not found in case account was not exist.', async () => { const res = await request() .delete('/api/accounts/10') .set('x-access-token', loginRes.body.token) .send(); expect(res.status).equals(404); }); it('Should delete the give account from the storage.', async () => { const account = await create('account'); await request() .delete(`/api/accounts/${account.id}`) .set('x-access-token', loginRes.body.token) .send(); const foundAccounts = await Account.query().where('id', account.id); expect(foundAccounts).to.have.lengthOf(0); }); it('Should not delete the given account in case account has associated transactions.', async () => { const accountTransaction = await create('account_transaction'); const res = await request() .delete(`/api/accounts/${accountTransaction.accountId}`) .set('x-access-token', loginRes.body.token) .send(); expect(res.status).equals(400); expect(res.body.errors).include.something.that.deep.equals({ type: 'ACCOUNT.HAS.ASSOCIATED.TRANSACTIONS', code: 100, }); }); }); });