帮助网友解决一个drools的问题

      看到网友提的一个问题:

   http://drools.group.iteye.com/group/topic/39063

 

      鄙人刚刚开始研究Drools,但看了些例子,仍然不知道怎么处理下面的业务: 

超市打折促销,某种商品(按照类别code)促销规则: 
   1.在指定日期区间内(比如1月1日-1月3日), 
   2.买第1件按原价,第2件则价格打6折。第3件原价,第4件打6折... ... 

现在顾客推着购物车来消费,里面有很多种商品,其中上面促销的那种有5件,结果应该是3件原价,两件要打折。 

哪位大大提供个思路,怎么用drools来给顾客的购物票算总额。

 

由于之前使用的是excel规则表,我也使用excel规则表。


帮助网友解决一个drools的问题_第1张图片
 测试的父类如下:

 

import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.Arrays;
import java.util.Collection;
import java.util.Map;

import org.drools.KnowledgeBase;
import org.drools.KnowledgeBaseFactory;
import org.drools.builder.DecisionTableConfiguration;
import org.drools.builder.DecisionTableInputType;
import org.drools.builder.KnowledgeBuilder;
import org.drools.builder.KnowledgeBuilderFactory;
import org.drools.builder.ResourceType;
import org.drools.definition.KnowledgePackage;
import org.drools.io.ResourceFactory;
import org.drools.runtime.StatelessKnowledgeSession;

public class KATestBase {
	public void testExcel(String fileName, Map<String, Object> params)
			throws Exception {
		System.out.println("---------------begin------------------------");
		
		DecisionTableConfiguration dtableconfiguration = KnowledgeBuilderFactory
				.newDecisionTableConfiguration();
		dtableconfiguration.setInputType(DecisionTableInputType.XLS);
		final KnowledgeBuilder kbuilder = KnowledgeBuilderFactory
				.newKnowledgeBuilder();
		File file = new File("E:\\workspace\\epct\\rule\\src\\test\\resources\\"
				+ fileName);
		InputStream is = new FileInputStream(file);

		//InputStream is = new ClassPathResource(fileName).getInputStream();
		kbuilder.add(ResourceFactory.newInputStreamResource(is,"UTF-8"),
				ResourceType.DTABLE);
		if (kbuilder.hasErrors()) {
			System.out.println(kbuilder.getErrors().toString());
		}
		Collection<KnowledgePackage> pkgs = kbuilder.getKnowledgePackages();
		KnowledgeBase kbase = KnowledgeBaseFactory.newKnowledgeBase();
		kbase.addKnowledgePackages(pkgs);

		StatelessKnowledgeSession ksession = kbase
				.newStatelessKnowledgeSession();
		ksession.execute(Arrays.asList(new Object[] {params}));
		
		System.out.println("---------------end------------------------");
	}
}

 测试的子类如下:

 

import java.util.Arrays;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;

import junit.framework.Assert;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters;

@RunWith(Parameterized.class)  
public class DroolsTest extends KATestBase{
	 private KADest param;  
	 private String extected;  
	      
	 public DroolsTest(KADest param,String extected) {  
	        this.param = param;  
	        this.extected = extected;  
	 }  
	    
	public static class KADest {
		private String orderTime;
		private String orderTotal;
		
		public KADest(String orderTime, String orderTotal) {
			this.orderTime = orderTime;
			this.orderTotal = orderTotal;
		}
		
		public Map<String,Object> getParams(){
			Map<String,Object> params = new HashMap<String,Object>();
			
			
			params.put("orderTime", orderTime);
			params.put("orderTotal", orderTotal);
			params.put("discountTotal", 0);
			
			return params;
		}
	} 
      
    @Parameters
    public static Collection<?> contructData(){  
        return Arrays.asList(new Object[][]{  
                {new KADest("2013-01-02 12:30:31","6"),"3"},
                {new KADest("2013-01-02 12:30:31","1"),"0"},
                {new KADest("2013-01-02 12:30:31","2"),"1"},
                {new KADest("2013-01-01 12:30:31","2"),"1"},
                {new KADest("2013-01-01 12:30:31","2"),"1"},
                {new KADest("2013-01-01 12:30:31","2"),"1"},
                {new KADest("2013-01-04 12:30:31","2"),"0"},
                {new KADest("2013-01-04 12:30:31","2"),"0"},
                {new KADest("2013-01-04 12:30:31","2"),"0"},
               });
    }  
    
    @Test
    public void testKaDest() throws Exception{
    	Map<String,Object> params = new HashMap<String,Object>();
    	params.putAll(param.getParams());
    	System.out.println(params);
    	super.testExcel("ka/drools.xls", params);
    	System.out.println(params);
        Assert.assertEquals(extected, "" +params.get("discountTotal"));  
    }

 单元测试结果如下:


帮助网友解决一个drools的问题_第2张图片
 

 

你可能感兴趣的:(drools)