Skip to main content

Notice: this Wiki will be going read only early in 2024 and edits will no longer be possible. Please see: https://gitlab.eclipse.org/eclipsefdn/helpdesk/-/wikis/Wiki-shutdown-plan for the plan.

Jump to: navigation, search

EDT:v07 green threads

Revision as of 15:11, 13 September 2011 by Jqian.us.ibm.com (Talk | contribs)

Last update: 2011/9/7, run in 0.7.0.v201109061723, By Rocky

Overview

Note: By default, I use the P2 installable build to test the green thread. However, if the defects marked with * mean tested by development workspace.

Capability
Status
Defects
EUnit test framework


Create EGL web client with service project.
Successful

Create RUI handler and the default handler created by the wizard can be opened successfully by VE.
Successful

The button, input box & grid can be drag/drop in VE.
Blocked
MAJOR: Bug 356429 - The children widgets which are defined after their container can not be displayed - Scott
MAJOR: Still have lots of widget do not work, probably in JS generation etc. Forest will perform a full test to open the relevant defects. - Forest/Jiyong

MIDDLE: Bug 356039 - VE prints 'document.write("could not open %handler_name%");' when opening the RUI handlers - Forest

The properties, outline, data view etc can be used.
Failed
The block issues were just removed for 'EGL Data' view, Forest & Jiyong will do detailed FVT before attempting to test the data view green thread.
Create interface, service part & set binding information in the dd file.
Successful


Run service call in preview mode.
Blocked
The code is still in IBM CVS, not checked in Eclipse yet.- Justin
Debug RUI handler & service (step over & into etc)
Blocked
The code is still in IBM CVS, not checked in Eclipse yet.- Justin
Deploy the RUI handler to the Tomcat
Successful

Deploy the service to the Tomcat
Successful
Minor: Bug 356141 - The contents of web.xml is not correct if no RUIHandler is configured in the DD file - Jimmy
Run the application
Successful

The service call with database
Blocked
Function is not ready for testing - Tony/Zhi


Green thread scenario

0. Create an EGL basic project (myProj)

   1. create a library (myLib) under a package (a), copy the following content

package a;
// basic library

library myLib



// Function Declarations function functionName() {@Test} LogResult.assertTrue("test fail", false); end


function functionName1() {@Test} LogResult.assertTrue("test success", true); end


end

  2. Right click on the project you just created, Choose Generate EGL Test Driver => Java to create the java test driver

  3. Right click on the project you just created, Choose Generate EGL Test Driver => JavaScript to create the java script test driver.

  4. Execute java test driver, go to project myProj.eunit.java => folder generatedJava => Run eunitgen.RunAllTests_pgm as Java application.

  5. Refresh project myProj.eunit.java, you should see a new folder  "ResultRoot", expand its subfolder (name is in current timestamp yyyymmdd_hhmmss), till you see file "ResultSummary.trs", double click to open this file. 

     You should see one successful and one failed results

  6. Execute javascript test driver in preview pane, go to project myProj.eunit.javascript => EGLSource => eunitgen.RunAllTests_rui.egl, open in EGL Rich UI editor's preview pane, execute it

  7. Refresh project myProj.eunit.javascript, you should see a new folder "ResultRoot", expand its subfolder (name is in current timestamp yyyymmdd_hhmmss), till you see file "ResultSummary.trs", double click to open this file.

     You should see one successful and one failed results.

  8 Execute javascript test driver in deployed application. go to project myProj.eunit.javascript => EGLSource => deploye myProj.eunit.javascript.egldd file

1. Create EGL web client with service project

   1. Create an EGL Project
   2. type base package "org.eclipse.edt.greenthread.helloworld"
   3. Select "Web Client With Service Project" as the project template
   4. Add "Dojo Widget" (dojotoolkit.org) and RUI UI widgets (0.7.0) into the RUI widget libraries list
   5. Press "Finish"
   6. There should be a directory whose structure as follows
    [base package name].client (configured for JavaScript gen)
    [base package name].server (configured for Java gen)
    [base package name].common (configured for both JavaScript and Java gen)"

2. Create RUI handler and the default handler created by the wizard can be opened successfully by VE

   1. User enters name and package for a new RUIHandler.
   2. System creates the EGL part and then opens it in the Rich UI Editor
   3. Switch to Design, Source and preview tab to check if editor shows the proper content

3. The button, input box & grid can be drag/drop in VE

   1. Drag a Button in the grid layout from palette, Set the text to "Call Service" in properties view
   2. Use the EGL Source editor to instantiate a Dialog whose children include a Box named "content".
   3. Drag an input box and set the properties

4. The properties, outline, data view etc can be used

   1. In properties view, add a click event process function for the button we created above.
   2. Show the dialog in the click event function above.
   3. Check outline and preview view

5. Create service part & set binding information in the dd file.

   1. Create an interface
   2. Create a new service and implement the interface created in previous step, specifying package and part name.
   3. Use the EGL editor to implement a function that returns a string by concatenating Hello, to whatever is passed in.
   4. Extract EGL Service interface
   5. Add a service client binding in egl dd file

6. Run service call in preview mode.

   1. Open RUI handler, in the event handler function (created above), use code completion to instantiate the service.
   2. Use EGL's call statement to invoke the service, specifying that it returns to a callback function that does not yet exist.
   3. Use the EGL Editor's Quick Fix to automatically define the callback function.
   4. Implement the callback function to instantiate a textfield containing the service result and programmatically add it to the children of the dialog's UI (which again is a Box named content)
   5. switch back to preview tab to exercise a running instance of their UI.

7. Debug RUI handler & service (step over) & (step into) etc.

   1. In the EGL Editor, the User sets breakpoints on both the service invocation as well as the function that implements the service.
   2. From the preview pane, the user hits the Debug button to launch the UI in an external instance of their system browser.
   3. exercise Step into/step return/step over feature
   4. exercise resume/suspend/terminate feature
   5. verify the debug call stack tree, variables, breakpoints and expression view for the above debug operation

8. Deploy the RUI handler/service to the Tomcat

   1. User right clicks on the egl dd file and chooses "Deploy".
   2. System responds that there is no target (project), and prompts user to create one. From the deployment descriptor, the user specifies the target project by creating a new Dynamic Web Project and chooses Tomcat 6.0 as their target runtime.
   3. User clicks on the Deploy button in the descriptor to deploy the project to the target Dynamic Web Project.

9. Run the application

   1. User right-clicks on the UI HTML file that was generated in the target project, and chooses Run as... Run on Server.
   2. System gives the user a choice of web servers on which to run, and then publishes to that server and launches the HTML in a browser.


Back to the top