mirror of
https://github.com/ruvnet/RuView
synced 2026-06-09 10:13:17 +00:00
b116a99481
Raises the Nexmon path from a normalized record format to parsing what the patched Broadcom firmware actually emits, end to end. napi-c shim (ABI 1.0 -> 1.1, additive): - rvcsi_nx_csi_udp_header / rvcsi_nx_csi_udp_decode — parse the real nexmon_csi UDP payload: the 18-byte header (magic 0x1111, rssi int8, fctl, src_mac[6], seq_cnt, core/spatial-stream, Broadcom chanspec, chip_ver) + nsub complex CSI samples (modern int16 LE I/Q export — what CSIKit/csireader.py read for the BCM43455c0 / 4358 / 4366c0; nsub = (len-18)/4). rvcsi_nx_csi_udp_write to synthesize payloads for tests. rvcsi_nx_decode_chanspec — d11ac chanspec -> channel (chanspec & 0xff) / bandwidth (bits [13:11], cross-checked against the FFT size) / band (bits [15:14], cross-checked against the channel number). Still allocation-free, bounds-checked, structured errors, never panics. - ffi.rs wraps it: decode_chanspec / parse_nexmon_udp_header / decode_nexmon_udp / encode_nexmon_udp + DecodedChanspec / NexmonCsiHeader; every unsafe block documented; the ABI guard now expects 1.1. rvcsi-adapter-nexmon: - pcap.rs — a dependency-free classic-libpcap reader (all four byte-order / timestamp-resolution magics; Ethernet / raw-IPv4 / Linux-SLL link types; tolerates a truncated final record; pcapng is a follow-up) + extract_udp_payload + a synthetic_udp_pcap / synthetic_nexmon_pcap test/example generator. - NexmonPcapAdapter (a CsiSource) — reads the CSI UDP packets out of a `tcpdump -i wlan0 dst port 5500 -w csi.pcap` capture, decodes each via the C shim, stamps the frame timestamp from the pcap packet time; non-CSI packets counted as "skipped" in health. rvcsi-runtime: decode_nexmon_pcap, summarize_nexmon_pcap (+ NexmonPcapSummary: link type, CSI frame count, channels, bandwidths, subcarrier counts, chip versions, RSSI range, time span), CaptureRuntime::open_nexmon_pcap[_bytes]. rvcsi-node (napi-rs): nexmonDecodePcap, inspectNexmonPcap, decodeChanspec, RvcsiRuntime.openNexmonPcap. @ruv/rvcsi SDK + .d.ts updated (NexmonPcapSummary, DecodedChanspec). rvcsi-cli: `record --source nexmon-pcap`, `inspect-nexmon`, `decode-chanspec`. 161 rvcsi tests pass (adapter-nexmon 9->22), 0 failures, clippy-clean. ADR-096 §2.2/§2.3/§5, CHANGELOG, CLAUDE.md updated. https://claude.ai/code/session_01CdYAPvRTjcch6YrYf42n1z
46 lines
1.5 KiB
JavaScript
46 lines
1.5 KiB
JavaScript
'use strict';
|
|
|
|
// Structural smoke test for the @ruv/rvcsi JS surface.
|
|
//
|
|
// Importing the package never throws (the native addon loads lazily). This test
|
|
// asserts the public API shape; if the .node addon HAS been built (e.g. CI ran
|
|
// `npm run build` first), it also checks `rvcsiVersion()` returns a string —
|
|
// otherwise it asserts the error message is the helpful "not built" one.
|
|
//
|
|
// Run with: node --test (Node >= 18)
|
|
|
|
const test = require('node:test');
|
|
const assert = require('node:assert/strict');
|
|
const rvcsi = require('../index.js');
|
|
|
|
test('exports the expected functions and class', () => {
|
|
for (const fn of [
|
|
'rvcsiVersion',
|
|
'nexmonShimAbiVersion',
|
|
'nexmonDecodeRecords',
|
|
'nexmonDecodePcap',
|
|
'inspectNexmonPcap',
|
|
'decodeChanspec',
|
|
'inspectCaptureFile',
|
|
'eventsFromCaptureFile',
|
|
'exportCaptureToRfMemory',
|
|
]) {
|
|
assert.equal(typeof rvcsi[fn], 'function', `${fn} should be a function`);
|
|
}
|
|
assert.equal(typeof rvcsi.RvCsi, 'function', 'RvCsi should be a class');
|
|
assert.equal(typeof rvcsi.RvCsi.openCaptureFile, 'function');
|
|
assert.equal(typeof rvcsi.RvCsi.openNexmonFile, 'function');
|
|
assert.equal(typeof rvcsi.RvCsi.openNexmonPcap, 'function');
|
|
});
|
|
|
|
test('native calls either work (addon built) or fail with a helpful message', () => {
|
|
try {
|
|
const v = rvcsi.rvcsiVersion();
|
|
assert.equal(typeof v, 'string');
|
|
assert.match(v, /^\d+\.\d+\.\d+/);
|
|
assert.equal(typeof rvcsi.nexmonShimAbiVersion(), 'number');
|
|
} catch (e) {
|
|
assert.match(e.message, /native addon is not built/i);
|
|
}
|
|
});
|