com.github.robozonky.app.tenant.ZonkyApiTokenSupplier.<init>()方法的使用及代码示例

x33g5p2x  于2022-02-05 转载在 其他  
字(6.8k)|赞(0)|评价(0)|浏览(75)

本文整理了Java中com.github.robozonky.app.tenant.ZonkyApiTokenSupplier.<init>()方法的一些代码示例,展示了ZonkyApiTokenSupplier.<init>()的具体用法。这些代码示例主要来源于Github/Stackoverflow/Maven等平台,是从一些精选项目中提取出来的代码,具有较强的参考意义,能在一定程度帮忙到你。ZonkyApiTokenSupplier.<init>()方法的具体详情如下:
包路径:com.github.robozonky.app.tenant.ZonkyApiTokenSupplier
类名称:ZonkyApiTokenSupplier
方法名:<init>

ZonkyApiTokenSupplier.<init>介绍

暂无

代码示例

代码示例来源:origin: com.github.robozonky/robozonky-app

public PowerTenant build(final Duration tokenRefresh) {
  if (secrets == null) {
    throw new IllegalStateException("Secret provider must be provided.");
  }
  final ApiProvider apis = api == null ? new ApiProvider() : api;
  final Function<ZonkyScope, ZonkyApiTokenSupplier> tokenSupplier =
      scope -> new ZonkyApiTokenSupplier(scope, apis, secrets, tokenRefresh);
  final SessionInfo sessionInfo = new SessionInfo(secrets.getUsername(), name, dryRun);
  return new PowerTenantImpl(sessionInfo, apis, strategyProvider, tokenSupplier);
}

代码示例来源:origin: RoboZonky/robozonky

public PowerTenant build() {
  if (secrets == null) {
    throw new IllegalStateException("Secret provider must be provided.");
  }
  final ApiProvider apis = api == null ? new ApiProvider() : api;
  final Function<OAuthScope, ZonkyApiTokenSupplier> tokenSupplier =
      scope -> new ZonkyApiTokenSupplier(scope, apis, secrets);
  final SessionInfo sessionInfo = new SessionInfo(secrets.getUsername(), name, dryRun);
  final BooleanSupplier zonkyAvailability = lifecycle == null ? () -> true : () -> lifecycle.get().isOnline();
  return new PowerTenantImpl(sessionInfo, apis, zonkyAvailability, strategyProvider, tokenSupplier);
}

代码示例来源:origin: RoboZonky/robozonky

@Test
void failsOnLogin() {
  final Zonky zonky = mock(Zonky.class);
  final OAuth oAuth = mock(OAuth.class);
  doThrow(IllegalStateException.class).when(oAuth).login(any(), any(), any());
  final ApiProvider api = mockApi(oAuth, zonky);
  final ZonkyApiTokenSupplier t = new ZonkyApiTokenSupplier(api, SECRETS);
  assertThatThrownBy(t::get).isInstanceOf(IllegalStateException.class);
}

代码示例来源:origin: RoboZonky/robozonky

@Test
void closingNeverLoaded() {
  final Zonky zonky = mock(Zonky.class);
  final OAuth oAuth = mock(OAuth.class);
  final ZonkyApiToken token = getTokenExpiringIn(Duration.ofSeconds(5));
  when(oAuth.login(eq(OAuthScope.SCOPE_APP_WEB), eq(SECRETS.getUsername()), eq(SECRETS.getPassword())))
      .thenAnswer(invocation -> token);
  when(oAuth.refresh(any())).thenReturn(token);
  final ApiProvider api = mockApi(oAuth, zonky);
  final ZonkyApiTokenSupplier t = new ZonkyApiTokenSupplier(api, SECRETS);
  t.close();
  verify(oAuth, never()).login(any(), any(), any());
  verify(zonky, never()).logout();
  assertThatThrownBy(t::get).isInstanceOf(IllegalStateException.class);
}

代码示例来源:origin: RoboZonky/robozonky

@Test
  void notClosingWhenExpired() {
    final Zonky zonky = mock(Zonky.class);
    final OAuth oAuth = mock(OAuth.class);
    final ZonkyApiToken token = getTokenExpiringIn(Duration.ZERO);
    when(oAuth.login(eq(OAuthScope.SCOPE_APP_WEB), eq(SECRETS.getUsername()), eq(SECRETS.getPassword())))
        .thenAnswer(invocation -> token);
    final ApiProvider api = mockApi(oAuth, zonky);
    final ZonkyApiTokenSupplier t = new ZonkyApiTokenSupplier(api, SECRETS);
    t.close();
    verify(zonky, never()).logout();
  }
}

代码示例来源:origin: RoboZonky/robozonky

