Test a Pipeline
3 minute read
Overview
In this tutorial you will test a Pipeline containing a route node processor using the test bench you created. You will configure the route node to send all logs from a particular service to the Edge Delta Archive. All other logs will be sent to a local storage output.
Prerequisites
Before starting this tutorial, complete the steps in Tutorial 1: Create a Test Bench.
1. Create Route Node
- In the Edge Delta App, click Pipelines.
- Select the
testbench
Fleet and click View/Edit Pipeline. - Click Edit Mode.
- Click Add Processor, expand Filters and select Route.
- Specify a Name for the node
route_test
. - Click Add New in the Paths section.
- Enter
PaymentService_Path
in the Path field. - Specify the following CEL macro in the Condition field:
regex_match(item["body"], "PaymentService")
- Click Okay.
2. Connect the Route Node.
- Connect file_input_test to the input of the route_test node.
- Connect the PaymentService_Path output path on the route_test node to the ed_archive node.
- Click the link between the file_input_test node and the ed_archive node and click Delete.
- Click Review Changes.
- Click Save Changes.
3. Test the Pipeline
The pipeline currently pipes logs tailed from the input file through the route node to the ed_archive node. Test this functionality by dropping a log into the input file.
- In a terminal, navigate to the local mapped volume of the input file, such as
/Users/path/testbench/inputlogs
. You configured this location when you created a cluster definition in Tutorial 1: Create a Test Bench. - Echo the following test messages into the file:
echo "{"timestamp": "2024-01-25T17:12:04.873419Z", "logLevel": "TRACE", "service": "PaymentService", "records": [{"data": {"user": "user650", "action": "data_fetch", "details": "Leaving method calculateShippingCost after 15ms, returning value $5.99"}}], "additionalInfo": {"sessionID": "2eaed606-933e-4373-9c67-2427aa3d3bd3", "transactionID": "trx346828"}}
" >> testbench_input_file.log
echo "{"timestamp": "2024-01-25T12:22:27.947573Z", "logLevel": "INFO", "serviceName": "AuthService", "message": "The user has logged in successfully.", "username": "Raider293", "event": "user_logged_in", "outcome": "success"}" >> testbench_input_file.log
This appends the logs one at a time to the file input.
- View the
testbench_input_file.log
file.
cat testbench_input_file.log
- After a few minutes, click Logs in the Edge Delta app.
Log search will open and it will show the most recent logs saved to the ed_archive. You may need to filter on your pipeline testbench
in the Filters pane if you have more than one agent running. You should see the first log but not the second one because it did not contain PaymentService
in the body, so it was not routed on the PaymentService_Path
path to ed_archive
. If the first log isn’t visible, wait a minute then click the Refresh button to see if it has been ingested and indexed in the archive.
The second log that didn’t match was sent to the unmatched path of the route node, which is not connected to any output so it is dropped. In the next tutorial you will see how to handle nodes’ unmatched or failure paths by routing them to their own destination.