Has the application run successfully before?
Application errors can often be determined by determining if they have run successfully before or if they have produced error messages and unexpected return codes.
If the problem appears to involve one particular application, consider whether the application has run successfully before.
Before you answer Yes to this question, consider:
- Have any changes been made to the application since it last ran successfully?
- If so, it is likely that the error lies somewhere in the new or modified part of the application. Investigate the changes and see if we can find an obvious reason for the problem.
- Have all the functions of the application been fully exercised before?
-
Did problem occur when part of the application that had never been started before was used for the first time? If so, it is likely that the error lies in that part of the application. Try to find out what the application was doing when it failed, and check the source code in that part of the program for errors.
If a program has been run successfully on many previous occasions, check the current queue status and files that were being processed when the error occurred. It is possible that they contain some unusual data value that causes a rarely used path in the program to be invoked.
- Does the application check all return codes?
- Has your system has been changed, perhaps in a minor way. Check the return codes your
application receives as a result of the change. For example:
- Does our application assume that the queues it accesses can be shared? If a queue has been redefined as exclusive, can our application deal with return codes indicating that it can no longer access that queue?
- Have any security profiles been altered? An MQOPEN call might fail because of a security violation; can our application recover from the resulting return code?
- Does the application expect particular message formats?
- If a message with an unexpected message format has been put onto a queue (for example, a message from a queue manager on a different platform), it might require data conversion or another different form of processing.
- Does the application run on other IBM MQ for z/OSĀ® systems?
- Is something different about the way that this queue manager is set up that is causing the problem? For example, have the queues been defined with the same maximum message length, or default priority?
- Does the application use the MQSET call to change queue attributes?
- Is the application is designed to set a queue to have no trigger, then process some work, then set the queue to have a trigger? The application might have failed before the queue had been reset to have a trigger.
- Does the application handle messages that cause an application to fail?
- If an application fails because of a corrupted message, the message retrieved is rolled back. The next application might get the same message and fail in the same way. Ensure that applications use the backout count; when the backout count threshold has been reached, the message in question is put onto the backout queue.
If our application has never run successfully before, examine our application carefully to see if we can find any of the following errors:
- Translation and compilation problems
- Before you look at the code, examine the output from the translator, the compiler or assembler, and the linkage editor, to see if any errors have been reported. If our application fails to translate, compile/assemble, or link edit into the load library, it also fails to run if you attempt to invoke it. See Developing applications for information about building our application, and for examples of the job control language (JCL) statements required.
- Batch and TSO programs
- For batch and TSO programs, check that the correct stub has been included. There is one batch stub and two RRS stubs. If you are using RRS, check that you are not using the MQCMIT and MQBACK calls with the CSQBRSTB stub. Use the CSQBRRSI stub if you want to continue using these calls with RRS.
- CICSĀ® programs
- For CICS programs, check that the program, the IBM MQ CICS stub, and the CICS stub have been linked in the correct order. Also, check that your program or transaction is defined to CICS.
- IMS programs
- For IMS programs, check that the link includes the program, the IBM MQ stub, and the IMS language interface module. Ensure that the correct entry point has been specified. A program that is loaded dynamically from an IMS program must have the stub and language interface module linked also if it is to use IBM MQ.
- Possible code problems
- If the documentation shows that each step was accomplished without error, consider the coding of the application. Do the symptoms of the problem indicate the function that is failing and, therefore, the piece of code in error? See Do we have a program error? for some examples of common errors that cause problems with IBM MQ applications.
- Do applications report errors from IBM MQ ?
- For example, a queue might not be enabled for "gets". It receives a return code specifying this condition but does not report it. Consider where our applications report any errors or problems.