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: add extended math utils and duration support #923

Merged
merged 1 commit into from
Dec 6, 2024

Conversation

nathanklick
Copy link
Member

@nathanklick nathanklick commented Dec 4, 2024

Description

This pull request changes the following:

  • Adds a new Duration class based on the official Java implementation.
  • Adds a new MathEx class to support the Duration implementation.
  • Adds a new ArithmeticError class to support proper exception handling.
  • Replaces all usages of the SECONDS and MINUTES constants with the appropriate Duration methods.
  • Updates the sleep() method to accept Duration instances as the argument.

Related Issues

Notes to Reviewers

  • This draft PR is still missing unit test coverage for the Duration class. If anyone has bandwidth please feel to contribute unit tests.

@nathanklick nathanklick added the Feature Enhancement Enhancing an existing feature driven by business requirements. Typically backwards compatible. label Dec 4, 2024
@nathanklick nathanklick self-assigned this Dec 4, 2024
Copy link
Contributor

github-actions bot commented Dec 4, 2024

Unit Test Results - Linux

  1 files  ± 0   53 suites  +3   4s ⏱️ -1s
216 tests +18  216 ✅ +18  0 💤 ±0  0 ❌ ±0 
226 runs  +18  226 ✅ +18  0 💤 ±0  0 ❌ ±0 

Results for commit 55884af. ± Comparison against base commit a7bbae0.

♻️ This comment has been updated with latest results.

Copy link
Contributor

github-actions bot commented Dec 4, 2024

Unit Test Results - Windows

  1 files  ± 0   53 suites  +3   13s ⏱️ -2s
216 tests +18  216 ✅ +18  0 💤 ±0  0 ❌ ±0 
226 runs  +18  226 ✅ +18  0 💤 ±0  0 ❌ ±0 

Results for commit 55884af. ± Comparison against base commit a7bbae0.

♻️ This comment has been updated with latest results.

Copy link
Contributor

@instamenta instamenta left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I like what I see definitely. Left some small suggestions that are up for debate

src/core/time/duration.ts Outdated Show resolved Hide resolved
src/core/time/time.ts Outdated Show resolved Hide resolved
jeromy-cannon
jeromy-cannon previously approved these changes Dec 4, 2024
@nathanklick nathanklick force-pushed the 00867-Time-Handling branch 3 times, most recently from c3d940d to f355b26 Compare December 6, 2024 16:38
@nathanklick nathanklick marked this pull request as ready for review December 6, 2024 16:43
@nathanklick nathanklick requested review from a team and leninmehedy as code owners December 6, 2024 16:43
Copy link
Contributor

github-actions bot commented Dec 6, 2024

E2E Test Report

 13 files  ±0  105 suites  ±0   56m 47s ⏱️ + 1m 49s
220 tests ±0  220 ✅ ±0  0 💤 ±0  0 ❌ ±0 
223 runs  ±0  223 ✅ ±0  0 💤 ±0  0 ❌ ±0 

Results for commit 55884af. ± Comparison against base commit a7bbae0.

♻️ This comment has been updated with latest results.

Copy link

Coverage summary from Codacy

See diff coverage on Codacy

Coverage variation Diff coverage
+0.30% (target: -1.00%) 91.51%
Coverage variation details
Coverable lines Covered lines Coverage
Common ancestor commit (a7bbae0) 18307 15316 83.66%
Head commit (55884af) 19035 (+728) 15982 (+666) 83.96% (+0.30%)

Coverage variation is the difference between the coverage for the head and common ancestor commits of the pull request branch: <coverage of head commit> - <coverage of common ancestor commit>

