87 lines
2.4 KiB
Nix
87 lines
2.4 KiB
Nix
import ./make-test-python.nix (
|
|
{ pkgs, ... }:
|
|
let
|
|
port = 4318;
|
|
in
|
|
{
|
|
name = "opentelemetry-collector";
|
|
meta = with pkgs.lib.maintainers; {
|
|
maintainers = [ tylerjl ];
|
|
};
|
|
|
|
nodes.machine =
|
|
{ ... }:
|
|
{
|
|
networking.firewall.allowedTCPPorts = [ port ];
|
|
services.opentelemetry-collector = {
|
|
enable = true;
|
|
settings = {
|
|
exporters.logging.verbosity = "detailed";
|
|
receivers.otlp.protocols = {
|
|
http.endpoint = "0.0.0.0:${toString port}";
|
|
};
|
|
service = {
|
|
pipelines.logs = {
|
|
receivers = [ "otlp" ];
|
|
exporters = [ "logging" ];
|
|
};
|
|
};
|
|
};
|
|
};
|
|
virtualisation.forwardPorts = [
|
|
{
|
|
host.port = port;
|
|
guest.port = port;
|
|
}
|
|
];
|
|
};
|
|
|
|
extraPythonPackages = p: [
|
|
p.requests
|
|
p.types-requests
|
|
];
|
|
|
|
# Send a log event through the OTLP pipeline and check for its
|
|
# presence in the collector logs.
|
|
testScript = # python
|
|
''
|
|
import requests
|
|
import time
|
|
|
|
from uuid import uuid4
|
|
|
|
flag = str(uuid4())
|
|
|
|
machine.wait_for_unit("opentelemetry-collector.service")
|
|
machine.wait_for_open_port(${toString port})
|
|
|
|
event = {
|
|
"resourceLogs": [
|
|
{
|
|
"resource": {"attributes": []},
|
|
"scopeLogs": [
|
|
{
|
|
"logRecords": [
|
|
{
|
|
"timeUnixNano": str(time.time_ns()),
|
|
"severityNumber": 9,
|
|
"severityText": "Info",
|
|
"name": "logTest",
|
|
"body": {
|
|
"stringValue": flag
|
|
},
|
|
"attributes": []
|
|
},
|
|
]
|
|
}
|
|
]
|
|
}
|
|
]
|
|
}
|
|
|
|
response = requests.post("http://localhost:${toString port}/v1/logs", json=event)
|
|
assert response.status_code == 200
|
|
assert flag in machine.execute("journalctl -u opentelemetry-collector")[-1]
|
|
'';
|
|
}
|
|
)
|