/*
* Copyright 2016 Red Hat, Inc. and/or its affiliates.
*
* 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 org.kie.workbench.common.services.refactoring.backend.server.drl;
import static org.junit.Assert.assertEquals;
import static org.mockito.Matchers.argThat;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
import java.io.IOException;
import java.util.Collections;
import java.util.Map;
import java.util.concurrent.ExecutionException;
import org.apache.lucene.analysis.Analyzer;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.Query;
import org.apache.lucene.search.ScoreDoc;
import org.apache.lucene.search.TopScoreDocCollector;
import org.junit.Test;
import org.kie.workbench.common.services.refactoring.backend.server.BaseIndexingTest;
import org.kie.workbench.common.services.refactoring.backend.server.TestIndexer;
import org.kie.workbench.common.services.refactoring.backend.server.query.builder.SingleTermQueryBuilder;
import org.kie.workbench.common.services.refactoring.model.index.terms.valueterms.ValueReferenceIndexTerm;
import org.kie.workbench.common.services.refactoring.service.ResourceType;
import org.mockito.ArgumentMatcher;
import org.slf4j.LoggerFactory;
import org.uberfire.ext.metadata.backend.lucene.index.LuceneIndex;
import org.uberfire.ext.metadata.engine.Index;
import org.uberfire.java.nio.file.Path;
import ch.qos.logback.classic.Logger;
import ch.qos.logback.classic.spi.ILoggingEvent;
import ch.qos.logback.core.Appender;
public class IndexDrlInvalidDrl extends BaseIndexingTest<TestDrlFileTypeDefinition> {
@Test
public void testIndexDrlInvalidRuleName() throws IOException, InterruptedException, ExecutionException {
//Setup logging
final Logger root = (Logger) LoggerFactory.getLogger( Logger.ROOT_LOGGER_NAME );
final Appender<ILoggingEvent> mockAppender = mock( Appender.class );
when( mockAppender.getName() ).thenReturn( "MOCK" );
root.addAppender( mockAppender );
//Add test files
final Path path1 = basePath.resolve( "bz1269366.drl" );
final String drl1 = loadText( "bz1269366.drl" );
ioService().write( path1, drl1 );
Thread.sleep(5000);
final Index index = getConfig().getIndexManager().get( org.uberfire.ext.metadata.io.KObjectUtil.toKCluster( basePath.getFileSystem() ) );
{
final Query query = new SingleTermQueryBuilder( new ValueReferenceIndexTerm( "org.kie.workbench.common.services.refactoring.backend.server.drl.classes.Applicant", ResourceType.JAVA ) ).build();
final IndexSearcher searcher = ( (LuceneIndex) index ).nrtSearcher();
final TopScoreDocCollector collector = TopScoreDocCollector.create( 10 );
searcher.search( query,
collector );
final ScoreDoc[] hits = collector.topDocs().scoreDocs;
assertEquals( 0,
hits.length );
verify( mockAppender ).doAppend( argThat( new ArgumentMatcher<ILoggingEvent>() {
@Override
public boolean matches( final Object argument ) {
return ( (ILoggingEvent) argument ).getMessage().startsWith( "Unable to parse DRL" );
}
} ) );
( (LuceneIndex) index ).nrtRelease( searcher );
}
}
@Override
protected TestIndexer getIndexer() {
return new TestDrlFileIndexer();
}
@Override
public Map<String, Analyzer> getAnalyzers() {
return Collections.<String, Analyzer>emptyMap();
}
@Override
protected TestDrlFileTypeDefinition getResourceTypeDefinition() {
return new TestDrlFileTypeDefinition();
}
@Override
protected String getRepositoryName() {
return this.getClass().getSimpleName();
}
}