• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Java QueueStateInfo类代码示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本文整理汇总了Java中com.google.appengine.api.taskqueue.dev.QueueStateInfo的典型用法代码示例。如果您正苦于以下问题:Java QueueStateInfo类的具体用法?Java QueueStateInfo怎么用?Java QueueStateInfo使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。



QueueStateInfo类属于com.google.appengine.api.taskqueue.dev包,在下文中一共展示了QueueStateInfo类的12个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Java代码示例。

示例1: executeTasks

import com.google.appengine.api.taskqueue.dev.QueueStateInfo; //导入依赖的package包/类
/**
 * Executes mapreduce tasks, increment the clock between each task.
 *
 * <p>Incrementing the clock between tasks is important if tasks have transactions inside the
 * mapper or reducer, which don't have access to the fake clock.
 *
 * <p>The maxTasks parameter determines how many tasks (at most) will be run. If maxTasks is
 * absent(), all tasks are run until the queue is empty. If maxTasks is zero, no tasks are run.
 */
protected void executeTasks(
    String queueName, @Nullable FakeClock clock, Optional<Integer> maxTasks) throws Exception {
  for (int numTasksDeleted = 0;
      !maxTasks.isPresent() || (numTasksDeleted < maxTasks.get());
      numTasksDeleted++) {
    ofy().clearSessionCache();
    // We have to re-acquire task list every time, because local implementation returns a copy.
    List<QueueStateInfo.TaskStateInfo> taskInfo =
        taskQueue.getQueueStateInfo().get(queueName).getTaskInfo();
    if (taskInfo.isEmpty()) {
      break;
    }
    QueueStateInfo.TaskStateInfo taskStateInfo = taskInfo.get(0);
    taskQueue.deleteTask(queueName, taskStateInfo.getTaskName());
    executeTask(queueName, taskStateInfo);
    if (clock != null) {
      clock.advanceOneMilli();
    }
  }
}
 
开发者ID:google,项目名称:nomulus,代码行数:30,代码来源:MapreduceTestCase.java


示例2: testExport

import com.google.appengine.api.taskqueue.dev.QueueStateInfo; //导入依赖的package包/类
@Test
public void testExport() throws Exception {
  metrics.projectId = "project id";
  metrics.export();
  QueueStateInfo queueInfo = getLocalTaskQueue().getQueueStateInfo().get("default");
  assertEquals(1, queueInfo.getCountTasks());
  assertEquals("/task/metrics", queueInfo.getTaskInfo().get(0).getUrl());
  Multimap<String, String> params = parseQuery(queueInfo.getTaskInfo().get(0).getBody());
  assertEquals("/path", getOnlyElement(params.get("path")));
  assertEquals("tld", getOnlyElement(params.get("tld")));
  assertEquals("GET", getOnlyElement(params.get("method")));
  assertEquals("0", getOnlyElement(params.get("starttime")));
  assertEquals(
      ImmutableSet.of("foo", "bar"),
      ImmutableSet.copyOf(Splitter.on(' ').split(getOnlyElement(params.get("activity")))));
  assertEquals("456", getOnlyElement(params.get("responsecode")));
  assertTrue(params.containsKey("endtime"));
  assertTrue(params.containsKey("insertid"));
}
 
开发者ID:google,项目名称:domaintest,代码行数:20,代码来源:MetricsImplTest.java


示例3: waitUntilTaskQueueIsEmpty

import com.google.appengine.api.taskqueue.dev.QueueStateInfo; //导入依赖的package包/类
protected void waitUntilTaskQueueIsEmpty() throws InterruptedException {
  boolean hasMoreTasks = true;
  while (hasMoreTasks) {
    Map<String, QueueStateInfo> taskInfoMap = taskQueue.getQueueStateInfo();
    hasMoreTasks = false;
    for (QueueStateInfo taskQueueInfo : taskInfoMap.values()) {
      if (taskQueueInfo.getCountTasks() > 0) {
        hasMoreTasks = true;
        break;
      }
    }
    if (hasMoreTasks) {
      Thread.sleep(100);
    }
  }
}
 
开发者ID:GoogleCloudPlatform,项目名称:appengine-pipelines,代码行数:17,代码来源:PipelineTest.java


示例4: assertTasksEnqueued

import com.google.appengine.api.taskqueue.dev.QueueStateInfo; //导入依赖的package包/类
/**
 * Ensures that the only tasks in the named queue are exactly those that match the expected
 * matchers.
 */
