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

Difference between revisions of "EDT:v07 green threads"

Line 92: Line 92:
  
 
|-
 
|-
| bgcolor="#cccccc" | 12. The service call with database<br>  
+
| bgcolor="#ffffff" | 12. The service call with database<br>  
| bgcolor="#cccccc" | Blocked<br>  
+
| bgcolor="#ff0066" | Blocked<br>  
| bgcolor="#cccccc" | <br>  
+
| bgcolor="#ffffff" | <br>  
| bgcolor="#cccccc" | Function is not ready for testing - Tony/Zhi<br>
+
| bgcolor="#ffffff" |  
 +
The SQL function is still under development,I need do a couple of workarounds to make a very simple scenario work fine.
 +
 
 +
I'm not sure if the function is ready for test or not.
 +
 
 +
The simple scenario is:
 +
 
 +
#Define a SQL resource Derby binding in the workspace
 +
#Define a service and try to get one string field from db, and return to client.
 +
#Create an RUIHandler &amp; display it in a text field.
 +
 
 
|}
 
|}
  

Revision as of 03:36, 22 September 2011

Italic textLast update: 2011/9/22, run in 0.7.0.v201109212102, By Rocky

Overview

Note: By default, I use the P2 installable build to test the green thread.

Capability
Status
Development Owner Defects

0. Run EUnit test framework

Failed in java script

FAILED

Bug 357577 - EUnit test framework can NOT run in javascript preview pane or deployed mode
Bug 358321 - Record => XML conversion in javascript is not producing the right results

1. Create EGL web client with service project.
Successful


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


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

Bug 358171 - The VE cannot reflect the changes if without saving changes

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

etc...

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

Lots of issues
5. Create interface, service part & set binding information in the dd file.
Successful


6. Run service call in preview mode.
Successful


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

The breakpoint cannot be hit in the preview tab of RUIHandler, not sure if the debug function is available in nightly build or not.
8. Deploy the RUI handler to the Tomcat
Successful


9. Deploy the service to the Tomcat
Successful


10. Run the application
Successful


11. RUI Technical sample runs in preview and deployed mode
(org.eclipse.edt.rui.samples_0.7.0 in the kan-cvs repository)
Blocked

Working Samples (Preview Mode, possibly with modifications for the defects listed below):

  • HelloWorld
    * RSSDemo

Defects:
* RSSDemo.egl - 356514, 357992, 357247
* Board - 357977
* HorizontalBarChart, PieChart, VerticalBarChart - 357979
* DataDisplayDemo/DataGridSelector - 357982
* EventDemo - 357986
* TicTacToe - 357974
* ServiceDemo, Welcome, AdvancedTopics - 358029

Issues:
* RUIPropertiesLib is not supported yet, so many strings are missing from the samples
* Defect 357093 requires the use of a temporary .egldd file named 'workaround.egldd'
* The Rich UI Visual Editor did not reliably render HelloWorld and RSSDemo in the Design or Preview tabs (no defects have been opened)

12. The service call with database
Blocked

The SQL function is still under development,I need do a couple of workarounds to make a very simple scenario work fine.

I'm not sure if the function is ready for test or not.

The simple scenario is:

  1. Define a SQL resource Derby binding in the workspace
  2. Define a service and try to get one string field from db, and return to client.
  3. Create an RUIHandler & display it in a text field.


Green thread scenario

0. Run EUnit test framework

  • For Java (when generating test driver for Java fails)

check out the EDT project from eclipse cvs org.eclipse.edt   tests/smoketest.eunit.java

Execute the RunAllTest_pgm.egl as Java Main application.

Refresh project "smoketest.eunit.java", you should see a folder ResultRoot, double click to open ResultSummary.trs (should by default open with Test Result Viewer)

select the root node, you should see 2 out of 4 passed, 2 out of 4 failed.

  • Testing Generating test driver for Java and JavaScript

   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.

11. RUI Technical sample runs in preview and deployed mode

   1. import the RUI technical sample from IBM CVS repository "org.eclipse.edt.rui.samples_0.7.0"

   2. view the RUIHandler in preview mode successfully

   3. deploy the application

   4. run the deployed application

Back to the top