Skip to content

Commit

Permalink
common: add escrow accounts test
Browse files Browse the repository at this point in the history
Signed-off-by: Gustavo Inacio <gustavo@semiotic.ai>
  • Loading branch information
gusinacio committed Oct 10, 2024
1 parent 0cb1056 commit 6b347aa
Show file tree
Hide file tree
Showing 2 changed files with 71 additions and 1 deletion.
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
import { Address, toAddress } from '@graphprotocol/common-ts'
import { EscrowAccountResponse, EscrowAccounts } from '../escrow-accounts'

const timeout = 30000

const SENDER_ADDRESS_1 = toAddress('ffcf8fdee72ac11b5c542428b35eef5769c409f0')
const SENDER_ADDRESS_2 = toAddress('dead47df40c29949a75a6693c77834c00b8ad624')
const SENDER_ADDRESS_3 = toAddress('6aea8894b5ab5a36cdc2d8be9290046801dd5fed')

describe('EscrowAccounts', () => {
test(
'fromResponse should create correctly EscrowAccount',
() => {
const response: EscrowAccountResponse = {
escrowAccounts: [
{
sender: {
id: SENDER_ADDRESS_1,
},
balance: '1000',
},
{
sender: {
id: SENDER_ADDRESS_2,
},
balance: '2000',
},
],
}

const escrowAccounts = EscrowAccounts.fromResponse(response)

expect(escrowAccounts.getBalanceForSender(SENDER_ADDRESS_1)).toEqual(1000n)
expect(escrowAccounts.getBalanceForSender(SENDER_ADDRESS_2)).toEqual(2000n)
expect(() => escrowAccounts.getBalanceForSender(SENDER_ADDRESS_3)).toThrowError()
},
timeout,
)
test('test subtractSenderBalance', () => {
const balances = new Map<Address, bigint>()
balances.set(SENDER_ADDRESS_1, 1000n)
balances.set(SENDER_ADDRESS_2, 1000n)
balances.set(SENDER_ADDRESS_3, 1000n)
const escrowAccounts = new EscrowAccounts(balances)

expect(escrowAccounts.getBalanceForSender(SENDER_ADDRESS_1)).toEqual(1000n)

escrowAccounts.subtractSenderBalance(SENDER_ADDRESS_1, 100n)
expect(escrowAccounts.getBalanceForSender(SENDER_ADDRESS_1)).toEqual(900n)

escrowAccounts.subtractSenderBalance(SENDER_ADDRESS_1, 100n)
expect(escrowAccounts.getBalanceForSender(SENDER_ADDRESS_1)).toEqual(800n)

escrowAccounts.subtractSenderBalance(SENDER_ADDRESS_1, 600n)
expect(escrowAccounts.getBalanceForSender(SENDER_ADDRESS_1)).toEqual(200n)

expect(() =>
escrowAccounts.subtractSenderBalance(SENDER_ADDRESS_1, 400n),
).toThrowError()

escrowAccounts.subtractSenderBalance(SENDER_ADDRESS_1, 200n)

expect(escrowAccounts.getBalanceForSender(SENDER_ADDRESS_1)).toEqual(0n)
expect(escrowAccounts.getBalanceForSender(SENDER_ADDRESS_2)).toEqual(1000n)
expect(escrowAccounts.getBalanceForSender(SENDER_ADDRESS_3)).toEqual(1000n)
})
})
5 changes: 4 additions & 1 deletion packages/indexer-common/src/allocations/escrow-accounts.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import gql from 'graphql-tag'

type U256 = bigint

type EscrowAccountResponse = {
export type EscrowAccountResponse = {
escrowAccounts: {
balance: string
sender: {
Expand All @@ -26,6 +26,9 @@ export class EscrowAccounts {

subtractSenderBalance(sender: Address, ravValue: U256) {
const balance = this.getBalanceForSender(sender)
if (balance < ravValue) {
throw new Error(`Negative balances are not allowed`)
}
const newBalance = balance - ravValue
this.sendersBalances.set(sender, newBalance)
}
Expand Down

0 comments on commit 6b347aa

Please sign in to comment.