forked from KaotoIO/kaoto
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
This commit adds support for the Rest DSL from Apache Camel. fix: KaotoIO#1505 fix: KaotoIO#54
- Loading branch information
Showing
9 changed files
with
414 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
201 changes: 201 additions & 0 deletions
201
packages/ui/src/models/visualization/flows/camel-rest-visual-entity.test.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,201 @@ | ||
import catalogLibrary from '@kaoto/camel-catalog/index.json'; | ||
import { CatalogLibrary, Rest } from '@kaoto/camel-catalog/types'; | ||
import { restStub } from '../../../stubs/rest'; | ||
import { getFirstCatalogMap } from '../../../stubs/test-load-catalog'; | ||
import { EntityType } from '../../camel/entities'; | ||
import { CatalogKind } from '../../catalog-kind'; | ||
import { CamelCatalogService } from './camel-catalog.service'; | ||
import { CamelRestVisualEntity } from './camel-rest-visual-entity'; | ||
import { KaotoSchemaDefinition } from '../../kaoto-schema'; | ||
|
||
describe('CamelRestVisualEntity', () => { | ||
const REST_ID_REGEXP = /^rest-[a-zA-Z0-9]{4}$/; | ||
let restDef: { rest: Rest }; | ||
let restSchema: KaotoSchemaDefinition['schema']; | ||
|
||
beforeAll(async () => { | ||
const catalogsMap = await getFirstCatalogMap(catalogLibrary as CatalogLibrary); | ||
CamelCatalogService.setCatalogKey(CatalogKind.Entity, catalogsMap.entitiesCatalog); | ||
restSchema = catalogsMap.entitiesCatalog[EntityType.Rest].propertiesSchema as KaotoSchemaDefinition['schema']; | ||
}); | ||
|
||
afterAll(() => { | ||
CamelCatalogService.clearCatalogs(); | ||
}); | ||
|
||
beforeEach(() => { | ||
restDef = { | ||
rest: { | ||
...restStub.rest, | ||
}, | ||
}; | ||
}); | ||
|
||
describe('isApplicable', () => { | ||
it.each([ | ||
[true, { rest: {} }], | ||
[true, { rest: { bindingMode: 'off' } }], | ||
[true, restStub], | ||
[false, { from: { id: 'from-1234', steps: [] } }], | ||
[false, { rest: { bindingMode: 'off' }, anotherProperty: true }], | ||
])('should return %s for %s', (result, definition) => { | ||
expect(CamelRestVisualEntity.isApplicable(definition)).toEqual(result); | ||
}); | ||
}); | ||
|
||
describe('constructor', () => { | ||
it('should set id to generated id', () => { | ||
const entity = new CamelRestVisualEntity(restDef); | ||
|
||
expect(entity.id).toMatch(REST_ID_REGEXP); | ||
}); | ||
}); | ||
|
||
it('should return id', () => { | ||
const entity = new CamelRestVisualEntity(restDef); | ||
|
||
expect(entity.getId()).toMatch(REST_ID_REGEXP); | ||
}); | ||
|
||
it('should set id', () => { | ||
const entity = new CamelRestVisualEntity(restDef); | ||
const newId = 'newId'; | ||
entity.setId(newId); | ||
|
||
expect(entity.getId()).toEqual(newId); | ||
}); | ||
|
||
it('should return node label', () => { | ||
const entity = new CamelRestVisualEntity(restDef); | ||
|
||
expect(entity.getNodeLabel()).toEqual('rest'); | ||
}); | ||
|
||
it('should return tooltip content', () => { | ||
const entity = new CamelRestVisualEntity(restDef); | ||
|
||
expect(entity.getTooltipContent()).toEqual('rest'); | ||
}); | ||
|
||
describe('getComponentSchema', () => { | ||
it('should return entity current definition', () => { | ||
const entity = new CamelRestVisualEntity(restDef); | ||
|
||
expect(entity.getComponentSchema().definition).toEqual(restDef.rest); | ||
}); | ||
|
||
it('should return schema from store', () => { | ||
const entity = new CamelRestVisualEntity(restDef); | ||
|
||
expect(entity.getComponentSchema().schema).toEqual(restSchema); | ||
}); | ||
}); | ||
|
||
describe('updateModel', () => { | ||
it('should update model', () => { | ||
const entity = new CamelRestVisualEntity(restDef); | ||
const path = 'rest.bindingMode'; | ||
const value = 'json'; | ||
|
||
entity.updateModel(path, value); | ||
|
||
expect(restDef.rest.bindingMode).toEqual(value); | ||
}); | ||
|
||
it('should not update model if path is not defined', () => { | ||
const entity = new CamelRestVisualEntity(restDef); | ||
const value = 'json_xml'; | ||
|
||
entity.updateModel(undefined, value); | ||
|
||
expect(restDef.rest.bindingMode).toEqual('auto'); | ||
}); | ||
|
||
it('should reset the rest object if it is not defined', () => { | ||
const entity = new CamelRestVisualEntity(restDef); | ||
|
||
entity.updateModel('rest', {}); | ||
|
||
expect(restDef.rest).toEqual({}); | ||
}); | ||
}); | ||
|
||
it('return no interactions', () => { | ||
const entity = new CamelRestVisualEntity(restDef); | ||
|
||
expect(entity.getNodeInteraction()).toEqual({ | ||
canHavePreviousStep: false, | ||
canHaveNextStep: false, | ||
canHaveChildren: false, | ||
canHaveSpecialChildren: false, | ||
canRemoveStep: false, | ||
canReplaceStep: false, | ||
canRemoveFlow: true, | ||
canBeDisabled: false, | ||
}); | ||
}); | ||
|
||
describe('getNodeValidationText', () => { | ||
it('should return undefined for valid definitions', () => { | ||
const entity = new CamelRestVisualEntity({ | ||
rest: { | ||
...restDef.rest, | ||
bindingMode: 'json', | ||
}, | ||
}); | ||
|
||
expect(entity.getNodeValidationText()).toBeUndefined(); | ||
}); | ||
|
||
it('should not modify the original definition when validating', () => { | ||
const originalRestDef: Rest = { ...restDef.rest }; | ||
const entity = new CamelRestVisualEntity(restDef); | ||
|
||
entity.getNodeValidationText(); | ||
|
||
expect(restDef.rest).toEqual(originalRestDef); | ||
}); | ||
|
||
it('should return errors when there is an invalid property', () => { | ||
const invalidRestDef: Rest = { | ||
...restDef.rest, | ||
bindingMode: 'true' as unknown as Rest['bindingMode'], | ||
openApi: 'true' as unknown as Rest['openApi'], | ||
}; | ||
const entity = new CamelRestVisualEntity({ rest: invalidRestDef }); | ||
|
||
expect(entity.getNodeValidationText()).toEqual(`'/bindingMode' must be equal to one of the allowed values, | ||
'/openApi' must be object`); | ||
}); | ||
}); | ||
|
||
describe('toVizNode', () => { | ||
it('should return visualization node', () => { | ||
const entity = new CamelRestVisualEntity(restDef); | ||
|
||
const vizNode = entity.toVizNode(); | ||
|
||
expect(vizNode.data).toEqual({ | ||
componentName: undefined, | ||
entity, | ||
icon: '', | ||
isGroup: true, | ||
path: 'rest', | ||
processorName: 'rest', | ||
}); | ||
}); | ||
|
||
it('should return hardcoded schema title', () => { | ||
const entity = new CamelRestVisualEntity(restDef); | ||
const vizNode = entity.toVizNode(); | ||
|
||
expect(vizNode.getTitle()).toEqual('Rest'); | ||
}); | ||
}); | ||
|
||
it('should serialize the rest definition', () => { | ||
const entity = new CamelRestVisualEntity(restDef); | ||
|
||
expect(entity.toJSON()).toEqual(restDef); | ||
}); | ||
}); |
Oops, something went wrong.