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

refactor: AgentSettings Circular Structure and improve internals #412

Closed

Conversation

sw-joelmut
Copy link

#minor

Description

This PR replaces the skipProperties functionality with an internal _replacer function when the JSON.stringify function gets called in the calculateChangeHash.
The calculateChangeHash has been changed to use a new internal stringify function, that allows to detect and handle Circular Structures.
Additionally, the AgentSettings configuration has being added to the getRuntimeServices function, so internal functionalities can use them. Not only that, the SkillClient has being updated based on this configuration, that work for both Composer and non-Composer bots.

Specific Changes

  • The BotState class has being updated, removing all the skipProperties functionality.
  • The calculateChangeHash has being refactored to handle Circular Structures and generate a hash, instead of a plain JSON.stringify value, so it is easier to debug and identify.
  • Added the ConnectorClientOptions to the start and getRuntimeServices functions for Composer bots, so it can be customizable, and delegate to the internal CoreBot to use.
  • The BeginSkill has being updated, removing the skipProperties and introducing the new internal _replace function, for the stringify functionality to execute.
  • Added a new stringify function that encapsulates the native JSON.stringify function, with the addition to handle Circular Structures and expose the internal _replacer function to customize it.
  • Updated the internal botFrameworkClientFetchImpl function to use a single instance of axios and handle its configuration from ConnectorClientOptions.

Testing

The following images show how the ConnectorClientOptions can be provided from a Composer bot perspective, the new stringify functionality that detects and replaces circular references, and the generated hash string.
image
image
image

@coveralls
Copy link

coveralls commented Mar 11, 2024

Pull Request Test Coverage Report for Build 8236257439

Details

  • 40 of 56 (71.43%) changed or added relevant lines in 6 files are covered.
  • No unchanged relevant lines lost coverage.
  • Overall coverage decreased (-0.05%) to 84.427%

Changes Missing Coverage Covered Lines Changed/Added Lines %
libraries/botbuilder-stdlib/src/stringify.ts 24 25 96.0%
libraries/botframework-connector/src/auth/botFrameworkClientImpl.ts 2 17 11.76%
Totals Coverage Status
Change from base Build 8172036330: -0.05%
Covered Lines: 20418
Relevant Lines: 22893

💛 - Coveralls

@sw-joelmut
Copy link
Author

/promoted 4641

@sw-joelmut sw-joelmut closed this Apr 3, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants