Skip to content

Commit

Permalink
fix: allow missing instanceId in client metrics (#1522)
Browse files Browse the repository at this point in the history
* fix: allow missing instanceId in client metrics

* fix: remove ts-ignore
  • Loading branch information
ivarconr committed Apr 22, 2022
1 parent 2b74651 commit 14694fd
Show file tree
Hide file tree
Showing 3 changed files with 111 additions and 2 deletions.
14 changes: 14 additions & 0 deletions src/lib/routes/client-api/register.test.ts
Expand Up @@ -84,12 +84,26 @@ test('should require strategies field', () => {
.expect(400);
});

test('should allow an no instanceId field', () => {
expect.assertions(0);
return request
.post('/api/client/register')
.send({
appName: 'demo',
strategies: ['default'],
started: Date.now(),
interval: 10,
})
.expect(202);
});

test('should allow an empty instanceId field', () => {
expect.assertions(0);
return request
.post('/api/client/register')
.send({
appName: 'demo',
instanceId: '',
strategies: ['default'],
started: Date.now(),
interval: 10,
Expand Down
95 changes: 95 additions & 0 deletions src/lib/services/client-metrics/schema.test.ts
@@ -0,0 +1,95 @@
import { clientRegisterSchema, clientMetricsSchema } from './schema';

test('clientRegisterSchema should allow empty ("") instanceId', () => {
const { value } = clientRegisterSchema.validate({
appName: 'test',
instanceId: '',
strategies: ['default'],
started: Date.now(),
interval: 100,
});
//@ts-ignore
expect(value.instanceId).toBe('default');
});

test('clientRegisterSchema should allow undefined instanceId', () => {
const { value } = clientRegisterSchema.validate({
appName: 'test',
strategies: ['default'],
started: Date.now(),
interval: 100,
});

expect(value.instanceId).toBe('default');
});

test('clientRegisterSchema should allow null instanceId', () => {
const { value } = clientRegisterSchema.validate({
appName: 'test',
instanceId: null,
strategies: ['default'],
started: Date.now(),
interval: 100,
});
expect(value.instanceId).toBe('default');
});

test('clientRegisterSchema should use instanceId', () => {
const { value } = clientRegisterSchema.validate({
appName: 'test',
instanceId: 'some',
strategies: ['default'],
started: Date.now(),
interval: 100,
});
expect(value.instanceId).toBe('some');
});

test('clientMetricsSchema should allow null instanceId', () => {
const { value } = clientMetricsSchema.validate({
appName: 'test',
instanceId: null,
bucket: {
started: Date.now(),
stopped: Date.now(),
},
});
expect(value.instanceId).toBe('default');
});

test('clientMetricsSchema should allow empty ("") instanceId', () => {
const { value } = clientMetricsSchema.validate({
appName: 'test',
instanceId: '',
bucket: {
started: Date.now(),
stopped: Date.now(),
},
});
expect(value.instanceId).toBe('default');
});

test('clientMetricsSchema should allow undefined instanceId', () => {
const { value } = clientMetricsSchema.validate({
appName: 'test',
bucket: {
started: Date.now(),
stopped: Date.now(),
},
});

expect(value.instanceId).toBe('default');
});

test('clientMetricsSchema should use instanceId', () => {
const { value } = clientMetricsSchema.validate({
appName: 'test',
instanceId: 'some',
bucket: {
started: Date.now(),
stopped: Date.now(),
},
});

expect(value.instanceId).toBe('some');
});
4 changes: 2 additions & 2 deletions src/lib/services/client-metrics/schema.ts
Expand Up @@ -15,7 +15,7 @@ export const clientMetricsSchema = joi
.keys({
environment: joi.string().optional(),
appName: joi.string().required(),
instanceId: joi.string().default('default'),
instanceId: joi.string().empty(['', null]).default('default'),
bucket: joi
.object()
.required()
Expand Down Expand Up @@ -48,7 +48,7 @@ export const clientRegisterSchema = joi
.options({ stripUnknown: true })
.keys({
appName: joi.string().required(),
instanceId: joi.string().default('default'),
instanceId: joi.string().empty(['', null]).default('default'),
sdkVersion: joi.string().optional(),
strategies: joi
.array()
Expand Down

0 comments on commit 14694fd

Please sign in to comment.