Skip to main content

Error and Exception Handling in UiPath Studio

System and Business exceptions

Errors are events that occur in a program and can't be handled normally. On the other hand, exceptions are events that are recognized, categorized, and handled by the program.

Errors are events that a particular program can’t normally deal with. There are different types of errors, based on what's causing them—for example:

Syntax errors, where the compiler/interpreter can't parse the written code into meaningful computer instructions.
User errors, where the software determines that the user’s input isn't acceptable for some reason.
Programming errors, where the program contains no syntax errors but doesn't produce the expected results. These types of errors are often called bugs.

Exceptions are events that are recognized (caught) by the program, categorized, and handled. More specifically, there is a routine configured by the developer that is activated when an exception is caught. Sometimes, the handling mechanism can be simply stopping the execution.

Some of the exceptions are linked to the systems used, while others are linked to the logic of the business process.

System exceptions

The unexpected exceptions are the one known as System Exceptions (SE). They're also called Application Exceptions (AE), but the underlying concept remains the same. They belong to the .NET framework and are categorized under the System.Exception class. Proper handling should be in place for these kinds of exceptions and they can cause the process to fail.

The below list encompasses the most common exceptions that you can encounter in projects developed with Studio. They are derived from System.Exception as mentioned already, so using this generic type in a TryCatch, for example, will catch all types of errors.

NullReferenceException

Occurs when using a variable with no set value (not initialized).

IndexOutOfRangeException

Occurs when the index of an object is out of the limits of the collection.

ArgumentException

Is thrown when a method is invoked and at least one of the passed arguments doesn't meet the parameter specification of the called method.

SelectorNotFoundException

Is thrown when the robot is unable to find the specified selector for an activity in the target app within the Timeout period. As you know, the timeout property specifies the amount of time, in seconds, that the system will wait for an operation to finish before generating an error.

ImageOperationException

Occurs when an image isn't found within the Timeout period.

TextNotFoundException

Occurs when the indicated text isn't found within the Timeout period.

ApplicationException

Describes an error rooted in a technical issue, such as an application that isn't responding.

Business exceptions


On the other hand, the expected exceptions are the ones referred to as Business Rule Exceptions (BRE).

A business exception mainly refers to information used in an automated process; either it may be incomplete or incorrect from a business perspective. When business exceptions occur, robots stop the process, and it requires human intervention to address a thrown exception.

Some of the examples of business exceptions are: certain pieces of data which the automation project depends on are incomplete, missing, outside set boundaries (like trying to extract more from the ATM than its daily limit), or don't pass other data validation criteria.

The message associated with a business rule exception should provide meaningful information for the process. For example, if a business rule states that only purchase orders (POs) with a value greater than $1000 should be processed, the code would include an If statement to check the value. If the value is less than or equal to $1000, a Business Rule Exception (BRE) is thrown with a message like "The PO <id of PO> value is less or equal than 1000$. The transaction is not processed."

BREs aren't automatically generated as system exceptions. They must be defined by a developer by using the Throw Activity and handled inside a TryCatch.

Source: UiPath Academy

Comments

Popular posts from this blog

How to set Profile Attribute in Siebel Workflow

For setting the Profile Attribute in Siebel Workflow, follow below steps: Add Business Service box in workflow. Open Business Service properties. Set  SessionAccessService in Business Service Name. Set  SetProfileAttr in Method Name. Then click on Business Service and set Input Arguments as below: Against Name argument you will add your profile attribute name and against Value argument you will add value for the new profile attribute, it could be from Process Property or Literal.

How to call Popup Applet through Server Script in Siebel

Background: Based on the requirements you need to show data or reports on a popup applet. You can invoke popup applet using workflow (below business service will be used in business service step), applet server script or browser script and using vanilla method and setting field user properties. Procedure: Below is the script for calling popup applet through server script: if (MethodName == "MethodName") { var oServiceAF = TheApplication().GetService("SLM Save List Service"); var inputPropAF = TheApplication().NewPropertySet(); var outputPropAF = TheApplication().NewPropertySet(); inputPropAF.SetProperty("Applet Name","ABC Popup Applet"); inputPropAF.SetProperty("Applet Mode","6"); inputPropAF.SetProperty("Applet Height", "700"); inputPropAF.SetProperty("Applet Width", "700"); oServiceAF.InvokeMethod("LoadPopupApplet", inputPropAF, outputPropAF) return (CancelOperati...

How to create and publish Inbound Web Service in Siebel based on Workflow

Inbound Web Services: The Inbound Web Service allows an external system to call a Siebel published Web Service. You can publish a business service or a business process as a Web Service and generate a Web Service Definition Language (WSDL) file that an external system can import. The Inbound Web Services can only be published from Siebel C using SOAP-RPC binding. Source: Oracle Docs What Is The Difference Between Web Services and APIs? An API is an interface that allows you to build on the data and functionality of another application, while a web service is a network-based resource that fulfills a specific task. Yes, there’s overlap between the two: all web services are APIs, but not all APIs are web services. Both web services and APIs are — at their core — very useful and very much used today. However, it’s the web services associated with SOAP and/or Service Oriented Architecture which are falling out of favor. Source: NordicApis Process: Prepare the workflow which will serve as Si...