/*
* Copyright 2012 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.drools.workbench.screens.guided.rule.backend.server.indexing;
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 org.apache.lucene.search.Query;
import org.drools.workbench.screens.guided.rule.type.GuidedRuleDRLResourceTypeDefinition;
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.ValueIndexTerm.TermSearchType;
import org.kie.workbench.common.services.refactoring.model.index.terms.valueterms.ValueResourceIndexTerm;
import org.kie.workbench.common.services.refactoring.service.ResourceType;
import org.mockito.ArgumentMatcher;
import org.slf4j.LoggerFactory;
import org.uberfire.ext.metadata.engine.Index;
import org.uberfire.ext.metadata.io.KObjectUtil;
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 IndexRuleInvalidDrlTest extends BaseIndexingTest<GuidedRuleDRLResourceTypeDefinition> {
@Test
public void testIndexRuleInvalidDrl() throws IOException, InterruptedException {
//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 file
final Path path = basePath.resolve( "bz1269366.rdrl" );
final String drl = loadText( "bz1269366.rdrl" );
ioService().write( path,
drl );
Thread.sleep( 5000 ); //wait for events to be consumed from jgit -> (notify changes -> watcher -> index) -> lucene index
final Index index = getConfig().getIndexManager().get( KObjectUtil.toKCluster( basePath.getFileSystem() ) );
{
final Query query = new SingleTermQueryBuilder( new ValueResourceIndexTerm( "*myRule", ResourceType.RULE, TermSearchType.WILDCARD ) )
.build();
searchFor(index, query, 0 );
verify( mockAppender ).doAppend( argThat( new ArgumentMatcher<ILoggingEvent>() {
@Override
public boolean matches( final Object argument ) {
return ( (ILoggingEvent) argument ).getMessage().startsWith( "Unable to parse DRL" );
}
} ) );
}
}
@Override
protected TestIndexer getIndexer() {
return new TestGuidedRuleDrlFileIndexer();
}
@Override
protected GuidedRuleDRLResourceTypeDefinition getResourceTypeDefinition() {
return new GuidedRuleDRLResourceTypeDefinition();
}
@Override
protected String getRepositoryName() {
return this.getClass().getSimpleName();
}
}