mirror of
https://github.com/zeek/zeek.git
synced 2025-10-02 06:38:20 +00:00

This patch changes invocations of `spicyz` and similar Spicy tools in tests which perform compilation to use debug mode via passing `-d`. This in turn leads to Spicy compiling generated C++ code in debug as opposed to release mode which typically seems to require less CPU time and RAM. For a local test running with `btest -j 16` and no caching via `HILTI_CXX_COMPILER_LAUNCER` this sped up running of BTests under `spicy/` by about 40s on my machine (120s vs 160s).
45 lines
1.2 KiB
Text
45 lines
1.2 KiB
Text
# @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
|