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.
110 lines
3.8 KiB
Markdown
110 lines
3.8 KiB
Markdown
get-uri
|
|
=======
|
|
### Returns a `stream.Readable` from a URI string
|
|
|
|
This high-level module accepts a URI string and returns a `Readable` stream
|
|
instance. There is built-in support for a variety of "protocols", and it's
|
|
easily extensible with more:
|
|
|
|
| Protocol | Description | Example
|
|
|:---------:|:-------------------------------:|:---------------------------------:
|
|
| `data` | [Data URIs][data] | `data:text/plain;base64,SGVsbG8sIFdvcmxkIQ%3D%3D`
|
|
| `file` | [File URIs][file] | `file:///c:/windows/example.ini`
|
|
| `ftp` | [FTP URIs][ftp] | `ftp://ftp.kernel.org/pub/site/README`
|
|
| `http` | [HTTP URIs][http] | `http://www.example.com/path/to/name`
|
|
| `https` | [HTTPS URIs][https] | `https://www.example.com/path/to/name`
|
|
|
|
Example
|
|
-------
|
|
|
|
To simply get a `stream.Readable` instance from a `file:` URI, try something like:
|
|
|
|
```ts
|
|
import { getUri } from 'get-uri';
|
|
|
|
// `file:` maps to a `fs.ReadStream` instance…
|
|
const stream = await getUri('file:///Users/nrajlich/wat.json');
|
|
stream.pipe(process.stdout);
|
|
```
|
|
|
|
|
|
Missing Endpoints
|
|
-----------------
|
|
|
|
When you pass in a URI in which the resource referenced does not exist on the
|
|
destination server, then a `NotFoundError` will be thrown. The `code` of the
|
|
error instance is set to `"ENOTFOUND"`, so you can check for that value
|
|
to detect when a bad filename is requested:
|
|
|
|
```ts
|
|
try {
|
|
await getUri('http://example.com/resource.json');
|
|
} catch (err) {
|
|
if (err.code === 'ENOTFOUND') {
|
|
// bad file path requested
|
|
} else {
|
|
// something else bad happened...
|
|
throw err;
|
|
}
|
|
}
|
|
```
|
|
|
|
|
|
Cacheability
|
|
------------
|
|
|
|
When calling `getUri()` with the same URI multiple times, the `get-uri` module
|
|
supports sending an indicator that the remote resource has not been modified
|
|
since the last time it has been retrieved from that node process.
|
|
|
|
To do this, define a `cache` property on the "options object" argument
|
|
with the value set to the `stream.Readable` instance that was previously
|
|
returned. If the remote resource has not been changed since the last call for
|
|
that same URI, then a `NotModifiedError` instance will be thrown with its
|
|
`code` property set to `"ENOTMODIFIED"`.
|
|
|
|
When the `"ENOTMODIFIED"` error occurs, then you can safely re-use the
|
|
results from the previous `getUri()` call for that same URI:
|
|
|
|
``` js
|
|
// First time fetches for real
|
|
const stream = await getUri('http://example.com/resource.json');
|
|
|
|
try {
|
|
// … some time later, if you need to get this same URI again, pass in the
|
|
// previous `stream.Readable` instance as `cache` option to potentially
|
|
// have an "ENOTMODIFIED" error thrown:
|
|
await getUri('http://example.com/resource.json', { cache: stream });
|
|
} catch (err) {
|
|
if (err.code === 'ENOTMODIFIED') {
|
|
// source file has not been modified since last time it was requested,
|
|
// so you are expected to re-use results from a previous call to `getUri()`
|
|
} else {
|
|
// something else bad happened...
|
|
throw err;
|
|
}
|
|
}
|
|
```
|
|
|
|
|
|
API
|
|
---
|
|
|
|
### getUri(uri: string | URL, options?: Object]): Promise<Readable>
|
|
|
|
A `uri` is required. An optional `options` object may be passed in:
|
|
|
|
- `cache` - A `stream.Readable` instance from a previous call to `getUri()` with the same URI. If this option is passed in, and the destination endpoint has not been modified, then an `ENOTMODIFIED` error is thrown
|
|
|
|
Any other options passed in to the `options` object will be passed through
|
|
to the low-level connection creation functions (`http.get()`, `ftp.connect()`,
|
|
etc).
|
|
|
|
Returns a `stream.Readable` instance to read the resource at the given `uri`.
|
|
|
|
[data]: http://tools.ietf.org/html/rfc2397
|
|
[file]: http://tools.ietf.org/html/draft-hoffman-file-uri-03
|
|
[ftp]: http://www.w3.org/Protocols/rfc959/
|
|
[http]: http://www.w3.org/Protocols/rfc2616/rfc2616.html
|
|
[https]: http://wikipedia.org/wiki/HTTP_Secure
|