60e2149072
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.
57 lines
2.0 KiB
JavaScript
57 lines
2.0 KiB
JavaScript
"use strict";
|
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
};
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
exports.file = void 0;
|
|
const debug_1 = __importDefault(require("debug"));
|
|
const fs_1 = require("fs");
|
|
const notfound_1 = __importDefault(require("./notfound"));
|
|
const notmodified_1 = __importDefault(require("./notmodified"));
|
|
const url_1 = require("url");
|
|
const debug = (0, debug_1.default)('get-uri:file');
|
|
/**
|
|
* Returns a `fs.ReadStream` instance from a "file:" URI.
|
|
*/
|
|
const file = async ({ href: uri }, opts = {}) => {
|
|
const { cache, flags = 'r', mode = 438, // =0666
|
|
} = opts;
|
|
try {
|
|
// Convert URI → Path
|
|
const filepath = (0, url_1.fileURLToPath)(uri);
|
|
debug('Normalized pathname: %o', filepath);
|
|
// `open()` first to get a file descriptor and ensure that the file
|
|
// exists.
|
|
const fdHandle = await fs_1.promises.open(filepath, flags, mode);
|
|
// extract the numeric file descriptor
|
|
const fd = fdHandle.fd;
|
|
// store the stat object for the cache.
|
|
const stat = await fdHandle.stat();
|
|
// if a `cache` was provided, check if the file has not been modified
|
|
if (cache && cache.stat && stat && isNotModified(cache.stat, stat)) {
|
|
await fdHandle.close();
|
|
throw new notmodified_1.default();
|
|
}
|
|
// `fs.ReadStream` takes care of calling `fs.close()` on the
|
|
// fd after it's done reading
|
|
const rs = (0, fs_1.createReadStream)(filepath, {
|
|
autoClose: true,
|
|
...opts,
|
|
fd,
|
|
});
|
|
rs.stat = stat;
|
|
return rs;
|
|
}
|
|
catch (err) {
|
|
if (err.code === 'ENOENT') {
|
|
throw new notfound_1.default();
|
|
}
|
|
throw err;
|
|
}
|
|
};
|
|
exports.file = file;
|
|
// returns `true` if the `mtime` of the 2 stat objects are equal
|
|
function isNotModified(prev, curr) {
|
|
return +prev.mtime === +curr.mtime;
|
|
}
|
|
//# sourceMappingURL=file.js.map
|