use of io.nem.symbol.sdk.api.BlockSearchCriteria in project nem2-sdk-java by nemtech.
the class BlockRepositoryIntegrationTest method searchOrderByHeightAsc.
@ParameterizedTest
@EnumSource(RepositoryType.class)
void searchOrderByHeightAsc(RepositoryType type) {
BlockSearchCriteria criteria = new BlockSearchCriteria();
criteria.setOrderBy(BlockOrderBy.HEIGHT);
criteria.setOrder(OrderBy.ASC);
BlockPaginationStreamer streamer = new BlockPaginationStreamer(getBlockRepository(type));
List<BlockInfo> blocks = get(streamer.search(criteria).toList().toObservable());
List<BlockInfo> sorted = blocks.stream().sorted(Comparator.comparing(BlockInfo::getHeight)).collect(Collectors.toList());
Assertions.assertEquals(blocks, sorted);
}
use of io.nem.symbol.sdk.api.BlockSearchCriteria in project nem2-sdk-java by nemtech.
the class BlockRepositoryIntegrationTest method searchByBeneficiaryAddressWhenInvalid.
@ParameterizedTest
@EnumSource(RepositoryType.class)
void searchByBeneficiaryAddressWhenInvalid(RepositoryType type) {
BlockRepository blockRepository = getBlockRepository(type);
BlockSearchCriteria criteria = new BlockSearchCriteria();
Address expectedBeneficiaryAddress = Account.generateNewAccount(getNetworkType()).getAddress();
criteria.setBeneficiaryAddress(expectedBeneficiaryAddress);
BlockPaginationStreamer streamer = new BlockPaginationStreamer(blockRepository);
List<BlockInfo> blocks = get(streamer.search(criteria).toList().toObservable());
Assertions.assertTrue(blocks.isEmpty());
}
use of io.nem.symbol.sdk.api.BlockSearchCriteria in project nem2-sdk-java by nemtech.
the class BlockRepositoryIntegrationTest method searchBySignerPublicKeyWhenInvalid.
@ParameterizedTest
@EnumSource(RepositoryType.class)
void searchBySignerPublicKeyWhenInvalid(RepositoryType type) {
BlockRepository blockRepository = getBlockRepository(type);
BlockSearchCriteria criteria = new BlockSearchCriteria();
PublicKey expectedSignerPublicKey = PublicKey.generateRandom();
criteria.setSignerPublicKey(expectedSignerPublicKey);
BlockPaginationStreamer streamer = new BlockPaginationStreamer(blockRepository);
List<BlockInfo> blocks = get(streamer.search(criteria).toList().toObservable());
Assertions.assertTrue(blocks.isEmpty());
}
use of io.nem.symbol.sdk.api.BlockSearchCriteria in project nem2-sdk-java by nemtech.
the class BlockRepositoryIntegrationTest method searchByBeneficiaryAddress.
@ParameterizedTest
@EnumSource(RepositoryType.class)
void searchByBeneficiaryAddress(RepositoryType type) {
BlockRepository blockRepository = getBlockRepository(type);
BlockInfo block1 = get(blockRepository.getBlockByHeight(BigInteger.ONE));
BlockSearchCriteria criteria = new BlockSearchCriteria();
Address expectedBeneficiaryAddress = block1.getBeneficiaryAddress();
criteria.setBeneficiaryAddress(expectedBeneficiaryAddress);
BlockPaginationStreamer streamer = new BlockPaginationStreamer(blockRepository);
List<BlockInfo> blocks = get(streamer.search(criteria).toList().toObservable());
blocks.forEach(b -> Assertions.assertEquals(expectedBeneficiaryAddress, b.getBeneficiaryAddress()));
Assertions.assertFalse(blocks.isEmpty());
}
use of io.nem.symbol.sdk.api.BlockSearchCriteria in project nem2-sdk-java by nemtech.
the class BlockRepositoryOkHttpImplTest method shouldGetBlocksByHeightWithLimit.
@Test
public void shouldGetBlocksByHeightWithLimit() throws Exception {
Address address = Address.generateRandom(networkType);
BlockInfoDTO dto = new BlockInfoDTO();
BlockMetaDTO metaDTO = new BlockMetaDTO();
metaDTO.setHash("someHash");
metaDTO.setTransactionsCount(10);
metaDTO.setGenerationHash("generationHash");
metaDTO.setStatementsCount(20);
metaDTO.setStateHashSubCacheMerkleRoots(Arrays.asList("string1", "string2"));
metaDTO.setTotalFee(BigInteger.valueOf(8));
dto.setMeta(metaDTO);
BlockDTO blockDto = new BlockDTO();
blockDto.setType(BlockType.NORMAL_BLOCK.getValue());
blockDto.setVersion(3);
blockDto.setSignerPublicKey("B630EFDDFADCC4A2077AB8F1EC846B08FEE2D2972EACF95BBAC6BFAC3D31834C");
blockDto.setBeneficiaryAddress(address.encoded());
blockDto.setHeight(BigInteger.valueOf(9L));
blockDto.setNetwork(NetworkTypeEnum.NUMBER_144);
blockDto.setProofGamma("proofGamma");
blockDto.setProofScalar("proofScalar");
blockDto.setProofVerificationHash("proofVerificationHash");
dto.setBlock(blockDto);
mockRemoteCall(Collections.singletonList(dto));
mockRemoteCall(toPage(dto));
BlockSearchCriteria criteria = new BlockSearchCriteria();
criteria.offset("abc");
List<BlockInfo> resolvedList = repository.search(criteria).toFuture().get().getData();
BlockInfo info = resolvedList.get(0);
Assertions.assertNotNull(info);
Assertions.assertEquals(blockDto.getBeneficiaryAddress(), info.getBeneficiaryAddress().encoded());
Assertions.assertEquals(blockDto.getSignerPublicKey(), info.getSignerPublicAccount().getPublicKey().toHex());
Assertions.assertEquals(BlockType.NORMAL_BLOCK, info.getType());
Assertions.assertEquals(3, info.getVersion().intValue());
Assertions.assertEquals(NetworkType.MIJIN_TEST, info.getNetworkType());
Assertions.assertEquals(BigInteger.valueOf(9L), info.getHeight());
Assertions.assertEquals(metaDTO.getHash(), info.getHash());
Assertions.assertEquals(metaDTO.getTransactionsCount(), info.getTransactionsCount());
Assertions.assertEquals(metaDTO.getGenerationHash(), info.getGenerationHash());
Assertions.assertEquals(metaDTO.getTransactionsCount(), info.getTransactionsCount());
Assertions.assertEquals(metaDTO.getStateHashSubCacheMerkleRoots(), info.getSubCacheMerkleRoots());
Assertions.assertEquals(metaDTO.getTotalFee(), info.getTotalFee());
Assertions.assertEquals(blockDto.getHeight(), info.getHeight());
Assertions.assertEquals(blockDto.getProofGamma(), info.getProofGamma());
Assertions.assertEquals(blockDto.getProofScalar(), info.getProofScalar());
Assertions.assertEquals(blockDto.getProofVerificationHash(), info.getProofVerificationHash());
Assertions.assertEquals(address, info.getBeneficiaryAddress());
}
Aggregations