diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 24aec5fff..526c15cca 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -399,7 +399,7 @@ jobs: report_name: Coverage Frontend type: lcov result_path: ./coverage/lcov.info - min_coverage: 90 + min_coverage: 94 token: ${{ github.token }} ############################################################################## diff --git a/backend/src/graphql/resolver/AdminResolver.ts b/backend/src/graphql/resolver/AdminResolver.ts index bae4369e8..416838c1c 100644 --- a/backend/src/graphql/resolver/AdminResolver.ts +++ b/backend/src/graphql/resolver/AdminResolver.ts @@ -16,6 +16,7 @@ import { TransactionCreation } from '@entity/TransactionCreation' import { UserTransaction } from '@entity/UserTransaction' import { UserTransactionRepository } from '../../typeorm/repository/UserTransaction' import { BalanceRepository } from '../../typeorm/repository/Balance' +import { calculateDecay } from '../../util/decay' @Resolver() export class AdminResolver { @@ -149,10 +150,11 @@ export class AdminResolver { const pendingCreation = await loginPendingTasksAdminRepository.findOneOrFail(id) const transactionRepository = getCustomRepository(TransactionRepository) + const receivedCallDate = new Date() let transaction = new Transaction() transaction.transactionTypeId = 1 transaction.memo = pendingCreation.memo - transaction.received = new Date() + transaction.received = receivedCallDate transaction.blockchainTypeId = 1 transaction = await transactionRepository.save(transaction) if (!transaction) throw new Error('Could not create transaction') @@ -174,7 +176,11 @@ export class AdminResolver { if (!lastUserTransaction) { newBalance = 0 } else { - newBalance = lastUserTransaction.balance + newBalance = await calculateDecay( + lastUserTransaction.balance, + lastUserTransaction.balanceDate, + receivedCallDate, + ) } newBalance = Number(newBalance) + Number(parseInt(pendingCreation.amount.toString())) @@ -195,8 +201,8 @@ export class AdminResolver { if (!userBalance) userBalance = balanceRepository.create() userBalance.userId = pendingCreation.userId userBalance.amount = Number(newBalance) - userBalance.modified = new Date() - userBalance.recordDate = userBalance.recordDate ? userBalance.recordDate : new Date() + userBalance.modified = receivedCallDate + userBalance.recordDate = receivedCallDate await balanceRepository.save(userBalance) await loginPendingTasksAdminRepository.delete(pendingCreation) diff --git a/frontend/src/plugins/globalDirectives.js b/frontend/src/plugins/globalDirectives.js index 1ef005f5b..836643706 100755 --- a/frontend/src/plugins/globalDirectives.js +++ b/frontend/src/plugins/globalDirectives.js @@ -1,4 +1,3 @@ -// import clickOutside from '@/directives/click-ouside.js' import { focus } from 'vue-focus' /** @@ -7,7 +6,6 @@ import { focus } from 'vue-focus' const GlobalDirectives = { install(Vue) { - // Vue.directive('click-outside', clickOutside) Vue.directive('focus', focus) }, } diff --git a/frontend/src/plugins/globalDirectives.test.js b/frontend/src/plugins/globalDirectives.test.js new file mode 100644 index 000000000..385ccb651 --- /dev/null +++ b/frontend/src/plugins/globalDirectives.test.js @@ -0,0 +1,21 @@ +import GlobalDirectives from './globalDirectives' +import { focus } from 'vue-focus' +import Vue from 'vue' + +jest.mock('vue-focus', () => { + return { + __esModule: true, + focus: jest.fn(), + } +}) +jest.mock('vue') + +const vueDirectiveMock = jest.fn() +Vue.directive = vueDirectiveMock + +describe('globalDirectives', () => { + it('installs the focus directive', () => { + GlobalDirectives.install(Vue) + expect(vueDirectiveMock).toBeCalledWith('focus', focus) + }) +}) diff --git a/frontend/src/views/Layout/DashboardLayout_gdd.spec.js b/frontend/src/views/Layout/DashboardLayout_gdd.spec.js index 3e03bec2e..4ea2e86b2 100644 --- a/frontend/src/views/Layout/DashboardLayout_gdd.spec.js +++ b/frontend/src/views/Layout/DashboardLayout_gdd.spec.js @@ -52,6 +52,7 @@ describe('DashboardLayoutGdd', () => { publisherId: 123, firstName: 'User', lastName: 'Example', + token: 'valid-token', }, dispatch: storeDispatchMock, commit: storeCommitMock, @@ -222,6 +223,65 @@ describe('DashboardLayoutGdd', () => { expect(toasterMock).toBeCalledWith('Ouch!') }) }) + + describe('set visible method', () => { + beforeEach(() => { + wrapper.findComponent({ name: 'Navbar' }).vm.$emit('set-visible', true) + }) + + it('sets visible to true', () => { + expect(wrapper.vm.visible).toBe(true) + }) + }) + + describe('elopage URI', () => { + describe('user has no publisher ID and no elopage', () => { + beforeEach(() => { + mocks.$store.state.publisherId = null + mocks.$store.state.hasElopage = false + wrapper = Wrapper() + }) + + it('links to basic-de', () => { + expect(wrapper.vm.elopageUri).toBe( + 'https://elopage.com/s/gradido/basic-de/payment?locale=en&prid=111&pid=2896&firstName=User&lastName=Example&email=user@example.org', + ) + }) + }) + + describe('user has elopage', () => { + beforeEach(() => { + mocks.$store.state.publisherId = '123' + mocks.$store.state.hasElopage = true + wrapper = Wrapper() + }) + + it('links to sign in for elopage', () => { + expect(wrapper.vm.elopageUri).toBe('https://elopage.com/s/gradido/sign_in?locale=en') + }) + }) + }) + + describe('admin method', () => { + const windowLocationMock = jest.fn() + beforeEach(() => { + delete window.location + window.location = { + assign: windowLocationMock, + } + wrapper.findComponent({ name: 'Navbar' }).vm.$emit('admin') + }) + + it('dispatches logout to store', () => { + expect(storeDispatchMock).toBeCalled() + }) + + it('changes window location to admin interface', () => { + expect(windowLocationMock).toBeCalledWith( + 'http://localhost/admin/authenticate?token=valid-token', + ) + }) + }) }) }) }) diff --git a/frontend/src/views/Pages/SendOverview.vue b/frontend/src/views/Pages/SendOverview.vue index fc0dc5692..822cc3117 100644 --- a/frontend/src/views/Pages/SendOverview.vue +++ b/frontend/src/views/Pages/SendOverview.vue @@ -70,11 +70,6 @@ export default { default: true, }, }, - computed: { - showContext() { - return this.currentTransactionStep === 0 - }, - }, methods: { setTransaction(data) { this.transactionData = { ...data }