Newsletters   Subscriptions  Forums  Store   Career  Media Kit  About Us  Contact  Search   Home 
fhg
Volume 5, Number 43 -- November 16, 2005

Two Handy Programs


by Ted Holt


I get quite a bit of email from readers who say they have found something in Four Hundred Guru to be of help to them. I appreciate their taking time to let me know. Today I present two CL programs that I would be hard-pressed to do without. I hope some of you will find them helpful too.

Here's the first one, DUMMY1.

pgm   
return

Do you like it? At two lines, it would be hard to make a keying error when typing it in, wouldn't it? I don't think it matters what activation group it runs in, but I compile it to run in the caller's activation group.

CRTBNDCL PGM(mylib/DUMMY1)        
   SRCFILE(mylib/QCLSRC)
   SRCMBR(DUMMY1) 
   DFTACTGRP(*NO)         
   ACTGRP(*CALLER)

I use DUMMY1 for program testing. Suppose I am modifying a CL program that calls a lot of programs, some of which I do not want to run during testing. Maybe some of the called programs take a long time to run and I only want to test the changed logic in the calling program. Maybe one of the programs does something I don't want to be done, such as sending a fax. In such cases, I clone DUMMY1 as many times as is necessary, creating the clones in QTEMP or one of my development libraries and giving them the same names as the programs that I do not want to run.

Suppose the program I am modifying looks like this:

PGM
CALL       PGM(SOMEPGM)

But I want it to look like this:

PGM
CALL       PGM(SOMEPGM)
SNDPGMMSG  MSG('Program SOMEPGM completed normally') +
             MSGTYPE(*COMP)

Program SOMEPGM does not need to run in order for me to verify that the SNDPGMMSG command works properly, so I clone DUMMY1.

CRTDUPOBJ OBJ(DUMMY1) FROMLIB(MYLIB) OBJTYPE(*PGM) +
          TOLIB(QTEMP) NEWOBJ(SOMEPGM)

When the program I'm testing calls SOMEPGM, it calls the copy in QTEMP, which is always at the top of my library list, rather than the copy in the production library.

Sometimes I like to know that the dummy program ran, even though it didn't do anything. In those cases, I prefer to use the second program, which I cleverly call DUMMY2.

pgm                                                            
                                                               
dcl   &MsgKey        *char      4                        
dcl   &PgmName       *char     10                        
dcl   &Sender        *char     80                        
                                                               
/* Determine the name of this program. */                      
                                                               
sndpgmmsg   msg('Dummy message') topgmq(*same) +         
              msgtype(*info) keyvar(&msgkey)             
rcvmsg      pgmq(*same) msgtype(*info) msgkey(&MsgKey) + 
              rmv(*yes) sender(&Sender)                  
chgvar      var(&PgmName) value(%sst(&Sender 27 10))     
                                                               
sndmsg      msg('Program' *bcat &PgmName *bcat +         
                      'is running.') tousr(*requester)         
endpgm

Like DUMMY1, DUMMY2 does no processing of any kind. However, it does have the courtesy to let me know it's running. When my clone of DUMMY2 runs, I get a message on my screen: Program SOMEPGM is running.

Create DUMMY2 according to the compilation instructions for DUMMY1.


Let me add a couple more comments. First, the programs that these CL programs replace do not have to be CL programs. In the example given above, I did not mention what language SOMEPGM was written in. It didn't matter.

Second, testing is an art in itself, and entire books have been written about the subject. Too much software is installed without adequate testing, but fortunately, simple techniques, like the use of do-nothing programs, can make the testing process easier.

Sponsored By
ADVANCED SYSTEMS CONCEPTS

SEQUEL can be used for virtually ALL data access functions on the iSeries.

A Windows-based user interface makes it easy to design queries and reports.

SEQUEL offers executive dashboards, drill-down data analysis and run-time prompts to deliver important iSeries data to managers and other non-technical users.

E-mail and FTP delivery let you deliver information to remote users and servers.

www.asc-iseries.com


Technical Editors: Howard Arner, Joe Hertvik, Ted Holt,
Shannon O'Donnell, Kevin Vandever
Contributing Technical Editors: Joel Cochran, Wayne O. Evans, Raymond Everhart,
Bruce Guetzkow, Marc Logemann, David Morris
Publisher and Advertising Director: Jenny Thomas
Advertising Sales Representative: Kim Reed
Contact the Editors: To contact anyone on the IT Jungle Team
Go to our contacts page and send us a message.


THIS ISSUE
SPONSORED BY:

T.L. Ashford
Advanced Systems Concepts
WorksRight Software


Four Hundred Guru

BACK ISSUES

TABLE OF
CONTENTS
API Corner: Backup APIs

Two Handy Programs

Admin Alert: Darn Good FTP Commands You've Probably Never Heard Of


The Four Hundred
Keep Your Perspective on Platform Costs

The iSeries Goes to Town in Local Government

Nomination Process for iSeries Innovation Awards Opens

Shaking IT Up: Preemptive Listening, a Tool of Tools

Four Hundred Stuff
Teamstudio Brings Domino Version Control to iSeries

Lawson Unveils "Skip Upgrade" for iSeries Customers

IBM Updates Virtualization Engine for Multiplatform Management

IBM Unveils New Midrange Storage Systems

Four Hundred Monitor


Copyright © 1996-2008 Guild Companies, Inc. All Rights Reserved.
Guild Companies, Inc. (formerly Midrange Server), 50 Park Terrace East, Suite 8F, New York, NY 10034
Privacy Statement