Skip to content

Commit

Permalink
feat: add OPTIONS method to http measurements
Browse files Browse the repository at this point in the history
  • Loading branch information
alexey-yarmosh committed Dec 17, 2024
1 parent c238626 commit 4e8f024
Show file tree
Hide file tree
Showing 6 changed files with 24 additions and 4 deletions.
2 changes: 1 addition & 1 deletion public/demo/globals.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,4 +19,4 @@ const ALLOWED_MTR_PROTOCOLS = [ 'TCP', 'UDP', 'ICMP' ];

// http
const ALLOWED_HTTP_PROTOCOLS = [ 'HTTP', 'HTTPS', 'HTTP2' ];
const ALLOWED_HTTP_METHODS = [ 'GET', 'HEAD' ];
const ALLOWED_HTTP_METHODS = [ 'GET', 'HEAD', 'OPTIONS' ];
1 change: 1 addition & 0 deletions public/v1/components/schemas.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -449,6 +449,7 @@ components:
enum:
- HEAD
- GET
- OPTIONS
default: HEAD
headers:
type: object
Expand Down
2 changes: 1 addition & 1 deletion src/measurement/schema/command-schema.ts
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ export const ipVersionDnsSchema = Joi.number().when(Joi.ref('resolver'), {
export const validCmdTypes = [ 'ping', 'dns', 'traceroute', 'mtr', 'http' ];

const allowedHttpProtocols = [ 'HTTP', 'HTTPS', 'HTTP2' ];
const allowedHttpMethods = [ 'GET', 'HEAD' ];
const allowedHttpMethods = [ 'GET', 'HEAD', 'OPTIONS' ];

// Http
const httpTargetSchema = Joi.alternatives()
Expand Down
2 changes: 1 addition & 1 deletion src/measurement/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -126,7 +126,7 @@ type DnsResult = TestResult & (DnsRegularResult | DnsTraceResult);

type HttpTest = {
request: {
method: 'HEAD' | 'GET';
method: 'HEAD' | 'GET' | 'OPTIONS';
host?: string;
path: string;
query: string;
Expand Down
19 changes: 19 additions & 0 deletions test/e2e/cases/http.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,25 @@ describe('http measurement', () => {
expect(response).to.matchApiSchema();
});

it('should finish successfully in case of OPTIONS request', async () => {
const { id } = await got.post('http://localhost:80/v1/measurements', { json: {
target: 'www.jsdelivr.com',
type: 'http',
measurementOptions: {
request: {
method: 'OPTIONS',
},
},
} }).json<any>();

const response = await waitMeasurementFinish(id);

expect(response.body.status).to.equal('finished');
expect(response.body.results[0].result.status).to.equal('finished');
expect(response.body.results[0].result.rawBody.length).to.be.above(0);
expect(response).to.matchApiSchema();
});

it('should finish successfully in case of IPv6 domain target', async () => {
const { id } = await got.post('http://localhost:80/v1/measurements', { json: {
target: 'www.jsdelivr.com',
Expand Down
2 changes: 1 addition & 1 deletion test/tests/unit/measurement/schema/schema.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2109,7 +2109,7 @@ describe('command schema', async () => {
const valid = globalSchema.validate(input, { convert: true });

expect(valid.error).to.exist;
expect(valid.error!.message).to.equal('"measurementOptions.request.method" must be one of [GET, HEAD]');
expect(valid.error!.message).to.equal('"measurementOptions.request.method" must be one of [GET, HEAD, OPTIONS]');
});

it('should fail (unsupported protocol)', () => {
Expand Down

0 comments on commit 4e8f024

Please sign in to comment.