use of com.github.robozonky.api.notifications.Event in project robozonky by RoboZonky.
the class SellingTest method noSaleDueToNoData.
@Test
void noSaleDueToNoData() {
// no data is inserted into portfolio, therefore nothing happens
final Zonky zonky = mockApi();
final Portfolio portfolio = new Portfolio(mockBalance(zonky));
new Selling(ALL_ACCEPTING, true).accept(portfolio, mockAuthentication(zonky));
final List<Event> e = getNewEvents();
assertThat(e).hasSize(2);
assertSoftly(softly -> {
softly.assertThat(e.get(0)).isInstanceOf(SellingStartedEvent.class);
softly.assertThat(e.get(1)).isInstanceOf(SellingCompletedEvent.class);
});
verify(zonky, never()).sell(any());
}
use of com.github.robozonky.api.notifications.Event in project robozonky by RoboZonky.
the class PurchasingTest method noneAccepted.
@Test
void noneAccepted() {
final Zonky zonky = mockApi();
final Participation mock = mock(Participation.class);
when(mock.getRemainingPrincipal()).thenReturn(BigDecimal.valueOf(250));
final Purchasing exec = new Purchasing(NONE_ACCEPTING, mockAuthentication(zonky), true);
final Portfolio portfolio = Portfolio.create(zonky, mockBalance(zonky));
assertThat(exec.apply(portfolio, Collections.singleton(mock))).isEmpty();
final List<Event> e = this.getNewEvents();
assertThat(e).hasSize(2);
assertSoftly(softly -> {
softly.assertThat(e).first().isInstanceOf(PurchasingStartedEvent.class);
softly.assertThat(e).last().isInstanceOf(PurchasingCompletedEvent.class);
});
}
use of com.github.robozonky.api.notifications.Event in project robozonky by RoboZonky.
the class PurchasingTest method noStrategy.
@Test
void noStrategy() {
final Participation mock = mock(Participation.class);
final Purchasing exec = new Purchasing(Optional::empty, null, true);
final Portfolio portfolio = mock(Portfolio.class);
assertThat(exec.apply(portfolio, Collections.singleton(mock))).isEmpty();
// check events
final List<Event> events = this.getNewEvents();
assertThat(events).isEmpty();
}
use of com.github.robozonky.api.notifications.Event in project robozonky by RoboZonky.
the class PurchasingTest method someAccepted.
@Test
void someAccepted() {
final int loanId = 1;
final Loan loan = Loan.custom().setId(loanId).setAmount(100_000).setRating(Rating.D).setRemainingInvestment(1000).setMyInvestment(mockMyInvestment()).setDatePublished(OffsetDateTime.now()).build();
final Zonky zonky = mockApi();
when(zonky.getLoan(eq(loanId))).thenReturn(loan);
final Participation mock = mock(Participation.class);
when(mock.getId()).thenReturn(1);
when(mock.getLoanId()).thenReturn(loan.getId());
when(mock.getRemainingPrincipal()).thenReturn(BigDecimal.valueOf(250));
when(mock.getRating()).thenReturn(loan.getRating());
final Purchasing exec = new Purchasing(ALL_ACCEPTING, mockAuthentication(zonky), true);
final Portfolio portfolio = Portfolio.create(zonky, mockBalance(zonky));
assertThat(exec.apply(portfolio, Collections.singleton(mock))).isNotEmpty();
// purchase as balance changed
verify(zonky, never()).purchase(eq(mock));
final List<Event> e = this.getNewEvents();
assertThat(e).hasSize(5);
assertSoftly(softly -> {
softly.assertThat(e).first().isInstanceOf(PurchasingStartedEvent.class);
softly.assertThat(e.get(1)).isInstanceOf(PurchaseRecommendedEvent.class);
softly.assertThat(e.get(2)).isInstanceOf(PurchaseRequestedEvent.class);
softly.assertThat(e.get(3)).isInstanceOf(InvestmentPurchasedEvent.class);
softly.assertThat(e).last().isInstanceOf(PurchasingCompletedEvent.class);
});
// purchase as marketplace first initialized
assertThat(exec.apply(portfolio, Collections.singleton(mock))).isNotEmpty();
// no balance change, no marketplace change => don't purchase
assertThat(exec.apply(portfolio, Collections.singleton(mock))).isEmpty();
// nothing changed, so no more purchase
verify(zonky, never()).purchase(eq(mock));
}
use of com.github.robozonky.api.notifications.Event in project robozonky by RoboZonky.
the class Repayments method accept.
@Override
public void accept(final Portfolio portfolio, final Authenticated authenticated) {
final PortfolioOverview portfolioOverview = portfolio.calculateOverview();
final Collection<Integer> active = getActiveLastTime();
// detect and process loans that have been fully repaid, comparing to the last time active loans were checked
final Stream<Investment> repaid = portfolio.getActiveWithPaymentStatus(PaymentStatuses.of(PaymentStatus.PAID));
repaid.filter(i -> active.contains(i.getLoanId())).peek(i -> {
final Loan l = authenticated.call(zonky -> LoanCache.INSTANCE.getLoan(i, zonky));
final Event e = new LoanRepaidEvent(i, l, portfolioOverview);
Events.fire(e);
}).forEach(i -> active.remove(i.getLoanId()));
// add all active loans to date
portfolio.getActiveWithPaymentStatus(PaymentStatus.getActive()).forEach(i -> active.add(i.getLoanId()));
// store for future reference
setActive(active);
}
Aggregations