solr客户端基本是配置出来的,服务端可以对其进行测试,我使用的是solrj服务端。 
如果初学solr,先使用普通的测试类:

  1. import java.io.IOException;
  2. import java.util.ArrayList;
  3. import java.util.Collection;
  4. import java.util.Date;
  5. import org.apache.solr.client.solrj.SolrQuery;
  6. import org.apache.solr.client.solrj.SolrServer;
  7. import org.apache.solr.client.solrj.SolrServerException;
  8. import org.apache.solr.client.solrj.impl.CommonsHttpSolrServer;
  9. import org.apache.solr.client.solrj.request.AbstractUpdateRequest;
  10. import org.apache.solr.client.solrj.request.UpdateRequest;
  11. import org.apache.solr.client.solrj.response.QueryResponse;
  12. import org.apache.solr.common.SolrInputDocument;
  13. public class SolrTest {
  14. public static void main(String[] args) throws IOException,
  15. SolrServerException {
  16. String urlString = " http://localhost:8393/keyPlace";
  17. SolrServer server = new CommonsHttpSolrServer(urlString);
  18. testAdd(server);
  19. testQuery(server);
  20. }
  21. static void testAdd(SolrServer server) throws IOException,
  22. SolrServerException {
  23. SolrInputDocument doc1 = new SolrInputDocument();
  24. doc1.addField("id", 456);
  25. doc1.addField("orgId", "33030300310");
  26. doc1.addField("name", "张三");
  27. doc1.addField("key", "1");
  28. doc1.addField("createDate", new Date());
  29. SolrInputDocument doc2 = new SolrInputDocument();
  30. doc2.addField("id", 123);
  31. doc2.addField("orgId", "33030300310");
  32. doc2.addField("name", "李四");
  33. doc2.addField("key", "2");
  34. doc2.addField("createDate", new Date());
  35. Collection<SolrInputDocument> docs = new ArrayList<SolrInputDocument>();
  36. docs.add(doc1);
  37. docs.add( doc2 );
  38. server.add(docs);
  39. UpdateRequest req = new UpdateRequest();
  40. req.setAction(AbstractUpdateRequest.ACTION.COMMIT, false, false);
  41. req.add(docs);
  42. req.process(server);
  43. }
  44. static void testQuery(SolrServer server) throws IOException,
  45. SolrServerException {
  46. SolrQuery query = new SolrQuery();
  47. query.setQuery("name:张三");
  48. query.setHighlight(true).setHighlightSnippets(1);
  49. QueryResponse ret = server.query(query);
  50. System.out.println(ret);
  51. }

如果服务端配置了ExtractingRequestHandler,可使用下面的类进行测试:

    1. import java.io.File;
    2. import java.io.IOException;
    3. import org.apache.solr.client.solrj.SolrServer;
    4. import org.apache.solr.client.solrj.SolrServerException;
    5. import org.apache.solr.client.solrj.request.AbstractUpdateRequest;
    6. import org.apache.solr.client.solrj.response.QueryResponse;
    7. import org.apache.solr.client.solrj.SolrQuery;
    8. import org.apache.solr.client.solrj.impl.CommonsHttpSolrServer;
    9. import org.apache.solr.client.solrj.request.ContentStreamUpdateRequest;
    10. import org.apache.solr.common.params.ModifiableSolrParams;
    11. import org.apache.solr.handler.extraction.ExtractingParams;
    12. public class ExtractTest {
    13. public static void main(String[] args) {
    14. try {
    15. String urlString = "http://localhost:8393/sourcePool/";
    16. SolrServer solr = new CommonsHttpSolrServer(urlString);
    17. String fileName = "c:/slor1.doc";
    18. String solrId = "2";
    19. String resoucePoolid = "2";
    20. indexFilesSolrCell(fileName, solrId , resoucePoolid , solr);
    21. testQuery(solr);
    22. } catch (Exception ex) {
    23. System.out.println(ex.toString());
    24. }
    25. }
    26. /**
    27. * Method to index all types of files into Solr.
    28. * @throws IOException
    29. * @throws SolrServerException
    30. */
    31. public static void indexFilesSolrCell(String fileName, String solrId , String resoucePoolid , SolrServer solr)
    32. throws IOException, SolrServerException {
    33. ContentStreamUpdateRequest up
    34. = new ContentStreamUpdateRequest("/update/extract");
    35. ModifiableSolrParams p = new ModifiableSolrParams();
    36. p.add(ExtractingParams.LITERALS_PREFIX + "orgids" , "33010033001");
    37. p.add(ExtractingParams.LITERALS_PREFIX + "orgids" , "33010033002");
    38. p.add(ExtractingParams.LITERALS_PREFIX + "orgids" , "33010033003");
    39. up.setParams(p);
    40. up.addFile(new File(fileName));
    41. up.setParam(ExtractingParams.LITERALS_PREFIX + "id", solrId);
    42. up.setParam(ExtractingParams.LITERALS_PREFIX + "resoucepoolid", resoucePoolid);
    43. up.setParam(ExtractingParams.LITERALS_PREFIX + "orgid", "33010033001");
    44. up.setParam(ExtractingParams.LITERALS_PREFIX + "name", "33010033001");
    45. up.setParam(ExtractingParams.LITERALS_PREFIX + "releaseunit", "33010033001");
    46. up.setParam(ExtractingParams.LITERALS_PREFIX + "releasetime", "2011-02-12");
    47. up.setParam(ExtractingParams.UNKNOWN_FIELD_PREFIX, "attr_");
    48. //up.setParam("fmap.content", "filestream");
    49. up.setAction(AbstractUpdateRequest.ACTION.COMMIT, true, true);
    50. solr.request(up);
    51. }
    52. static void testQuery(SolrServer solr)  throws IOException, SolrServerException {
    53. String fileStream = "filestream:老婆的老公";
    54. String field = "orgid:33010033001";
    55. QueryResponse rsp = solr.query(new SolrQuery(field));
    56. System.out.println(rsp);
    57. }
    58. }

solr学习三(测试类,含普通与ExtractingRequestHandler测试)的更多相关文章

  1. Junit核心——测试类(TestCase)、测试集(TestSuite)、测试运行器(TestRunner)

    首先,把这三个定义简单的说明一下: 1.测试类(TestCase):一个包含一个或是多个测试的类,在Junit中就是指的是包含那些带有@Test注解的方法的类,同一样也被称作“测试用例”; 2.测试集 ...

  2. python调用HTMLTestRunner+unittest实现一次执行多个测试类,并生成与每个测试类对应的测试报告,具体看代码,附上整个project代码

    python自动化框架雏形,根据自己需要封装:ui自动化,接口自动化均可适用,python版本为python3.x,不要问我为什么不用python2.x,附上整个project代码:http://fi ...

  3. C++学习三 模板类出错总结(Missing template arguments before 'L')

    一.模板类的说明 模板类有一个好处是可以放宽你输入的数据类型. 比如有这样的一个函数: int add(int x, int y) { return x+y; } 这个函数对于int类型的x,y才适合 ...

  4. XCode中的单元测试:编写测试类和方法(内容意译自苹果官方文档)

    当你在工程中通过测试导航栏添加了一个测试target之后, xcode会在测试导航栏中显示该target所属的测试类和方法. 这一章演示了怎么创建测试类,以及如何编写测试方法. 测试targets, ...

  5. 多个测试类 只使用同一个浏览器,同一个driver对象, 或者同一个页面的对象

    如果是:多个测试类 只使用同一个浏览器,同一个driver对象, 或者同一个页面的对象,只需要:1. 创建一个基本的测试类(BaseTest),具有一个公共静态的driver属性, public st ...

  6. Dubbo入门到精通学习笔记(十五):Redis集群的安装(Redis3+CentOS)、Redis集群的高可用测试(含Jedis客户端的使用)、Redis集群的扩展测试

    文章目录 Redis集群的安装(Redis3+CentOS) 参考文档 Redis 集群介绍.特性.规范等(可看提供的参考文档+视频解说) Redis 集群的安装(Redis3.0.3 + CentO ...

  7. JUit——(三)JUnit核心对象(测试、测试类、Suit和Runner)

    JUnit的核心对象:测试.测试类.测试集(Suite).测试运行器 1. 测试: @Test注释的.公共的.不带有任何参数.并且返回void类型的方法 2. 测试类: 公共的,包含对应类的测试方法的 ...

  8. Java开发学习(三十二)----Maven多环境配置切换与跳过测试的三种方式

    一.多环境开发 我们平常都是在自己的开发环境进行开发, 当开发完成后,需要把开发的功能部署到测试环境供测试人员进行测试使用, 等测试人员测试通过后,我们会将项目部署到生成环境上线使用. 这个时候就有一 ...

  9. JAVA基础学习之路(三)类定义及构造方法

    类的定义及使用 一,类的定义 class Book {//定义一个类 int price;//定义一个属性 int num; public static int getMonney(int price ...

随机推荐

  1. WPF 元素的查找

    预设置元素名字 WPF有两种方式设置元素的Name <StackPanel x:Name="panel"> <Label Name="name1&quo ...

  2. 『Kaggle』分类任务_决策树&集成模型&DataFrame向量化操作

    决策树这节中涉及到了很多pandas中的新的函数用法等,所以我单拿出来详细的理解一下这些pandas处理过程,进一步理解pandas背后的数据处理的手段原理. 决策树程序 数据载入 pd.read_c ...

  3. hdu多校2C

    题意:找多条路径覆盖所有的边,求最小路径数,要求输出路径 题解:新建一个点n+1,所有奇点向它连边,然后跑欧拉回路,最后把新加的边删去,一段连续的边就是一条路径 = =但是由于太久没写欧拉回路以及之前 ...

  4. Note: further occurrences of HTTP header parsing errors will be logged at DEBUG level

    2018-03-23 18:32:21,690 [INFO] [http-nio-11007-exec-2] org.apache.coyote.http11.Http11Processor [Dir ...

  5. Eclipse修改已存在的SVN地址

    1.Window---->Show View---->Other...

  6. nginx支持返回相对路径

    一.问题:http://192.168.72.4/bm-crm/  局域网可以访问[实际指向了192.168.80.1:8081/brm-crm] http://59.41.111.24:8280/b ...

  7. Spring Boot 学习(一) 快速搭建SpringBoot 项目

    快速搭建一个 Spring Boot 项目 部分参考于<深入实践Spring Boot>.<Spring实战 第四版>与程序猿DD的有关博客. 参考(嘟嘟独立博客):http: ...

  8. idea Exception in thread "http-apr-8080-exec-2" java.lang.OutOfMemoryError: PermGen space

    idea Exception in thread "http-apr-8080-exec-2" java.lang.OutOfMemoryError: PermGen space ...

  9. JAVASCRIPT开发HTML5游戏--斗地主(网络对战PART4)

    继之前用游戏引擎(青瓷引擎)做了斗地主单机版游戏之后,这里分享下使用socket.io来实现网络对战,代码可已放到github上,在此谈谈自己整个的开发思路吧. 客户端代码 服务端代码 (点击图片进入 ...

  10. sgu107. 987654321 problem 简单打表 难度:0

    107. 987654321 problem time limit per test: 0.25 sec. memory limit per test: 4096 KB For given numbe ...