zeek/testing/btest/spicy/packet-analyzer.zeek
Patrick Kelley 8fd444092b initial
2025-05-07 15:35:15 -04:00

46 lines
1.2 KiB
Plaintext

# @TEST-REQUIRES: have-spicy
#
# @TEST-EXEC: spicyz -d -o test.hlto spicy/raw-layer.pcap.spicy spicy/raw-layer.pcap.evt
# @TEST-EXEC: zeek -r ${TRACES}/spicy/raw-layer.pcap test.hlto %INPUT >output
# @TEST-EXEC: btest-diff output
# @TEST-EXEC: btest-diff weird.log
module PacketAnalyzer::SPICY_RAWLAYER;
event zeek_init()
{
PacketAnalyzer::register_packet_analyzer(PacketAnalyzer::ANALYZER_ETHERNET, 0x88b5, PacketAnalyzer::ANALYZER_SPICY_RAWLAYER);
if ( ! PacketAnalyzer::try_register_packet_analyzer_by_name("spicy_RawLayer", 0x4950, "IP") )
print "cannot register IP analyzer";
}
event raw::data(p: raw_pkt_hdr, data: string)
{
print fmt("MACs: src=%s dst=%s", p$l2$src, p$l2$dst);
print "raw data", data;
}
# @TEST-START-FILE spicy/raw-layer.pcap.spicy
module RawLayer;
import zeek;
public type Packet = unit {
data: bytes &size=19;
protocol: uint16;
on %done {
zeek::forward_packet(self.protocol);
zeek::weird("test_weird");
}
};
# @TEST-END-FILE
# @TEST-START-FILE spicy/raw-layer.pcap.evt
packet analyzer spicy::RawLayer:
parse with RawLayer::Packet;
on RawLayer::Packet::data -> event raw::data($packet, self.data);
# @TEST-END-FILE