In reviewing my statistics, I found that one common search was “basics steps to create an appengine in PeopleSoft”. I hope the person(s) found what they were looking for on my blog. Nonetheless, that gave me the idea to write a simple overview on creating a new Application Engine program.
This post can’t cover everything but I do plan to cover:
- Creating a new Application Engine definition
- Setting program properties
- Understanding program flow
- Inserting new sections, steps, and actions
- Loops/logic
- State records
- Adding programs to projects
- Where to go from here
Creating a new Application Engine Definition
Application Engine programs are definitions that are created and edited within Application Designer. So, open Application Designer and log in. Next, either use the File > New menu, press Ctrl + N, or click on the “New” icon on the toolbar.
File > New / Ctrl + N:
New icon on the toolbar:
After you do that, you should get a New dialog. There is where you tell Application Designer what type of new object you want to create. From here, you will want to choose the “App Engine Program” object type.
This should give you a new Application Engine program window:
You probably want to save your program as you go. You can use File > Save or Ctrl + S or the Save icon on the toolbar. The first save will prompt you for a name for your new program:
Settings Program Properties
The first thing you need to do is set your properties. If nothing else, you need to check the “Disable Restart” button. So, click on the properties button on the toolbar.
On the first tab of the properties, you should enter a general description of your program. In the comments area, you want to describe in more detail what your program does. You should also enter the date, author, and description of changes to the program throughout it’s lifetime.
Read on for more information about State Records later, but the State Records tab is where you connect the state record with your program.
This is the most important property to set. On the fourth tab, make sure to check the disable restart option. In my opinion, this should be default. I don’t have room to go into all of the reasons, but let’s just say that in order to make a program restartable, you need to make several design decisions first. If you want your program restartable, get it running first, check that your design is restartable, and then, come back here and uncheck the disable restart option.
Understanding Program Flow
The first that you need to understand is what the parts mean and how it runs each piece. So, here are the parts:
- Program: a complete application (or a library of functions)
- Section: like a function in a regular language
- Step: a single task; like a line of code in a regular language
- Action: a single action; like a clause in a regular language
The most important thing to understand is that the program starts at the first step in the “MAIN” section. It runs to the last step of the MAIN section in sequence. At the last step, the program is done. The other sections do not run unless they are explicitly called with a “Call Section” action.
Don’t let the names of the steps confuse you. The name can be anything. The step sequence number (circled below) is what controls the order of the steps. If you’re not careful, the step names can confuse you. In the following example, step02 runs first before step01.
Also, you can’t control the order of the actions. You should have only one action per step unless you are doing looping. If you do insert two actions into the same step, you can hit the refresh button on the toolbar and it will rearrange the actions in the order in which they will execute.
Inserting New Sections, Steps, and Actions
These three buttons on the toolbar insert new sections, steps, and actions (respectively). You can also use the insert menu.
The part of the program you have selected is significant when inserting a new part. When inserting a section, you used to have to select the previous section. Also, the order of the sections does not matter, so once you hit the Refresh button it will alphabetize them by their name. (Remember sections run in the order they are called from MAIN.)
To insert a step, select the step before, and it will insert the new step after what you have selected. The program will never change the order of the steps. If you want to reorder them, you have to cut and paste them in the new location.
To insert an action, select the action or step before, and it will insert the new action afterward. Again, remember that you can’t control the order of the actions. After you insert the action, you will need to change the type in the drop down:
For most of the actions, you will want to double click on the grey area of the action and open the PeopleCode or SQL editor. This is what defines exactly what the action does.
Loops/Logic
Complex logic is best done inside of PeopleCode steps. Note that you can have an App Engine program with a single PeopleCode step/action. The PeopleCode can do all of the work for you.
That being said, you can do some logic flow with looping and such in the App Engine itself. This is accomplished with the following action types:
- Do Select: like a for loop, loops through a set of rows
- Do While: like a while loop
- Do When: like an if statement
- Call Section: branches to another section
Next, the Do While loop will go until no rows are returned. It is similar to the Do Select except that it executes the SQL statement every iteration. The actions following it are executed when the SQL statement returns 1 or more rows. Also, note that the actions are executed once for each time the select statement is run no matter how many rows are returned.
Now, the Do When action is like an If statement. Basically, if the select statement returns a row, that’s true. If no rows result, it’s false. So, if the Do When select statement returns a row or more, it executes the action. If no rows are returned, it moves on to the next Step without running any more actions in the current step.
Finally, the Call Section action is simple: it just runs all the steps in the selected section and comes back to the next step.
State Records
Now, you have the program flow mastered, but you need to know how to pass information between the steps. The State Record is your tool. If you are familiar with COBOL, the state record is like the working storage area on a COBOL program. Or, you could say that the state record is the variables for the App Engine program.
So, to create a state record, you just need to create a new record with a name that ends with “AET”. You can create a new record the same way as you created the App Engine definition.
In your new record, you need to add at least three fields: PROCESS_INSTANCE, RUN_CNTRL_ID, and OPRID. You can use the Insert > Fields menu to add fields. The PROCESS_INSTANCE should be a key.
Next, on the record type tab, you should either select Derived/Work or you should select SQL Table. If you choose SQL Table, you will need to go through the Build process when you create and each time you change the record. If you use Derived/Work, you may loose the information in the state record when the program commits (which is no problem if the only commit you have is at the end).
Now, when you save it, make sure that you add the “AET” to the end of the name. You will not be able to select it on the State Record screen unless it is named appropriately.
Once you have the state record saved, you need to connect it to the App Engine program. To do so, open the App Engine properties and go to the State Record tab. Enter the name of the state record in the search box, click the “Get List” button, select the record in the “Record List”, and finally click the “Add” button.
Finally, we can use our state record in our program. With SQL statements, we can use two different meta-sql commands:
- %Select: loads a value selected from the database into the state record
- %Bind: places a value from the state record into a SQL statement
For example, the %Select in this statement will read the EMPLID returned by the select statement and place it in the state record. Because this is a Do Select, it will fetch each row and run the rest of the actions in the step for each row. When the action runs the first time, the EMPLID field in the state record will have the EMPLID from the first row as the actions run. The state record will have the EMPLID from row 2 as the actions run the second time, and so on.
This next example uses %Bind to pull the value from the state record and insert it into a staging table.
Also, in PeopleCode steps, you can refer to the state record with the Record.Field syntax. If you are familiar with PeopleCode on a page, you understand the buffer. The buffer for a PeopleCode program in App Engine is your state record, and you access them as if they were in the buffer.
Running/Testing
The easiest, quickest way to test your new program is to run it from Application Designer. When you have the main App Engine window active, you can click the Run button. You can also use the Edit > Run Program… menu.
This opens the Run Dialog window. You want to make sure that you select Output Log to File. If you don’t, the window will close and you won’t be able to see any of the output. I also uncheck the Run Minimized option so that I can see the window open and close more easily. Pay attention to the Log File Name because the first thing you want to do when it is done is view the output.
You will eventually want to set most programs up to run online from a Run Control. Creating a run control is outside of the scope of this post, but here are some thoughts that might help you toward that direction:
- You will need to create a page with the process scheduler sub page on it and a component containing the page.
- You will need to create a Process definition where the Process Type is application engine and the name is the same name as your program.
- You will need to enter the new component name on the Process Definition and select a Process Group that you have access to.
- When your program starts, PeopleTools will automatically populate the Process Instance, Operator ID, and Run Control ID fields for you.
- One of the first steps in your program will be to select the parameters from your run control page into your state record. You will use the Run Control ID and Operator ID that is pre-populated to get the correct values.
Adding Programs to Projects
As you create your program, you should be adding it to a project. This ensures that once you have it working, you can easily migrate it to your test environment and eventually to production. The catch is that the program has different parts that must be inserted individually. The program as a whole must be in the project. Each section must go into the project, as well as each individual SQL or PeopleCode program.
You run into problems when you miss a part. App Designer cannot migrate a child definition if the parent definition does not exist in the target. For example, you can’t migrate any sections if the parent App Engine program does not exist in your target environment. You can’t migrate a Do Select SQL statement if the section with the parent step/action does not exist in the target.
As you go, I recommend using the F7 key to insert everything your create or change as you do it. This ensures you don’t forget anything. When you create a new section, you can right click on the section and insert it into the project:
Assuming you want all of the program and its parts in your project, you can use the insert related definitions option. Remember, you only want to do this when you created the program by yourself. If you only modified some of the parts, you only want the parts in your project that you actually changed. To, use the option, press Ctrl + F7 or use the Insert > Definitions Into Project. Before you insert the program into the project, highlight all of the Related Definitions.
Where To Go From Here
Here are some other articles that I have written that might be helpful:
- Step-by-Step: App Engine for Testing PeopleCode
- PeopleTools Tip: App Engine Restart (If you forget to check Disable Restart)
Here are some other places you might want to look as well:
Very nice article..very helpful..
thanks a lot..
Explanation is good. This helps to understand and follow step by step process.
Thanks a lot,
Prasad
Very helpful …Thanks !
its nice we want some more example programs
Thanks so much for taking the time to write this up. I haven’t seen anything so clear like this even from Oracle/PeopleSoft.
Helpful content.Thank you.
I have a question in my mind for a longtime unanswered. Can some one tell me, In case of a restartable AE how will the program know to proceed from 101 th row when it fails while processing 500 rows of data. Is this possible just with a commit point and a SQL record as a state record. How exactly AE will retrieve the details of the last failed row and proceed from there. Is there something that will be helpful for this from the record PS_AERUNCONTROL.
Sreenath,
Thank you for the compliment and sorry for taking so long to respond.
The part you are missing to make the restart work is that you have to track your progress through your data. You need to add a flag to each of your 500 data rows.
Let’s say you have your 500 rows in a staging table. You would add a PROCESSED field onto the staging table and set it to “N” initially. Then, you write your Do Select to select the rows from the table only where PROCESSED = N, and set the Select Type to either Restartable or Reselect. You process row 1 by calling another section. At the end of the section, write an update statement to set the PROCESSED field on row 1 to Y. Then, you set it to commit after the section.
When your program gets to row #101, it can crash. Rows 1 – 100 will have committed and will have saved PROCESSED = Y. When your program restarts, it will start by selecting row #101 because it is the first row with PROCESSED = N.
Does that make sense? The bottom line is that to make your program restartable, you have to track your process through the data.
Could you please explain Restartable AE with screen shots
Hello!
Thank you for taking the time to explain this step by step.
:o)
I like the way you do the arrows in the images. Much easier to understand, at least to me.
Thanks.
Thanks, those are courtesy of a Linux tool called Shutter.
Thanks,
Stephen
Very very helpful step by step information.
Thank you for this step by step instruction on creating an App Engine program. It was very helpful.
Very Nice Explanation.. Good Work…
Nice.Steps are clear and understandable.
Very good explanation. Thank you very much!!!!
Do you have some more real world examples you can share?
Superb Explanation. Thank you verymuch
Awesome Explanation…Thank you so much !!
Awesome Explanation..Thank You so much !!
Awesome!!
I’m a rookie in PS and this explanation is the best i ever know.
Thank you so much!!
Very Useful.. Thanks
1.Can you give some more examples 3 tier application engine program using in PIA page
Hi Stephen,
I want to thank you for the great work you are doing in this PeopleTools Blog. I stumbled upon it as I was searching for information on building App Engine programs to help me add some new technical skills. I haven’t worked on PeopleSoft in a few years, and am hoping that reading your blog will help me refresh my skills so that I can find work again.
You have a fantastic gift for explaining highly technical concepts in a way that others can understand. Unlike PeopleBooks, your blog on App Engine tells me just what I need to know in a minimal amount of time. I encourage you to keep writing and keep working on your Jethro list because you are helping people like me.
Grateful to you,
Don
Hello, one question, I deleted some sections from an Application Engine, and when I compare Source VS Target, the system is not indluding those deleted sections ( so they can be deleted in target).
While comparing, I entered in Options’ button, ‘Compare Options’ tab, selected ‘Target Orientation’, and I chosed ‘Peoplesoft Vanilla’, but it didn’t work.
Can you help me with this please?
Thank you & Regards
Eva,
I haven’t mastered the compare options. To get around that…
– go to the “Upgrade” tab on the Project Workspace on the left
– Double click on the “Application Engine Sections” folder
– Find the section(s) that you want to delete
– Check the Action column: it should say delete (you can change it if it doesn’t)
– Check the “Upgrade” column: it should be checked
– check the “Done” column: uncheck that just to be safe
If you are copying the project from file, you will have to make the changes in your target database. Then, choose to use the project definition in the database instead of the one in the file.
If you are copying the project from database to database, you should make these changes in your source database.
Does that help?
Thanks,
Stephen
Hello,
Actually, the problem is that, since I already deleted those sections from program in Source, they do are not being shown in the “Application Engine Sections” folder, so I can not chose the ‘delete’ option in “action” column.
What I don’t understand is WHY -when I am trying to migrate the AE itself -, and it is migrated, target still keeps those sections that I deleted from Source.
I mean, the AE object should have some kind of information related its current and valid sections.
Thank you and Regards
Eva
Hello,
Awesome explanation
I have one question, can you please explain me how to run a App Engine Program from People soft Application.
Thank you very much for this information. It’s really helpful.
Hi,
It’s really helpful and more informative but the screenshots are not visible. Could you please check?
Thanks in advance!.