Feat: Add backend support for filmstrip capture

This commit is contained in:
2025-12-28 05:08:12 +11:00
parent d345694b01
commit 50dcf9b498
2 changed files with 22 additions and 5 deletions

View File

@@ -60,6 +60,7 @@ async function _executeTest(url, options) {
const { v4: uuidv4 } = await import('uuid');
const isMobile = options.isMobile ?? false; // Default to desktop (matches frontend)
const captureFilmstrip = options.captureFilmstrip ?? false;
const reportDir = path.join(__dirname, '..', 'reports');
// Ensure reports directory exists
@@ -111,7 +112,21 @@ async function _executeTest(url, options) {
},
throttlingMethod: 'provided'
},
passes: [{
passName: 'defaultPass',
recordTrace: true, // Required for filmstrip
useThrottling: true,
pauseAfterFcpMs: 0,
pauseAfterLoadMs: 0,
networkQuietThresholdMs: 0,
cpuQuietThresholdMs: 0,
gatherers: []
}]
};
if (!captureFilmstrip) {
config.settings.skipAudits = ['screenshot-thumbnails', 'final-screenshot'];
}
const runnerOptions = {
logLevel: 'info',
@@ -148,7 +163,9 @@ async function _executeTest(url, options) {
tbt: lhr.audits['total-blocking-time'].numericValue,
},
userAgent: lhr.userAgent,
isMobile: isMobile
isMobile: isMobile,
filmstrip: captureFilmstrip ? (lhr.audits['screenshot-thumbnails']?.details?.items || []) : []
};
};
// Save JSON Summary

View File

@@ -37,7 +37,7 @@ app.get("/api/git-info", (req, res) => {
// API Endpoint: Run Test (supports multi-run)
app.post("/api/run-test", async (req, res) => {
const { url, isMobile, runs = 1 } = req.body;
const { url, isMobile, runs = 1, captureFilmstrip = false } = req.body;
const userUuid = req.headers['x-user-uuid'];
const userIp = req.headers['x-forwarded-for'] || req.socket.remoteAddress;
@@ -51,7 +51,7 @@ app.post("/api/run-test", async (req, res) => {
try {
// Single run (original behavior)
if (runs === 1) {
const result = await runner.runTest(url, { isMobile, userUuid, userIp });
const result = await runner.runTest(url, { isMobile, userUuid, userIp, captureFilmstrip });
return res.json(result);
}
@@ -60,13 +60,13 @@ app.post("/api/run-test", async (req, res) => {
const suiteId = runner.generateTestId();
// Create suite record
await multiRun.createSuite(suiteId, userUuid, url, isMobile ? 'mobile' : 'desktop', runs);
await multiRun.createSuite(suiteId, userUuid, url, isMobile ? 'mobile' : 'desktop', runs, captureFilmstrip);
// Return suite ID immediately
res.json({ suiteId, runs, status: 'running' });
// Execute runs asynchronously
multiRun.executeMultipleRuns(suiteId, url, isMobile, runs, userUuid, userIp)
multiRun.executeMultipleRuns(suiteId, url, isMobile, runs, userUuid, userIp, captureFilmstrip)
.catch(error => console.error('Multi-run execution failed:', error));
} catch (error) {