On the SOA-training I’m following we’re using the Oracle SOA Suite, a very nice product, but the time needed between saving changes and deploying the process takes way too long. I also want to know exactly what’s happening and have control over the external web services. In this blog I will show you how you to deploy a process on ODE and how to use SoapUI to test a BPEL process.
Together with some colleagues we’re slowly becoming SOA-experts, we’re almost half way the SOA training and we learned a lot. Creating and deploying BPEL processes with JDeveloper is quite easy and the diagrams alone are a reason to learn BPEL 😉
I do however have the feeling I’m not really knowing what’s happening. I want to know which files are needed for a BPEL process and have more control over the input and output. Of course I can ask the instructors which files are needed and what each file does, but it’s more educational to find out yourself.
What I needed was a simple BPEL virtual machine. My only requirements were that it had to work within a few minutes, has proper documentation and work on Tomcat. A search for BPEL engine on google gave quite some results. I picked Apache ODE because that was the easiest to pronouce. After reading the documentation and deploying the HelloWorld process it fulfilled all my requirements.
You probably think this is a strange way to pick software, but what I’m about to do will never run in a production environment and is only needed to help me develop quicker and learn more about BPEL.
Running ODE inside Tomcat
The first step is downloading ODE and deploy the war on Tomcat.
Dowload ODE here. Unzip the zip file and you will find ode.war inside the first directory. Copy this file to your Tomcat webapps directory (while Tomcat is running) and watch the log file, you should see that the BPEL Server and ODE Service are both started. Now visit http://localhost:8080/ode/ in your browser and you should see the start page:
It might be a bit strange that you see Axis 2 and not ODE, but this is ok, Axis 2 is also something with WSDL’s 😉
BPEL processes will be listed under Services. Right now there are some admin serivces, we want to add an Hello World example.
Deploying the Hello World example
The ODE zip file ships with some examples. Of course we start with the Hello World sample. You can find this sample in the examples\HelloWorld2 directory. The testRequest.soap file is used with a command line utility to test the process. We will skip this utility because there is an easier way to test.
The deploy.xml describes how the partner link in the .bpel file is connected to the service in the .wsdl file.
HelloWorld2.bpel is the actual process. It takes an input variable and outputs it suffixed with World. The .wsdl file describes the input and output message for the process (a BPEL process is invoked just like a web service)
In a diagram this is the process:
Now that you have a basic understanding of the process it is time to deploy it. Copy the HelloWorld2 directory to the webapps\ode\WEB-INF\processes directory of your running Tomcat instance. Deploying a process takes a few seconds so you can immediately see the result on http://localhost:8080/ode/. Click on services and you should see a helloWorld process.
Righ click the helloWorld link and copy the url, you need this url to test the process.
SoapUI
Since a BPEL process publishes a WSDL it is easy to connect to the process. On JavaPolis I was quite impressed by SoapUI. It’s a tool for web service testing. You can give it a WSDL and it will generate an XML message which you can send to the endpoint of the WSDL. Of course the XML answer can also be reviewed.
SoapUI can be downloaded or started via Java Web Start
Click on the File menu, New WSDL Project and paste the url at the Initial WSDL text field. Give your project a useful name and click ok
After the wsdl is finished loading you see a tree. Expand the branches helloWorldSOAP12Binding and hello and double click on Request 1. soapUI now generates a request to the webservice (your Hello World process). This request is the same as the testRequest.soap we skipped earlier. You can change the details of the request. Let’s change the contents of the TestPart tag. Enter Hello instead of a question mark. Now hit the green play button to invoke the process.
The result will appear in the right pane:
<soapenv:Envelope
xmlns:soapenv="http://www.w3.org/2003/05/soap-envelope">
<soapenv:Body>
<axis2ns2:helloResponse
xmlns:axis2ns2="http://ode/bpel/unit-test.wsdl">
<TestPart
xmlns:soap="http://www.w3.org/2003/05/soap-envelope"
xmlns:unit="http://ode/bpel/unit-test.wsdl">Hello World</TestPart>
</axis2ns2:helloResponse>
</soapenv:Body>
</soapenv:Envelope>
Conclusion
Of course this example is pretty basic, but it shows you how easy it can be to deploy and test a BPEL process.
I also tried to get my BPEL processes created with JDeveloper running inside ODE, but that wasn’t as easy as I thought. There were some challenges with name spaces and older versions of the WSDL files. I spent a lot of time analyzing the .wsdl and .bpel files to find out what went wrong. So far no results, but I learned a lot about .wsdl and .bpel. I haven’t given up on it yet, I just need a break 😉 When I found out how to do it I will write an article on this weblog about it.
With soapUI it is also possible to create test cases with asserts in it, this way you can automate the testing of your BPEL processes.
Apache ODE is a nice tool to work with. Earlier I mentioned that I’m not going to use it in a production environment, but maybe it’s mature enough to run in a production environment, I haven’t looked into that.
Hello, i followed the tutorial but i think that the Soapui can’t be used to test asynchronous processes. How can i test asynchronous processes in ODE?
thanks
Yes, I have problems getting it to work. I have a Geronimo server pre-packaged with ODE and other components.SoapUI does not have to be integrated inside Geronimo, right?
I think that should work fine, do you have problems getting it to work?
Hi
I found the tutorial informative. However I would like to know if I can use SoapUI on ODE deployed in Geronimo.
thanks.
Sounds good Matthieu! Some easy tools for ODE is something that was missing, there is of course the Java API, but that probably takes a lot of effort.
ODE stands for “Orchestration Director Engine”, I just addedf a link to the ODE website where you can find that information and the great manuals that explain more than just how to use ODE.
Of course I can give a demo on an upcoming training.
Jeroen, very interesting article. I was not aware of ODE (what does it stand for by the way?) and it seems useful enough to pay some attention to. And of course I think it’s great you are taking this much trouble getting to the heart of BPEL – what is going on behind the scenes. Perhaps during one of the next SOA Training sessions you can give us a quick demo of what you found out about ODE and SOAP UI.
best regards, Lucas
Hi Jeroen,
Very nice article on ODE, thanks a lot for sharing it. For your production needs, there are many users and companies that run with ODE on production and it’s fairly mature, so that shouldn’t be a problem. You may also want to contact Intalio, we have a full BPMS based on ODE with simple design, runtime and reporting tools that you will probably like. And Intalio does support too, which is usually important when you consider production.
Cheers!
Matthieu