Contents
This sample demonstrates how to configure and call custom Java simple functions in an EventFlow module.
This sample's file's are:
- custom-functions.sbapp
-
The sample EventFlow module file, placed in In
src/main/eventflow/com.tibco.ep.sample. - sbengine.conf
-
The important
sbenginetype configuration file that defines aliases for the Java methods we want to call, placed insrc/main/configurations. This file illustrates the use of themethodNameproperty to allow more than one alias to the same method, and illustrates the syntax forargumentTypesas well asautoArguments. - Hypoteneuse.java, VarArgs.java
-
Java files containing our example custom classes, placed in
src/main/java/com.tibco.ep.sample. Notice that the package name for these Java files is the same here as for the EventFlow module, but this is not a requirement. - TestCase.java
-
An EventFlow JUnit test file, configured and ready to run, placed in
src/test/java/com.tibco.ep.sample. Run this test by selecting this file, right-clicking, and from the context menu, selecting >. - pom.xml
-
The Maven object model file for this project, placed at the root of the project folder.
The custom-functions.sbapp EventFlow module contains three independent streams.
- Input stream TriangleSidesIn
-
The top stream illustrates four ways to calculate the hypotenuse of a right triangle, given two doubles representing the lengths of the right angle sides, plus a report on which of the two inputs is the maximum.
The module generates the output using the following expressions in a Map operator:
-
hypotenuse(x, y) -
calchyp(x, y) -
calljava('java.lang.Math', 'hypot', x, y) -
hypot(x, y) -
mx(x, y)
The first two expressions illustrate the use of two different aliases to the same method, as defined in this sample's configuration file. These are aliases for the
calculatemethod in the Hypotenuse class defined in theHypotenuse.javafile insrc/main/java. The third expression uses thecalljavaexpression language function to call thejava.lang.Math.hypotmethod directly. The fourth expression uses an alias that calls the samejava.lang.Math.hypotmethod. The final expression shows an aliasmxforjava.lang.Math.max. -
The two lower streams illustrate how custom Java functions can take variable-length arguments. The functions have aliases in the project's configuration file that enables them to be called directly (as opposed to being invoked with the calljava() expression language function). Note that a function alias can have the same name as the function it refers to, or can have a different name.
- Input stream VarArgsIn
-
The middle stream uses the custom function
IsIn, defined in classcom.tibco.ep.sample.VarArgs, to determine whether input stringneedleexists in any of the following arguments stringshaystack1...haystack, and returns a boolean result.n - Input stream VarArgsSums
-
The bottom stream uses the custom function
SumAllin theVarArgsclass to calculate the sum of any number of doubles and returns a double result.
To keep the example simple, the custom functions do not validate their inputs at runtime.
In StreamBase Studio, import this sample with the following steps:
-
From the top-level menu, click >.
-
Enter
custom simpleto narrow the list of options. -
Select the Custom Java simple function sample from the Extending StreamBase category.
-
Click .
StreamBase Studio creates a project for the sample.
-
In the Project Explorer view, open this sample's folder.
Keep an eye on the bottom right status bar of the Studio window. Make sure any
Updating,Downloading,Building, orRebuild projectmessages finish before you proceed. -
Open the
src/main/eventflow/folder.packageName -
Double-click to open the
custom-functions.sbappapplication. Make sure the application is the currently active tab in the EventFlow Editor. -
Click the
Run button. This opens the SB Test/Debug perspective and starts the module.
-
Wait for the Waiting for fragment to initialize message to clear.
-
Enter data for the
TriangleSidesInstream.-
In the Manual Input view, select the
TriangleSidesIninput stream. -
Enter the following values in the
xandyfields, then press :x: 3
y: 4 -
In the Output Streams view, observe the emitted tuple. Look for four calculated hypotenuse values that are all
5.0, plus the fieldaliasedMaxshowing4.0. -
Enter other values into the
xandyfields. The calculated hypotenuse number is identical, no matter which function is called, which which calling option.
-
-
Enter data for the
VarArgsIsInstream.-
In the Manual Input view, select the
VarArgsIsIninput stream. Notice the three input fields:needle, the string to search for, andhaystack1andhaystack2, the strings to search within. If either of the haystacks containsneedle, the output field IsNeedleInHaystack will be true, else false. -
Enter the following unquoted strings in the respective fields:
needle: banana
haystack1: time flies like an arrow
haystack2: null -
In the Output Streams view, observe the emitted tuple. The value for
IsNeedleInHaystackisfalsebecause neitherhaystack1norhaystack2contains the stringbanana. -
Now in the
haystack2field, enter:fruit flies like a banana
-
Press again.
-
This time in the Output Streams view, the emitted tuple's value for
IsNeedleInHaystackistrue. -
Experiment with adding more
haystackfields to the VarArgsIn input stream's schema. To get them included in the evaluation without changing thenIsInJava method, just append the same field names to the expression in theIsInMap operator.
-
-
Enter data for the
VarArgsSumsstream.-
In the Manual Input view, select the
VarArgsSuminput stream. It has three double fields;value1,value2, andvalue3. -
Enter the following numbers in the respective fields:
value1: 10.
value2: 24.6.
value3: 365.2 -
In the Output Streams view, in the emitted tuple, look for the value of the field
sumto be399.8. -
Stop the application by pressing F9 or click the
Terminate EventFlow Fragment button.
-
With
custom-functions.sbappselected in the EventFlow Editor, select the input streamVarArgsSums. Add one more field to the input schema:value4, typedouble. -
Select the SumAll Map operator. In the Output Settings tab, change the expression to
sumAll(value1,value2,value3,value4), save the application, and run it again. -
In the Manual Input view, enter the following numbers in the respective fields:
value1: 10.
value2: 24.6
value3: 365.2
value4: 0.2 -
Press again.
-
In the Output Streams view, notice that emitted tuple's field
sumis now410.0.Because the Java function
sumAll()takes a variable list of arguments, you can add any number of double fields to the input schema and reference them in thesumoutput expression without having to edit the Java source file.
-
-
When done, press F9 or click the
Terminate EventFlow Fragment button.
When you load the sample into StreamBase® Studio, Studio copies the sample project's files to your Studio workspace, which is normally part of your home directory, with full access rights.
Important
Load this sample in StreamBase® Studio, and thereafter use the Studio workspace copy of the sample to run and test it, even when running from the command prompt.
Using the workspace copy of the sample avoids permission problems. The default workspace location for this sample is:
studio-workspace/sample_custom-java-functionSee Default Installation Directories for the default location of studio-workspace on your system.