Diff coverage details
Coverable lines Covered lines Diff coverage
Pull request (#923) 730 668 91.51%

Diff coverage is the percentage of lines that are covered by tests out of the coverable lines that the pull request added or modified: <covered lines added or modified>/<coverable lines added or modified> * 100%

See your quality gate settings    Change summary preferences

Codacy stopped sending the deprecated coverage status on June 5th, 2024. Learn more

Copy link

codecov bot commented Dec 6, 2024

Codecov Report

Attention: Patch coverage is 91.09589% with 65 lines in your changes missing coverage. Please review.

Project coverage is 82.91%. Comparing base (a7bbae0) to head (55884af).
Report is 59 commits behind head on main.

Files with missing lines Patch % Lines
src/core/time/duration.ts 87.75% 57 Missing and 3 partials ⚠️
src/core/util/math_ex.ts 96.61% 4 Missing ⚠️
src/core/k8.ts 91.66% 1 Missing ⚠️
Additional details and impacted files

Impacted file tree graph

@@            Coverage Diff             @@
##             main     #923      +/-   ##
==========================================
+ Coverage   82.61%   82.91%   +0.29%     
==========================================
  Files          67       71       +4     
  Lines       18335    19035     +700     
  Branches     1715     1513     -202     
==========================================
+ Hits        15148    15783     +635     
- Misses       3015     3158     +143     
+ Partials      172       94      -78     
Files with missing lines Coverage Δ
src/commands/node/tasks.ts 84.00% <100.00%> (ø)
src/core/constants.ts 97.01% <ø> (-0.05%) ⬇️
src/core/helpers.ts 70.78% <100.00%> (+0.08%) ⬆️
src/core/lease/lease.ts 85.09% <100.00%> (+0.03%) ⬆️
src/core/lease/lease_renewal.ts 91.66% <100.00%> (ø)
src/core/time/time.ts 100.00% <100.00%> (ø)
src/core/util/arithmetic_error.ts 100.00% <100.00%> (ø)
src/core/k8.ts 88.46% <91.66%> (-0.06%) ⬇️
src/core/util/math_ex.ts 96.61% <96.61%> (ø)
src/core/time/duration.ts 87.75% <87.75%> (ø)

... and 17 files with indirect coverage changes

Impacted file tree graph

@nathanklick nathanklick merged commit f5a69e7 into main Dec 6, 2024
36 of 37 checks passed
@nathanklick nathanklick deleted the 00867-Time-Handling branch December 6, 2024 17:24
swirlds-automation added a commit that referenced this pull request Dec 31, 2024
## [0.32.0](v0.31.1...v0.32.0) (2024-12-31)

### ⚠ BREAKING CHANGES

* update readme with warning about BREAKING CHANGE in this next release (#730)

### Features

* add ci test flow to test task command to launch solo ([#811](#811)) ([356f341](356f341))
* add example for using javascript SDK ([#832](#832)) ([1d9452e](1d9452e))
* add extended math utils and duration support ([#923](#923)) ([f5a69e7](f5a69e7))
* add separate commands for update ([#735](#735)) ([44c3132](44c3132))
* add solo smoke test to test flow ([#905](#905)) ([79410f0](79410f0))
* add support for flexible lease acquisition and production readiness ([#830](#830)) ([7fa86ad](7fa86ad))
* Add the ability to inject a ca certificate for use in gRPC and gRPC Web ([#753](#753)) ([2cd8a38](2cd8a38))
* add timeout flag to network destroy command ([#821](#821)) ([0fb570b](0fb570b))
* allow settings a reserved static IP address for the consensus nodes HAProxy and Envoy Proxy though the cli with flags ([#937](#937)) ([de9ec2e](de9ec2e))
* change mirror node and explorer from subchart to individual chart ([#743](#743)) ([58f0496](58f0496))
* Create a local config for storing configurations on the users machine ([#803](#803)) ([0a4382d](0a4382d))
* Create remote config  ([#862](#862)) ([e8fe739](e8fe739))
* dynamically construct the genesis-network.json and add it to the values file to be used during network deploy ([#982](#982)) ([1b9b7e6](1b9b7e6))
* expose pod check attempts and delays as environment controlled variables ([#812](#812)) ([a7b3279](a7b3279))
* Implement IOC ([#1010](#1010)) ([ed23a7b](ed23a7b))
* Implement solo context connect ([#863](#863)) ([782b3ec](782b3ec))
* Increase helm chart version and switch to use oci registry ([#788](#788)) ([1973275](1973275))
* **k8s:** introduce Kubernetes lease lock mechanism ([#707](#707)) ([f1b8089](f1b8089))
* new command to save state files and upload state files ([#849](#849)) ([d5a9a18](d5a9a18))
* removed caching of ConfigManager and its flags ([#713](#713)) ([76a61e3](76a61e3))
* Setup mirror node monitor pinger service ([#893](#893)) ([f4c4320](f4c4320))
* update `solo context connect` to connect to single remote cluster ([#993](#993)) ([c9711c5](c9711c5))
* Update document ([#956](#956)) ([b378937](b378937))
* update readme and hugo workflow ([#930](#930)) ([0e08abc](0e08abc))
* Validate a remote config ([#922](#922)) ([a7bbae0](a7bbae0))

### Bug Fixes

* add delay before calling script ([#955](#955)) ([76f4b81](76f4b81))
* allow expired leases to be overwritten ([#828](#828)) ([1fa1d78](1fa1d78))
* bump chart and hedera version,  re-enable node add ([#985](#985)) ([9cae011](9cae011))
* check if setup chart installed or not before network deploy ([#799](#799)) ([6930dab](6930dab))
* document typo ([#988](#988)) ([8e4fe04](8e4fe04))
* Error in `node update` separate commands when new admin key is not supplied ([#854](#854)) ([6e472b5](6e472b5))
* Examples of performance configs for HashSphere and Latitude ([#926](#926)) ([#957](#957)) ([928148b](928148b))
* fix missing file issues when running solo from npm install -g ([#736](#736)) ([2a5cfc1](2a5cfc1))
* fixed genesis-network.json file lock issue ([#1074](#1074)) ([e590516](e590516))
* flag check of node logs command and incorrect download source ([#848](#848)) ([03051f0](03051f0))
* inconsistent failures ([#866](#866)) ([13ea46d](13ea46d))
* local chart directory not being taken correctly ([#983](#983)) ([58e96e1](58e96e1))
* nextNode ID for release version > 0.56.0 ([#765](#765)) ([3b98dd6](3b98dd6))
* node id should start from `1` ([#884](#884)) ([d90c9b5](d90c9b5))
* node update with single node ([#981](#981)) ([74285bf](74285bf))
* patch issue with dist folder not showing up ([#733](#733)) ([077f989](077f989))
* performance improvements for node stop ([#986](#986)) ([437bbc6](437bbc6))
* refactored Taskfiles, fixed bugs with taskfile, lease interval, sdk node client connection, and commands missing quiet flag ([#978](#978)) ([7bb0e99](7bb0e99))
* remote config validation not working ([#967](#967)) ([88c2506](88c2506))
* resolve node update test failures ([#856](#856)) ([5e1c652](5e1c652))
* Revised example configs for Latitude deployment, automation friendly ([#1038](#1038)) ([434daf3](434daf3))
* undefined log output of namespace ([#764](#764)) ([ac15957](ac15957))

### Documentation

* update readme with warning about BREAKING CHANGE in this next release ([#730](#730)) ([06295f6](06295f6))
@swirlds-automation
Copy link
Contributor

🎉 This PR is included in version 0.32.0 🎉

The release is available on:

Your semantic-release bot 📦🚀

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Feature Enhancement Enhancing an existing feature driven by business requirements. Typically backwards compatible. released
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Production Readiness: Improve time handling logic
4 participants