@Test
void refreshes() {
  final Zonky zonky = mock(Zonky.class);
  final OAuth oAuth = mock(OAuth.class);
  final ZonkyApiToken token = getTokenExpiringIn(Duration.ofMinutes(5));
  when(oAuth.login(eq(OAuthScope.SCOPE_APP_WEB), eq(SECRETS.getUsername()), eq(SECRETS.getPassword())))
      .thenAnswer(invocation -> token);
  final ApiProvider api = mockApi(oAuth, zonky);
  final ZonkyApiTokenSupplier t = new ZonkyApiTokenSupplier(api, SECRETS);
  assertThat(t.get()).isEqualTo(token);
  skipAheadBy(Duration.ofSeconds(4 * 60 + 56)); // get over the refresh period
  final ZonkyApiToken secondToken = getTokenExpiringIn(Duration.ofMinutes(5));
  when(oAuth.refresh(any())).thenReturn(secondToken);
  assertThat(t.get()).isEqualTo(secondToken);
}

代码示例来源:origin: RoboZonky/robozonky

@Test
void failsOnRefresh() {
  final Zonky zonky = mock(Zonky.class);
  final OAuth oAuth = mock(OAuth.class);
  when(oAuth.login(eq(OAuthScope.SCOPE_APP_WEB), eq(SECRETS.getUsername()), eq(SECRETS.getPassword())))
      .thenAnswer(invocation -> getTokenExpiringIn(Duration.ofMinutes(5)));
  final ApiProvider api = mockApi(oAuth, zonky);
  final ZonkyApiTokenSupplier t = new ZonkyApiTokenSupplier(api, SECRETS);
  final ZonkyApiToken token = t.get();
  assertThat(token).isNotNull();
  skipAheadBy(Duration.ofSeconds(4 * 60 + 55)); // get over the refresh period, but not over expiration
  doThrow(IllegalStateException.class).when(oAuth).refresh(any());
  assertThat(t.get())
      .isNotNull()
      .isNotSameAs(token);
  verify(oAuth).refresh(any()); // make sure refresh was rejected before login was called
}

代码示例来源:origin: RoboZonky/robozonky

@Test
void newLoginWhenTokenExpiredWithoutRefresh() {
  final Zonky zonky = mock(Zonky.class);
  final OAuth oAuth = mock(OAuth.class);
  final ZonkyApiToken token = getTokenExpiringIn(Duration.ofMinutes(5));
  when(oAuth.login(eq(OAuthScope.SCOPE_APP_WEB), eq(SECRETS.getUsername()), eq(SECRETS.getPassword())))
      .thenAnswer(invocation -> token);
  final ApiProvider api = mockApi(oAuth, zonky);
  final ZonkyApiTokenSupplier t = new ZonkyApiTokenSupplier(api, SECRETS);
  assertThat(t.get()).isEqualTo(token);
  skipAheadBy(Duration.ofMinutes(6)); // get over the expiration period
  final ZonkyApiToken secondToken = getTokenExpiringIn(Duration.ofMinutes(5));
  when(oAuth.login(eq(OAuthScope.SCOPE_APP_WEB), eq(SECRETS.getUsername()), eq(SECRETS.getPassword())))
      .thenAnswer(invocation -> secondToken);
  assertThat(t.get()).isEqualTo(secondToken);
}

代码示例来源:origin: RoboZonky/robozonky

@Test
void reloginsWhenAlreadyExpired() {
  final Zonky zonky = mock(Zonky.class);
  final OAuth oAuth = mock(OAuth.class);
  final ZonkyApiToken token = getTokenExpiringIn(Duration.ofMinutes(5));
  when(oAuth.login(eq(OAuthScope.SCOPE_APP_WEB), eq(SECRETS.getUsername()), eq(SECRETS.getPassword())))
      .thenAnswer(invocation -> token);
  final ApiProvider api = mockApi(oAuth, zonky);
  final ZonkyApiTokenSupplier t = new ZonkyApiTokenSupplier(api, SECRETS);
  assertThat(t.get()).isEqualTo(token);
  skipAheadBy(Duration.ofMinutes(6)); // get over the expiration period
  final ZonkyApiToken secondToken = getTokenExpiringIn(Duration.ofMinutes(5));
  when(oAuth.login(eq(OAuthScope.SCOPE_APP_WEB), eq(SECRETS.getUsername()), eq(SECRETS.getPassword())))
      .thenAnswer(invocation -> secondToken);
  assertThat(t.get()).isEqualTo(secondToken);
}

代码示例来源:origin: RoboZonky/robozonky

@Test
void closingLoaded() {
  final Zonky zonky = mock(Zonky.class);
  final OAuth oAuth = mock(OAuth.class);
  final ZonkyApiToken token = getTokenExpiringIn(Duration.ofSeconds(5));
  when(oAuth.login(eq(OAuthScope.SCOPE_APP_WEB), eq(SECRETS.getUsername()), eq(SECRETS.getPassword())))
      .thenAnswer(invocation -> token);
  when(oAuth.refresh(any())).thenReturn(token);
  final ApiProvider api = mockApi(oAuth, zonky);
  final ZonkyApiTokenSupplier t = new ZonkyApiTokenSupplier(api, SECRETS);
  t.get();
  verify(oAuth).login(any(), any(), any());
  assertThat(t.isClosed()).isFalse();
  t.close();
  verify(zonky, only()).logout();
  assertThat(t.isClosed()).isTrue();
  assertThatThrownBy(t::get).isInstanceOf(IllegalStateException.class);
}

相关文章