/* * * * Copyright 2014 Orient Technologies. * * * * Licensed under the Apache License, Version 2.0 (the "License"); * * you may not use this file except in compliance with the License. * * You may obtain a copy of the License at * * * * http://www.apache.org/licenses/LICENSE-2.0 * * * * Unless required by applicable law or agreed to in writing, software * * distributed under the License is distributed on an "AS IS" BASIS, * * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * * See the License for the specific language governing permissions and * * limitations under the License. * */ package com.orientechnologies.lucene.test; import com.orientechnologies.orient.core.command.script.OCommandScript; import com.orientechnologies.orient.core.record.impl.ODocument; import com.orientechnologies.orient.core.sql.OCommandSQL; import com.orientechnologies.orient.core.sql.query.OSQLSynchQuery; import org.testng.Assert; import org.testng.annotations.Test; import java.io.InputStream; import java.util.List; /** * Created by Enrico Risa (e.risa-at-orientechnologies.com) on 26/09/14. */ @Test(groups = "remote") public class LuceneCreateIndexRemote extends LuceneCreateIndexTest { public LuceneCreateIndexRemote() { super(true); } @Override protected String getDatabaseName() { return "createIndexRemote"; } @Override public void loadAndTest() { InputStream stream = ClassLoader.getSystemResourceAsStream("testLuceneIndex.sql"); databaseDocumentTx.command(new OCommandScript("sql", getScriptFromStream(stream))).execute(); databaseDocumentTx.command(new OCommandSQL("create index Song.title on Song (title) FULLTEXT ENGINE LUCENE")).execute(); databaseDocumentTx.command(new OCommandSQL("create index Song.author on Song (author) FULLTEXT ENGINE LUCENE")).execute(); assertQuery(); restart(); assertQuery(); ODocument doc = new ODocument("Song"); doc.field("title", "Test"); doc.field("author", "Author"); databaseDocumentTx.save(doc); assertNewQuery(); restart(); assertNewQuery(); } protected void assertNewQuery() { List<ODocument> docs = databaseDocumentTx.query(new OSQLSynchQuery<ODocument>( "select * from Song where [title] LUCENE \"(title:Test)\"")); Assert.assertEquals(docs.size(), 1); } }