com.google.protobuf.util.Durations#fromMillis ( )源码实例Demo

下面列出了com.google.protobuf.util.Durations#fromMillis ( ) 实例代码,或者点击链接到github查看源代码,也可以在右侧发表评论。

public Details getServerStatus() {
    RuntimeMXBean rb = ManagementFactory.getRuntimeMXBean();
    Duration uptime = Durations.fromMillis(rb.getUptime());

    if (!leaderActivator.isLeader()) {
        return Details.newBuilder()
                .setStatus(NOT_SERVING)
                .setLeader(false)
                .setActive(false)
                .setUptime(uptime)
                .build();
    }

    boolean active = leaderActivator.isActivated();

    List<ServiceActivation> serviceActivations = activationLifecycle.getServiceActionTimesMs().stream()
            .sorted(Comparator.comparing(Pair::getRight))
            .map(pair -> ServiceActivation.newBuilder()
                    .setName(pair.getLeft())
                    .setActivationTime(Durations.fromMillis(pair.getRight()))
                    .build())
            .collect(Collectors.toList());

    Details.Builder details = Details.newBuilder()
            .setStatus(SERVING)
            .setCell(cellInfoResolver.getCellName())
            .setLeader(true)
            .setActive(active)
            .setUptime(uptime)
            .setElectionTimestamp(Timestamps.fromMillis(leaderActivator.getElectionTimestamp()))
            .setActivationTimestamp(Timestamps.fromMillis(leaderActivator.getActivationEndTimestamp()))
            .addAllServiceActivationTimes(serviceActivations);

    if (active) {
        details.setActivationTime(Durations.fromMillis(leaderActivator.getActivationTime()));
    }

    return details.build();
}
 
源代码2 项目: bazel   文件: RemoteSpawnRunnerTest.java
@Test
public void accountingAddsDurationsForStages() {
  SpawnMetrics.Builder builder =
      SpawnMetrics.Builder.forRemoteExec()
          .setQueueTime(Duration.ofSeconds(1))
          .setSetupTime(Duration.ofSeconds(2))
          .setExecutionWallTime(Duration.ofSeconds(2))
          .setProcessOutputsTime(Duration.ofSeconds(2));
  Timestamp queued = Timestamp.getDefaultInstance();
  com.google.protobuf.Duration oneSecond = Durations.fromMillis(1000);
  Timestamp workerStart = Timestamps.add(queued, oneSecond);
  Timestamp executionStart = Timestamps.add(workerStart, oneSecond);
  Timestamp executionCompleted = Timestamps.add(executionStart, oneSecond);
  Timestamp outputUploadStart = Timestamps.add(executionCompleted, oneSecond);
  Timestamp outputUploadComplete = Timestamps.add(outputUploadStart, oneSecond);
  ExecutedActionMetadata executedMetadata =
      ExecutedActionMetadata.newBuilder()
          .setWorker("test worker")
          .setQueuedTimestamp(queued)
          .setWorkerStartTimestamp(workerStart)
          .setExecutionStartTimestamp(executionStart)
          .setExecutionCompletedTimestamp(executionCompleted)
          .setOutputUploadStartTimestamp(outputUploadStart)
          .setOutputUploadCompletedTimestamp(outputUploadComplete)
          .build();
  RemoteSpawnRunner.spawnMetricsAccounting(builder, executedMetadata);
  SpawnMetrics spawnMetrics = builder.build();
  // remote queue time is accumulated
  assertThat(spawnMetrics.queueTime()).isEqualTo(Duration.ofSeconds(2));
  // setup time is substituted
  assertThat(spawnMetrics.setupTime()).isEqualTo(Duration.ofSeconds(1));
  // execution time is unspecified, assume substituted
  assertThat(spawnMetrics.executionWallTime()).isEqualTo(Duration.ofSeconds(1));
  // ProcessOutputs time is unspecified, assume substituted
  assertThat(spawnMetrics.processOutputsTime()).isEqualTo(Duration.ofSeconds(1));
}
 
源代码3 项目: live-transcribe-speech-engine   文件: TimeUtil.java
public static com.google.protobuf.Duration convert(Duration d) {
  return Durations.fromMillis(d.getMillis());
}
 
 同类方法