public static void assertTasksEnqueued(String queueName, Collection<TaskMatcher> taskMatchers)
    throws Exception {
  QueueStateInfo qsi = getQueueInfo(queueName);
  assertThat(qsi.getTaskInfo()).hasSize(taskMatchers.size());
  List<TaskStateInfo> taskInfos = new ArrayList<>(qsi.getTaskInfo());
  for (final TaskMatcher taskMatcher : taskMatchers) {
    try {
      taskInfos.remove(taskInfos.stream().filter(taskMatcher).findFirst().get());
    } catch (NoSuchElementException e) {
      final Map<String, Object> taskMatcherMap = taskMatcher.expected.toMap();
      assert_()
          .fail(
              "Task not found in queue %s:\n\n%s\n\nPotential candidate match diffs:\n\n%s",
              queueName,
              taskMatcher,
              taskInfos
                  .stream()
                  .map(
                      input ->
                          prettyPrintEntityDeepDiff(
                              taskMatcherMap,
                              Maps.filterKeys(
                                  new MatchableTaskInfo(input).toMap(),
                                  in(taskMatcherMap.keySet()))))
                  .collect(joining("\n")));
    }
  }
}
 
开发者ID:google,项目名称:nomulus,代码行数:33,代码来源:TaskQueueHelper.java


示例5: doTest

import com.google.appengine.api.taskqueue.dev.QueueStateInfo; //导入依赖的package包/类
private void doTest() throws InterruptedException {
  QueueFactory.getDefaultQueue().add(TaskOptions.Builder.withTaskName("task29"));
  // Give the task time to execute if tasks are actually enabled (which they
  // aren't, but that's part of the test).
  Thread.sleep(1000);
  LocalTaskQueue ltq = LocalTaskQueueTestConfig.getLocalTaskQueue();
  QueueStateInfo qsi = ltq.getQueueStateInfo().get(QueueFactory.getDefaultQueue().getQueueName());
  assertEquals(1, qsi.getTaskInfo().size());
  assertEquals("task29", qsi.getTaskInfo().get(0).getTaskName());
}
 
开发者ID:GoogleCloudPlatform,项目名称:java-docs-samples,代码行数:11,代码来源:TaskQueueTest.java


示例6: doTest

import com.google.appengine.api.taskqueue.dev.QueueStateInfo; //导入依赖的package包/类
private void doTest() throws InterruptedException {
  // [START QueueFactory]
  QueueFactory.getQueue("my-queue-name").add(TaskOptions.Builder.withTaskName("task29"));
  // [END QueueFactory]
  // Give the task time to execute if tasks are actually enabled (which they
  // aren't, but that's part of the test).
  Thread.sleep(1000);
  LocalTaskQueue ltq = LocalTaskQueueTestConfig.getLocalTaskQueue();
  QueueStateInfo qsi =
      ltq.getQueueStateInfo().get(QueueFactory.getQueue("my-queue-name").getQueueName());
  assertEquals(1, qsi.getTaskInfo().size());
  assertEquals("task29", qsi.getTaskInfo().get(0).getTaskName());
}
 
开发者ID:GoogleCloudPlatform,项目名称:java-docs-samples,代码行数:14,代码来源:TaskQueueConfigTest.java


示例7: assertNumTasksInQueue

import com.google.appengine.api.taskqueue.dev.QueueStateInfo; //导入依赖的package包/类
/**
 * Asserts that the {@code numExpectedTasksInQueue} matches the actual number of tasks in the queue.
 */
private void assertNumTasksInQueue(int numExpectedTasksInQueue)
{
	LocalTaskQueue ltq = LocalTaskQueueTestConfig.getLocalTaskQueue();
	QueueStateInfo qsi = ltq.getQueueStateInfo()
		.get(QueueFactory.getQueue(DELETE_COUNTER_SHARD_QUEUE_NAME).getQueueName());
	assertEquals(numExpectedTasksInQueue, qsi.getTaskInfo().size());
}
 
开发者ID:instacount,项目名称:appengine-counter,代码行数:11,代码来源:ShardedCounterServiceDeleteTest.java


示例8: getQueueInfo

import com.google.appengine.api.taskqueue.dev.QueueStateInfo; //导入依赖的package包/类
/** Returns the info object for the provided queue name. */
public static QueueStateInfo getQueueInfo(String queueName) {
  return getLocalTaskQueue().getQueueStateInfo().get(queueName);
}
 
开发者ID:google,项目名称:nomulus,代码行数:5,代码来源:TaskQueueHelper.java


示例9: getTasks

import com.google.appengine.api.taskqueue.dev.QueueStateInfo; //导入依赖的package包/类
protected List<QueueStateInfo.TaskStateInfo> getTasks(String queueName) {
  return taskQueue.getQueueStateInfo().get(queueName).getTaskInfo();
}
 
开发者ID:google,项目名称:nomulus,代码行数:4,代码来源:MapreduceTestCase.java


示例10: executeTask

