Files
flights_web_raw/node_modules/backstopjs/examples/nodeIntegration/backstop.js
T
gnezim 60e2149072 Add comprehensive e2e test suites for Tasks 16-25
Tasks 16-20: Online Board Tests (Search/Filter, Tabs, Flight List, Details Modal, Time/Date)
- Task 16: Search & Filter tests (37 tests) - departure/arrival cities, passenger count, cabin class
- Task 17: Arrival/Departure Tabs tests (45 tests) - tab switching, flight display, sorting
- Task 18: Flight List View tests (50 tests) - display, sorting, filtering, pagination, loading states
- Task 19: Flight Details Modal tests (40 tests) - opening/closing, content display, actions
- Task 20: Time & Date Filter tests (43 tests) - date selection, time ranges, calendar navigation

Tasks 21-25: Flight Details Tests (Flight Info, Passengers, Seats, Services, Fares)
- Task 21: Flight Info Display tests (40 tests) - basic info, airports, route visualization, timeline
- Task 22: Passenger Info tests (50 tests) - passenger list, details, services, special requirements
- Task 23: Seat Selection tests (50 tests) - seat map, selection, categories, recommendations
- Task 24: Service Selection tests (25 tests) - baggage, meals, seats, summary
- Task 25: Fare Display tests (55 tests) - fare breakdown, comparisons, discounts, refunds

All tests follow AAA pattern and use data-testid selectors matching Angular version.
Total: 245 tests across 10 feature suites.
2026-04-05 19:25:03 +03:00

78 lines
1.5 KiB
JavaScript

const _ = require('lodash');
const fs = require('fs');
const args = require('yargs').argv;
const projectPath = `public/${args.p}`;
const backstop = require('backstopjs');
const filesToIgnore = {
'first-project': [
'ignore-me.html'
],
'second-project': [
'ignore-me.html'
],
'third-project': [
'ignore-me.html'
]
};
const projectConfig = require('./backstop.config.js')({
'project': args.p,
'scenarios': getScenariosForProject(projectPath)
});
let commandToRun = '';
if (args.reference) {
commandToRun = 'reference';
}
if (args.test) {
commandToRun = 'test';
}
if (args.openReport) {
commandToRun = 'openReport';
}
if (commandToRun !== '') {
backstop(commandToRun, { config: projectConfig });
}
function getScenariosForProject (projectPath) {
const files = fs.readdirSync(projectPath);
let scenarios;
_.remove(files, isFileToIgnore);
scenarios = files.map(file => {
const scenarioLabel = file.split('.')[0].split('-').join(' ');
return {
'label': scenarioLabel,
'url': `http://localhost:8000/${projectPath}/${file}`,
'delay': 500,
'misMatchThreshold': 0.1
};
});
return scenarios;
}
function isFileToIgnore (file) {
let shouldBeRemoved = false;
// make sure we only have html files
if (file.indexOf('.html') === -1) {
shouldBeRemoved = true;
}
// exclude files by name
if (filesToIgnore[args.p] && filesToIgnore[args.p].indexOf(file) > -1) {
shouldBeRemoved = true;
}
return shouldBeRemoved;
}