Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: rename flag move to components to move duplicates to components #235

Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
21 commits
Select commit Hold shift + click to select a range
2ec4971
fix: add searching for `replyAddresses` component of v3 (#213)
aeworxet Jan 9, 2024
003f495
chore(release): v0.3.1 (#214)
asyncapi-bot Jan 9, 2024
e984a79
chore: remove JSON.stringify() from example code (#215)
aeworxet Jan 16, 2024
b3ec2c5
fix: update @asyncapi/parser to 3.0.3 version (#217)
asyncapi-bot Jan 29, 2024
add3060
chore(release): v0.3.2 (#218)
asyncapi-bot Jan 29, 2024
b7237e5
fix: update @asyncapi/parser to 3.0.4 version (#219)
asyncapi-bot Jan 30, 2024
19b6f11
chore(release): v0.3.3 (#220)
asyncapi-bot Jan 30, 2024
75e19db
fix: update @asyncapi/parser to 3.0.5 version (#221)
asyncapi-bot Feb 4, 2024
e8c9c64
chore(release): v0.3.4 (#222)
asyncapi-bot Feb 4, 2024
95080a2
fix: update @asyncapi/parser to 3.0.6 version (#223)
asyncapi-bot Feb 16, 2024
adfa155
chore(release): v0.3.5 (#224)
asyncapi-bot Feb 16, 2024
9dfb12f
fix: update @asyncapi/parser to 3.0.7 version (#225)
asyncapi-bot Feb 21, 2024
ac2bccb
chore(release): v0.3.6 (#226)
asyncapi-bot Feb 21, 2024
2aaecd5
ci: update of files from global .github repo (#227)
asyncapi-bot Mar 11, 2024
59ce2ff
fix: update @asyncapi/parser to 3.0.8 version (#228)
asyncapi-bot Mar 14, 2024
19871f1
chore(release): v0.3.7 (#229)
asyncapi-bot Mar 14, 2024
1c393e9
fix: update @asyncapi/parser to 3.0.9 version (#230)
asyncapi-bot Mar 14, 2024
8920f98
chore(release): v0.3.8 (#231)
asyncapi-bot Mar 14, 2024
beac12e
fix: update @asyncapi/parser to 3.0.10 version (#232)
asyncapi-bot Mar 14, 2024
4a20ce7
chore(release): v0.3.9 (#233)
asyncapi-bot Mar 14, 2024
5e37bbf
feat: rename flag `moveToComponents` -> `moveDuplicatesToComponents`
aeworxet Dec 20, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions .github/workflows/bump.yml
Original file line number Diff line number Diff line change
Expand Up @@ -26,9 +26,9 @@ jobs:
run: test -e ./package.json && echo "exists=true" >> $GITHUB_OUTPUT || echo "exists=false" >> $GITHUB_OUTPUT
- if: steps.packagejson.outputs.exists == 'true'
name: Bumping latest version of this package in other repositories
uses: derberg/npm-dependency-manager-for-your-github-org@26a4f13d740254719971325046822a169aaa7441 # using v5.-.- https://github.com/derberg/npm-dependency-manager-for-your-github-org/releases/tag/v5.0.0
uses: derberg/npm-dependency-manager-for-your-github-org@3df56be95bcaa5c76a9c9a4af863ab151545b649 # using v6.-.- https://github.com/derberg/npm-dependency-manager-for-your-github-org/releases/tag/v6
with:
github_token: ${{ secrets.GH_TOKEN }}
committer_username: asyncapi-bot
committer_email: [email protected]
repos_to_ignore: spec,bindings
repos_to_ignore: spec,bindings,saunter
3 changes: 1 addition & 2 deletions API.md
Original file line number Diff line number Diff line change
Expand Up @@ -132,7 +132,7 @@ Converts JSON or YAML string object.
| --- | --- | --- |
| [reuseComponents] | <code>Boolean</code> | whether to reuse components from `components` section or not. Defaults to `true`. |
| [removeComponents] | <code>Boolean</code> | whether to remove un-used components from `components` section or not. Defaults to `true`. |
| [moveToComponents] | <code>Boolean</code> | whether to move duplicated components to the `components` section or not. Defaults to `true`. |
| [moveDuplicatesToComponents] | <code>Boolean</code> | whether to move duplicated components to the `components` section or not. Defaults to `true`. |

<a name="Options"></a>

Expand All @@ -144,4 +144,3 @@ Converts JSON or YAML string object.
| --- | --- | --- |
| [rules] | [<code>Rules</code>](#Rules) | the list of rules that specifies which type of optimizations should be applied. |
| [output] | <code>String</code> | specifies which type of output user wants, `'JSON'` or `'YAML'`. Defaults to `'YAML'`; |

4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -137,7 +137,7 @@ the report value will be:
action: 'remove',
}
],
moveToComponents: [
moveDuplicatesToComponents: [
{
//move will ref the current path to the moved component as well.
path: 'channels.smartylighting/event/{streetlightId}/lighting/measured.parameters.streetlightId',
Expand All @@ -159,7 +159,7 @@ const optimizedDocument = optimizer.getOptimizedDocument({
rules: {
reuseComponents: true,
removeComponents: true,
moveToComponents: true
moveDuplicatesToComponents: true
}
});
/*
Expand Down
4 changes: 2 additions & 2 deletions examples/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,13 @@ const { Optimizer } = require('../lib/Optimizer')
const input = require('fs').readFileSync('./examples/input.yaml', 'utf8')
const optimizer = new Optimizer(input)
optimizer.getReport().then((report) => {
console.log(JSON.stringify(report))
console.log(report)
const optimizedDocument = optimizer.getOptimizedDocument({
output: 'YAML',
rules: {
reuseComponents: true,
removeComponents: true,
moveToComponents: true,
moveDuplicatesToComponents: true,
},
})
//store optimizedDocument as to output.yaml
Expand Down
34 changes: 17 additions & 17 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 2 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@asyncapi/optimizer",
"version": "0.3.0",
"version": "0.3.9",
"description": "This library will optimize the AsyncAPI specification file.",
"main": "./lib/index.js",
"types": "./lib/index.d.ts",
Expand Down Expand Up @@ -56,7 +56,7 @@
"access": "public"
},
"dependencies": {
"@asyncapi/parser": "^3.0.2",
"@asyncapi/parser": "^3.0.10",
"@types/debug": "^4.1.8",
"debug": "^4.3.4",
"js-yaml": "^4.1.0",
Expand Down
1 change: 1 addition & 0 deletions src/ComponentProvider.ts
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,7 @@ export const getOptimizableComponents = (
parameters: getAllComponents('parameters'),
correlationIds: getAllComponents('correlationIds'),
replies: getAllComponents('replies'),
replyAddresses: getAllComponents('replyAddresses'),
externalDocs: getAllComponents('externalDocs'),
tags: getAllComponents('tags'),
operationTraits: getAllComponents('operationTraits'),
Expand Down
8 changes: 4 additions & 4 deletions src/Optimizer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import {
Reporter,
} from './index.d'
import { Parser } from '@asyncapi/parser'
import { removeComponents, reuseComponents, moveToComponents } from './Reporters'
import { removeComponents, reuseComponents, moveDuplicatesToComponents } from './Reporters'
import YAML from 'js-yaml'
import merge from 'merge-deep'
import * as _ from 'lodash'
Expand Down Expand Up @@ -42,7 +42,7 @@ export class Optimizer {
*/
constructor(private YAMLorJSON: any) {
this.outputObject = toJS(this.YAMLorJSON)
this.reporters = [removeComponents, reuseComponents, moveToComponents]
this.reporters = [removeComponents, reuseComponents, moveDuplicatesToComponents]
}

/**
Expand Down Expand Up @@ -78,7 +78,7 @@ export class Optimizer {
* @typedef {Object} Rules
* @property {Boolean=} reuseComponents - whether to reuse components from `components` section or not. Defaults to `true`.
* @property {Boolean=} removeComponents - whether to remove un-used components from `components` section or not. Defaults to `true`.
* @property {Boolean=} moveToComponents - whether to move duplicated components to the `components` section or not. Defaults to `true`.
* @property {Boolean=} moveDuplicatesToComponents - whether to move duplicated components to the `components` section or not. Defaults to `true`.
*/

/**
Expand All @@ -98,7 +98,7 @@ export class Optimizer {
rules: {
reuseComponents: true,
removeComponents: true,
moveToComponents: true,
moveDuplicatesToComponents: true,
},
output: Output.YAML,
}
Expand Down
2 changes: 1 addition & 1 deletion src/Reporters/index.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
export * from './MoveToComponents'
export * from './moveDuplicatesToComponents'
export * from './RemoveComponents'
export * from './ReuseComponents'
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { Action } from '../Optimizer'
import { createReport, isEqual, isInComponents } from '../Utils'
import { OptimizableComponent, OptimizableComponentGroup, ReportElement, Reporter } from 'index.d'
import Debug from 'debug'
const debug = Debug('reporter:moveToComponents')
const debug = Debug('reporter:moveDuplicatesToComponents')
/**
*
* @param optimizableComponentGroup components that you want to analyze for duplicates.
Expand Down Expand Up @@ -58,8 +58,8 @@ const findDuplicateComponents = (
return resultElements
}

export const moveToComponents: Reporter = (optimizableComponentsGroup) => {
return createReport(findDuplicateComponents, optimizableComponentsGroup, 'moveToComponents')
export const moveDuplicatesToComponents: Reporter = (optimizableComponentsGroup) => {
return createReport(findDuplicateComponents, optimizableComponentsGroup, 'moveDuplicatesToComponents')
}

function getOutsideComponents(
Expand Down
4 changes: 2 additions & 2 deletions src/index.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ export type OptimizableComponentGroup = {
export interface Report {
reuseComponents?: ReportElement[]
removeComponents?: ReportElement[]
moveToComponents?: ReportElement[]
moveDuplicatesToComponents?: ReportElement[]
}

//In the next major version we can rename this to `Report` and use this format instead.
Expand All @@ -32,7 +32,7 @@ export type Reporter = (optimizeableComponents: OptimizableComponentGroup[]) =>
interface Rules {
reuseComponents?: boolean
removeComponents?: boolean
moveToComponents?: boolean
moveDuplicatesToComponents?: boolean
}
export interface Options {
rules?: Rules
Expand Down
12 changes: 6 additions & 6 deletions test/Reporters/Reporters.spec.ts
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
import { moveToComponents, reuseComponents, removeComponents } from '../../src/Reporters'
import { moveDuplicatesToComponents, reuseComponents, removeComponents } from '../../src/Reporters'
import { inputYAML } from '../fixtures'
import { Parser } from '@asyncapi/parser'
import { getOptimizableComponents } from '../../src/ComponentProvider'
import { OptimizableComponentGroup } from '../../src/index.d'

const MoveToComponentsExpectedResult: any[] = [
const moveDuplicatesToComponentsExpectedResult: any[] = [
{
path: 'channels.withDuplicatedMessage1.messages.duped1',
action: 'move',
Expand Down Expand Up @@ -55,11 +55,11 @@ describe('Optimizers', () => {
const asyncapiDocument = await new Parser().parse(inputYAML, { applyTraits: false })
optimizableComponents = getOptimizableComponents(asyncapiDocument.document!)
})
describe('MoveToComponents', () => {
describe('moveDuplicatesToComponents', () => {
test('should contain the correct optimizations.', () => {
const report = moveToComponents(optimizableComponents)
expect(report.elements).toEqual(MoveToComponentsExpectedResult)
expect(report.type).toEqual('moveToComponents')
const report = moveDuplicatesToComponents(optimizableComponents)
expect(report.elements).toEqual(moveDuplicatesToComponentsExpectedResult)
expect(report.type).toEqual('moveDuplicatesToComponents')
})
})

Expand Down
Loading