Home | » | ASP | » | Debugging You ASP Scripts and Handling Errors |
In ASP application, you can't usually crash the application the-ASP engine won't let it happen, but by default, any error that occurs on a page causes the ASP engine to stop executing the code on that page. To your users, it doesn't matter whether your application crashed or not. If users can't accomplish their goals, then your program is broken, no matter what the reason.
Contents
- How to Approach Error Handling?
- Raising Errors
- Debugging ASP Scripts
- Debugging Fatal and Non-fatal Bugs
How to Approach Error Handling?
One Way to approache the understanding of a large subject is to categories it into smaller chunks. There are 5 main categories of errors:
- Syntax errors
- Parameters/Input errors
- Logic errors
- Errors in external codes
- Resource errors
- Keep your application from crashing
- Provide as much information as possible about the error
- Propagate errors back to critical decision point
- Degrade gracefully
Raising Errors
The following code fragment raises an error if a string is to long or too short:
You can raise errors at the top-level and you'll see the standard error display with your error information, but you are probably better of redirecting to an error page. The error page would display only those parts of an error that you want to reveal to your clients.
Debugging ASP Scripts
Despite your best efforts, errors occur during development and you must track them down. Debugging ASP is still awkward, even at the best of times.
There are several different environments for writing ASP scripts, only Microsoft's Visual InterDev_environment has debugging facilities. Writing debug output isn't dependent on any particular environment-u can use it effectively even with a plain text editor.
Output
Last Name | Bintu |
---|---|
First Name | Chaudhary |
- The code creates the Dictionary object properly: otherwise the first assignment would raise an error.
- The values are apparently assigned properly because no error occurred-but because of the way Dictionary object work, you can't be absolutely sure of that.
- The html code is well formatted-all the rows and columns appear in the table.
Next, look at what you don't know. You don't know if the Dictionary contains the Email value, or whether it just isn't showing up properly. One test is to write a loop that displays all the keys and values in the Dictionary. Inser the following code after the <body> tag, but before the <table> tag.
All the fields show up. Therefore, the problem must lie in the way the code references the Email value.
Output
Last Name | Chaudhary |
---|---|
First Name | Bintu |
abc@gmail.com |
Debugging Fatal and Non-fatal Bugs
While debugging your ASP application we need to watch for two types of bugs.
Non-fatal bugs: It does not halt the execution of a program; rather, it causes the program to generate the wrong output for a given input.
Debugging Fatal Bugs
To see a good example of converting a non fatal bug into a fatal bug, compare listing 1 and listing 2.
Example 1 Non-fatal bugs
In Example,1, we commit an error of using an undeclared variable. note that line 3 declares the only variable as strName. Then line 4 refers to variable as strNme, a simple typo. Because we have noy explicitly declared a variable named strNme, this should cause a fatal bug. However it does not because we have not used option explicit. In lusting 1 two variables are allocated, one explicity (strName) and one implicitly(strNme). strNme is assigned the value Bintu, whereas strName equals the empty string. Therefore when line 6 outputs the value of strName, an empty string will be output. The output of Example 1 will be "Hello". because Example 1 executes completely and we did not receive the output we expected, the bug is classified as a non fatal bug. although the typo on line four in Example 1 might be easy to catch now, it becomes much more difficult when you have such an error on an asp page with hundreds of lines of code. it is in your favour, then to turn all non fatal bugs into fatal bugs. Example 2 contains the exact same code as Example 1. excpt for adding option explicit on line 2.
Example 2 Fatal bugs
Debugging Fatal Bugs
- Expected input values
- Near-boundaries input values
- Boundary input values
- Unexpected input values
Blogger Comment
Facebook Comment