Drools - डिबगिंग

ड्रोल्स प्रोजेक्ट को डिबग करने के विभिन्न तरीके हैं। यहां, हम आपको यह बताने के लिए एक उपयोगिता वर्ग लिखेंगे कि किन नियमों को ट्रिगर या निकाल दिया जा रहा है।

इस दृष्टिकोण के साथ, आप जांच सकते हैं कि आपके ड्रॉल्स प्रोजेक्ट में सभी नियम क्या हो रहे हैं। यहाँ हमारी उपयोगिता वर्ग है

Utility.java

package com.sample;
import org.drools.spi.KnowledgeHelper;

public class Utility {
   public static void help(final KnowledgeHelper drools, final String message){
      System.out.println(message);
      System.out.println("\nrule triggered: " + drools.getRule().getName());
   }
   public static void helper(final KnowledgeHelper drools){
      System.out.println("\nrule triggered: " + drools.getRule().getName());
   }
}

पहली विधि help कुछ अतिरिक्त जानकारी के साथ नियम को ट्रिगर करता है जिसे आप DRL फ़ाइल के माध्यम से स्ट्रिंग के रूप में पास कर सकते हैं।

दूसरा नियम helper प्रिंट करता है कि क्या विशेष नियम ट्रिगर किया गया था या नहीं।

हमने प्रत्येक DRL फ़ाइल में उपयोगिता विधियों में से एक जोड़ा है। हमने DRL फ़ाइल (Pune.drl) में आयात फ़ंक्शन भी जोड़ा है। मेंthenनियम का हिस्सा, हमने उपयोगिता फ़ंक्शन कॉल को जोड़ा है। संशोधित Pune.drl नीचे दिया गया है। नीले रंग में परिवर्तन किए गए हैं।

संशोधित पुणे

//created on: Dec 24, 2014
package droolsexample

//list any import classes here.
import com.sample.ItemCity;
import java.math.BigDecimal;
import com.sample.HelloCity; 
import function com.sample.Utility.helper;

// declare any global variables here
dialect "java"
rule "Pune Medicine Item"
   when
      item : ItemCity(purchaseCity == ItemCity.City.PUNE, 
         typeofItem == ItemCity.Type.MEDICINES)
   
   then
      BigDecimal tax = new BigDecimal(0.0);
      item.setLocalTax(tax.multiply(item.getSellPrice()));
      HelloCity.writeHello(item.getPurchaseCity().toString()); 
      helper(drools);
end

rule "Pune Groceries Item"
   when
      item : ItemCity(purchaseCity == ItemCity.City.PUNE, 
         typeofItem == ItemCity.Type.GROCERIES)
   then
      BigDecimal tax = new BigDecimal(2.0);
      item.setLocalTax(tax.multiply(item.getSellPrice())); 
      helper(drools);
end

इसी प्रकार, हमने दूसरी डीआरएल फ़ाइल (Nagpur.drl) में अन्य उपयोगिता फ़ंक्शन को जोड़ा है। यहाँ संशोधित कोड है -

नागपुर नागपुर संशोधित

// created on: Dec 26, 2014
package droolsexample

// list any import classes here.
import com.sample.ItemCity;
import java.math.BigDecimal; 
import function com.sample.Utility.help;

//declare any global variables here
dialect "java"

rule "Nagpur Medicine Item"
   when
      item : ItemCity(purchaseCity == ItemCity.City.NAGPUR, 
         typeofItem == ItemCity.Type.MEDICINES)
   
   then
      BigDecimal tax = new BigDecimal(0.0);
      item.setLocalTax(tax.multiply(item.getSellPrice())); 
      help(drools,"added info");
end

rule "Nagpur Groceries Item"
   when
      item : ItemCity(purchaseCity == ItemCity.City.NAGPUR, 
         typeofItem == ItemCity.Type.GROCERIES)
   then
      BigDecimal tax = new BigDecimal(1.0);
      item.setLocalTax(tax.multiply(item.getSellPrice())); 
      help(drools,"info");
end

प्रोग्राम को फिर से चलाएँ और इसे निम्न आउटपुट का उत्पादन करना चाहिए -

info

rule triggered: Nagpur Groceries Item
added info

rule triggered: Nagpur Medicine Item

rule triggered: Pune Groceries Item
HELLO PUNE!!!!!!

rule triggered: Pune Medicine Item
PUNE 0
PUNE 20
NAGPUR 0
NAGPUR 10

दोनों उपयोगिता कार्यों को कहा जाता है और यह दर्शाता है कि विशेष नियम को बुलाया गया था या नहीं। उपरोक्त उदाहरण में, सभी नियमों को बुलाया जा रहा है, लेकिन एक उद्यम आवेदन में, यह उपयोगिता फ़ंक्शन वास्तव में डिबग करने के लिए उपयोगी हो सकता है और यह पता लगा सकता है कि एक विशेष नियम को निकाल दिया गया था या नहीं।

ग्रहण में डीबग परिप्रेक्ष्य का उपयोग करना

आप अपने ड्रोल एप्लिकेशन के निष्पादन के दौरान नियमों को डीबग कर सकते हैं। आप अपने नियमों के परिणामों में ब्रेकप्वाइंट जोड़ सकते हैं, और जब भी नियमों के निष्पादन के दौरान इस तरह के ब्रेकप्वाइंट का सामना किया जाता है, तो निष्पादन अस्थायी रूप से रोक दिया जाता है। आप उस बिंदु पर ज्ञात चर का निरीक्षण कर सकते हैं जैसा कि आप एक जावा अनुप्रयोग में करते हैं, और ग्रहण में उपलब्ध सामान्य डिबगिंग विकल्पों का उपयोग करते हैं।

अपनी DRL फ़ाइल में एक ब्रेकपॉइंट बनाने के लिए, उस लाइन पर डबल-क्लिक करें, जहाँ आप एक ब्रेकपॉइंट बनाना चाहते हैं। याद रखें, आप केवल एक ब्रेकपॉइंट बना सकते हैंthenएक नियम का हिस्सा। डीआरएल संपादक में ब्रेकपॉइंट पर डबल-क्लिक करके एक ब्रेकपॉइंट हटाया जा सकता है।

ब्रेकप्वाइंट लगाने के बाद, आपको अपने एप्लिकेशन को ड्रोल एप्लिकेशन के रूप में डीबग करना होगा। ड्रॉल्स ब्रेकपॉइंट (डीआरएल फाइल में ब्रेकप्वाइंट) केवल तभी काम करेगा जब आपके एप्लिकेशन को ड्रोल एप्लिकेशन के रूप में डिबग किया जा रहा हो। यहाँ आपको वही करने की आवश्यकता है -

एक बार जब आप अपने एप्लिकेशन को ड्रोल एप्लिकेशन के रूप में डीबग करते हैं, तो आपको डीआरएल फ़ाइल पर नियंत्रण दिखाई देगा जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है -

आप उस डिबग बिंदु पर चर और वस्तु के वर्तमान मूल्यों को देख सकते हैं। अगली डीबग बिंदु पर जाने के लिए अगली पंक्ति और F8 पर जाने के लिए F6 का समान नियंत्रण यहां भी लागू होता है। इस तरह, आप अपने ड्रोल एप्लिकेशन को डीबग कर सकते हैं।

Note - ड्रोल एप्लिकेशन में डीबग परिप्रेक्ष्य केवल तभी काम करता है जब बोली एमआरईएल ड्रॉल्स 5.x तक हो।