use of com.hedera.mirror.common.domain.token.TokenTransfer in project hedera-mirror-node by hashgraph.
the class TransferTransactionPayerMigrationTest method persistTokenTransfers.
private void persistTokenTransfers(List<TokenTransfer> tokenTransfers) {
for (TokenTransfer tokenTransfer : tokenTransfers) {
var id = tokenTransfer.getId();
jdbcOperations.update("insert into token_transfer (amount, account_id, consensus_timestamp, token_id)" + " values (?,?,?,?)", tokenTransfer.getAmount(), id.getAccountId().getId(), id.getConsensusTimestamp(), id.getTokenId().getId());
}
}
use of com.hedera.mirror.common.domain.token.TokenTransfer in project hedera-mirror-node by hashgraph.
the class BatchUpserterTest method tokenDissociateTransfer.
@Test
void tokenDissociateTransfer() {
// given
EntityId accountId = EntityId.of("0.0.215", ACCOUNT);
EntityId accountId2 = EntityId.of("0.0.216", ACCOUNT);
Token nftClass1 = getDeletedNftClass(10L, 25L, EntityId.of("0.0.100", TOKEN));
Token nftClass2 = getDeletedNftClass(11L, 24L, EntityId.of("0.0.101", TOKEN));
EntityId tokenId1 = nftClass1.getTokenId().getTokenId();
// already deleted, result of wipe
Nft nft1 = getNft(tokenId1, accountId, 1L, 11L, 16L, true);
Nft nft2 = getNft(tokenId1, accountId, 2L, 11L, 11L, false);
Nft nft3 = getNft(tokenId1, accountId, 3L, 12L, 12L, false);
// different account
Nft nft4 = getNft(tokenId1, accountId2, 4L, 18L, 18L, false);
Nft nft5 = getNft(nftClass2.getTokenId().getTokenId(), accountId, 1L, 15L, 15L, false);
nftRepository.saveAll(List.of(nft1, nft2, nft3, nft4, nft5));
tokenRepository.saveAll(List.of(nftClass1, nftClass2));
long consensusTimestamp = 30L;
EntityId ftId = EntityId.of("0.0.217", TOKEN);
EntityId payerId = EntityId.of("0.0.2002", ACCOUNT);
TokenTransfer fungibleTokenTransfer = domainBuilder.tokenTransfer().customize(t -> t.amount(-10).id(new TokenTransfer.Id(consensusTimestamp, ftId, accountId)).isApproval(false).payerAccountId(payerId).tokenDissociate(true)).get();
TokenTransfer nonFungibleTokenTransfer = domainBuilder.tokenTransfer().customize(t -> t.amount(-2).id(new TokenTransfer.Id(consensusTimestamp, tokenId1, accountId)).isApproval(false).payerAccountId(payerId).tokenDissociate(true)).get();
List<TokenTransfer> tokenTransfers = List.of(fungibleTokenTransfer, nonFungibleTokenTransfer);
// when
persist(tokenDissociateTransferBatchUpserter, tokenTransfers);
// then
assertThat(nftRepository.findAll()).containsExactlyInAnyOrder(nft1, getNft(tokenId1, accountId, 2L, 11L, 30L, true), getNft(tokenId1, accountId, 3L, 12L, 30L, true), nft4, nft5);
NftTransfer serial2Transfer = getNftTransfer(tokenId1, accountId, 2L, consensusTimestamp);
serial2Transfer.setPayerAccountId(payerId);
NftTransfer serial3Transfer = getNftTransfer(tokenId1, accountId, 3L, consensusTimestamp);
serial3Transfer.setPayerAccountId(payerId);
assertThat(nftTransferRepository.findAll()).containsExactlyInAnyOrder(serial2Transfer, serial3Transfer);
assertThat(tokenTransferRepository.findAll()).usingElementComparatorIgnoringFields("tokenDissociate").containsOnly(fungibleTokenTransfer);
}
Aggregations