|Project Name||Stars||Downloads||Repos Using This||Packages Using This||Most Recent Commit||Total Releases||Latest Release||Open Issues||License||Language|
|Bout Dev||136||6 days ago||227||lgpl-3.0||C++|
|BOUT++: Plasma fluid finite-difference simulation code in curvilinear coordinate systems|
|Tracing Selenium Grid||33||3 months ago||2||apache-2.0||Shell|
|A simple project to showcase Selenium 4's Tracing capability using Jaeger client with Selenium Grid|
|Hagrid||32||5 years ago||mit||C++|
|Implementation of the paper: `GPU Ray Tracing using Irregular Grids`|
|Vulkano Raytracing||22||5 years ago||1||mit||Rust|
|Realtime GPU raytracer created with Vulkano.|
|Win32 Ray Tracing Demo||3||8 years ago||C++|
|A demonstration program for ray tracing|
|Voxelraytracers.jl||3||a year ago||2||mit||Julia|
|CPU ray tracing through voxelized geometry|
TL;DR: A simple project to showcase Selenium 4's Tracing capability using OpenTelemetry APIs(Jaeger) with Selenium Grid.
It is a measure of how well internal states of a system can be inferred from knowledge of its external outputs. It helps bring visibility into systems. – Wikipedia
Tracing is one of the important pillars for measuring observability along with logs and metrics. Its a way of thinking about the system, a way of being able to ask the system questions, that you need the answer to when you didn't know the questions beforehand. On the other hand, alerting is a way of asking questions when you do know the question beforehand.
Distributed Tracing can be quite helpful in answering questions for your distibuted system like,
It has number of new exciting features and one such is a cleaner code for Selenium Grid along with support for distributed tracing via OpenTelemetry APIs. This is pretty exciting and important feature for the admins and devops engineers to trace the flow of control through the Grid for each and every command.
Distributed tracing has two parts:
Code instrumentation: Adding instrumentation code in your application to produce traces. The major instrumentation parts are done neatly by the developers of Selenium project, which leaves us to consume it by using Selenium Grid start-up command along with Jaeger.
Collection of data and providing meaning over it, Jaeger has a UI which allows us to view traces visually well.
Steps to start tracing your tests,
Start Jaeger via docker(as its easy)
Instrument your Selenium Grid start-up command with Jaeger tracing as in start-grid-distributed.sh and start-grid-standalone.sh for standalone mode.
Now execute your tests tests, and navigate to
http://localhost:16686/ to view the outputs.
Assuming you have docker running on your machine,
brew install coursier/formulas/coursier
The simplest way to start the all-in-one is to use the pre-built image published to DockerHub (a single command line).
$ docker run --rm -it --name jaeger \ -p 16686:16686 \ -p 14250:14250 \ jaegertracing/all-in-one:1.17
You can then navigate to http://localhost:16686 to access the Jaeger UI.
We're going to add support for Open Telemetry API's(one of the many ways to do distributed tracing) using Coursier to generate a full classpath, when started this way the selenium server will inform you that it has found a tracer on stdout.
Refer start-grid-distributed.sh if you want to start Grid in distributed mode.
curl http://localhost:4444/status to check if your grid deployment is ready
Point your tests as in DistributedTracingExamples Class and navigate to http://localhost:16686/ to view the outputs.
Under services look up for Selenium-router and notices actions for each calls made by your tests. An example below
A special thanks to ever helpful Simon Stewart for being patience in answering my dumb questions.