import com.google.appengine.api.taskqueue.dev.QueueStateInfo; //导入依赖的package包/类
protected void executeTask(String queueName, QueueStateInfo.TaskStateInfo taskStateInfo)
    throws Exception {
  logger.finefmt("Executing task %s with URL %s",
      taskStateInfo.getTaskName(), taskStateInfo.getUrl());
  // Hack to allow for deferred tasks. Exploits knowing how they work.
  if (taskStateInfo.getUrl().endsWith("__deferred__")) {
    ObjectInputStream oin =
        new ObjectInputStream(new ByteArrayInputStream(taskStateInfo.getBodyAsBytes()));
    Runnable object = (Runnable) oin.readObject();
    object.run();
    return;
  }
  HttpServletRequest request = mock(HttpServletRequest.class);
  HttpServletResponse response = mock(HttpServletResponse.class);

  // Strip off routing paths that are handled in web.xml in non-test scenarios.
  String pathInfo = taskStateInfo.getUrl();
  if (pathInfo.startsWith("/_dr/mapreduce/")) {
    pathInfo = pathInfo.replace("/_dr/mapreduce", "");
  } else if (pathInfo.startsWith("/mapreduce/")) {
      pathInfo = pathInfo.replace("/mapreduce", "");
  } else if (pathInfo.startsWith("/")) {
    pathInfo = pathInfo.replace("/_ah/", "");
    pathInfo = pathInfo.substring(pathInfo.indexOf('/'));
  } else {
    pathInfo = "/" + pathInfo;
  }
  when(request.getPathInfo()).thenReturn(pathInfo);
  when(request.getHeader("X-AppEngine-QueueName")).thenReturn(queueName);
  when(request.getHeader("X-AppEngine-TaskName")).thenReturn(taskStateInfo.getTaskName());
  // Pipeline looks at this header but uses the value only for diagnostic messages
  when(request.getIntHeader(TaskHandler.TASK_RETRY_COUNT_HEADER)).thenReturn(-1);
  for (HeaderWrapper header : taskStateInfo.getHeaders()) {
    int value = parseAsQuotedInt(header.getValue());
    when(request.getIntHeader(header.getKey())).thenReturn(value);
    logger.finefmt("header: %s=%s", header.getKey(), header.getValue());
    when(request.getHeader(header.getKey())).thenReturn(header.getValue());
  }

  Map<String, String> parameters = decodeParameters(taskStateInfo.getBody());
  for (String name : parameters.keySet()) {
    when(request.getParameter(name)).thenReturn(parameters.get(name));
  }
  when(request.getParameterNames()).thenReturn(Collections.enumeration(parameters.keySet()));

  if (taskStateInfo.getMethod().equals("POST")) {
    if (taskStateInfo.getUrl().startsWith(PipelineServlet.BASE_URL)) {
      pipelineServlet.doPost(request, response);
    } else {
      mrServlet.doPost(request, response);
    }
  } else {
    throw new UnsupportedOperationException();
  }
}
 
开发者ID:google,项目名称:nomulus,代码行数:56,代码来源:MapreduceTestCase.java


示例11: getCountTasks

import com.google.appengine.api.taskqueue.dev.QueueStateInfo; //导入依赖的package包/类
private static int getCountTasks() {
    LocalTaskQueue localTaskQueue = LocalTaskQueueTestConfig.getLocalTaskQueue();

    Map<String, QueueStateInfo> queueStateInfo = localTaskQueue.getQueueStateInfo();

    int count = 0;

    for (String key : queueStateInfo.keySet()) {
        count += queueStateInfo.get(key).getCountTasks();
    }

    return count;
}
 
开发者ID:feroult,项目名称:yawp,代码行数:14,代码来源:AsyncHelper.java


示例12: getTaskCount

import com.google.appengine.api.taskqueue.dev.QueueStateInfo; //导入依赖的package包/类
/**
 * Fetches the number of tasks that have been scheduled in a named queue in the
 * current test, including both tasks that have executed, and those that have not.
 * @param queueName the name of the queue
 * @return the total number of tasks enqueued by the test
 */
public int getTaskCount(String queueName) {
    LocalTaskQueue localTaskQueue = LocalTaskQueueTestConfig.getLocalTaskQueue();
    QueueStateInfo queueState = localTaskQueue.getQueueStateInfo().get(queueName);
    return queueState.getCountTasks();
}
 
开发者ID:openmash,项目名称:mashmesh,代码行数:12,代码来源:IntegrationTestHelper.java



注:本文中的com.google.appengine.api.taskqueue.dev.QueueStateInfo类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Java XMLParser类代码示例发布时间:2022-05-23
下一篇:
Java FbStatus类代码示例发布时间:2022-05-23
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap