-
Notifications
You must be signed in to change notification settings - Fork 2.5k
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
[Bug]: span tags of type int64 may lose precision #3958 #4023
Conversation
@yurishkuro Could you please check this draft pull request? I suppose the types in domain_01.json and ui_01.json are to be different in case of large integer values. |
model/converter/json/from_domain.go
Outdated
@@ -122,6 +128,10 @@ func (fd fromDomain) convertKeyValues(keyValues model.KeyValues) []json.KeyValue | |||
value = kv.Bool() | |||
case model.Int64Type: | |||
value = kv.Int64() | |||
if kv.Int64() > js_limit_max || kv.Int64() < js_limit_min { | |||
kv.VType = 0 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this needs to go into temp variable above the switch, must not change (in place) the input data
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I could not get why this change is required. If we move this if
if kv.Int64() > jsMaxSafeInteger || kv.Int64() < jsMinSafeInteger {
kv.VType = model.StringType
value = fmt.Sprintf("%d", value)
}
before switch, the switch case model.StringType will be executed and the previous value will be overwriiten.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You should not be changing the type at all, just the value to be a string.
model/converter/json/from_domain.go
Outdated
js_limit_max = 9007199254740991 | ||
js_limit_min = -9007199254740991 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
js_limit_max = 9007199254740991 | |
js_limit_min = -9007199254740991 | |
jsMaxSafeInteger = int64(1)<<53 - 1 | |
jsMinSafeInteger = -jsMaxSafeInteger |
{ | ||
"key":"javascript_limit", | ||
"vType":"INT64", | ||
"vInt64":9223372036854775222 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I expect this to be string, otherwise it will lose precision upon parsing in JS
"vInt64":9223372036854775222 | |
"vInt64":"9223372036854775222" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
const z = Number.parseInt("9007199254740993");
console.log(z);
// expected output: 9007199254740992
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes it was shown as a string in ui_01-actual.json . There is a type mismatch between domain_01.json (int64) and ui_01-actual.json (string) and hence the test case TestFromDomain was failing
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am not talking about vType
field, it should indeed remain INT64
, but the value of vInt64
field needs to be a string, not a raw number, because the raw number is what's causing the precision loss.
please make sure commits are signed (git commit -s), see CONTRIBUTING.md |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You still have some commits unsigned. I recommend squashing them into one commit that you can sign.
{ | ||
"key":"javascript_limit", | ||
"vType":"INT64", | ||
"vInt64":9223372036854775222 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am not talking about vType
field, it should indeed remain INT64
, but the value of vInt64
field needs to be a string, not a raw number, because the raw number is what's causing the precision loss.
model/converter/json/from_domain.go
Outdated
@@ -122,6 +128,10 @@ func (fd fromDomain) convertKeyValues(keyValues model.KeyValues) []json.KeyValue | |||
value = kv.Bool() | |||
case model.Int64Type: | |||
value = kv.Int64() | |||
if kv.Int64() > js_limit_max || kv.Int64() < js_limit_min { | |||
kv.VType = 0 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You should not be changing the type at all, just the value to be a string.
model/converter/json/from_domain.go
Outdated
@@ -122,6 +128,10 @@ func (fd fromDomain) convertKeyValues(keyValues model.KeyValues) []json.KeyValue | |||
value = kv.Bool() | |||
case model.Int64Type: | |||
value = kv.Int64() | |||
if kv.Int64() > jsMaxSafeInteger || kv.Int64() < jsMinSafeInteger { | |||
kv.VType = 0 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
kv.VType = 0 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I have done the required changes. Could you please review?
Signed-off-by: Shubham Sawaiker <sawaikershubham@gmail.com>
[Bug]: span tags of type int64 may lose precision jaegertracing#3958 Signed-off-by: Shubham Sawaiker <sawaikershubham@gmail.com>
Bumps [github.com/spf13/viper](https://github.com/spf13/viper) from 1.13.0 to 1.14.0. - [Release notes](https://github.com/spf13/viper/releases) - [Commits](spf13/viper@v1.13.0...v1.14.0) --- updated-dependencies: - dependency-name: github.com/spf13/viper dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Signed-off-by: Shubham Sawaiker <sawaikershubham@gmail.com>
…tracing#4026) Bumps [github.com/dgraph-io/badger/v3](https://github.com/dgraph-io/badger) from 3.2103.3 to 3.2103.4. - [Release notes](https://github.com/dgraph-io/badger/releases) - [Changelog](https://github.com/dgraph-io/badger/blob/main/CHANGELOG.md) - [Commits](dgraph-io/badger@v3.2103.3...v3.2103.4) --- updated-dependencies: - dependency-name: github.com/dgraph-io/badger/v3 dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <support@github.com> Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Signed-off-by: Shubham Sawaiker <sawaikershubham@gmail.com>
Bumps [github/codeql-action](https://github.com/github/codeql-action) from 2.1.29 to 2.1.31. - [Release notes](https://github.com/github/codeql-action/releases) - [Changelog](https://github.com/github/codeql-action/blob/main/CHANGELOG.md) - [Commits](github/codeql-action@ec3cf9c...c3b6fce) --- updated-dependencies: - dependency-name: github/codeql-action dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <support@github.com> Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Signed-off-by: Shubham Sawaiker <sawaikershubham@gmail.com>
Bumps [anchore/sbom-action](https://github.com/anchore/sbom-action) from 0.13.0 to 0.13.1. - [Release notes](https://github.com/anchore/sbom-action/releases) - [Commits](anchore/sbom-action@b7e8507...06e1094) --- updated-dependencies: - dependency-name: anchore/sbom-action dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <support@github.com> Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Signed-off-by: Shubham Sawaiker <sawaikershubham@gmail.com>
Signed-off-by: Shubham Sawaiker <sawaikershubham@gmail.com>
[Bug]: span tags of type int64 may lose precision
model/converter/json/from_domain.go
Outdated
switch kv.VType { | ||
case model.StringType: | ||
value = kv.VStr | ||
case model.BoolType: | ||
value = kv.Bool() | ||
case model.Int64Type: | ||
value = kv.Int64() | ||
if jsflag { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
if jsflag { | |
if kv.Int64() > jsMaxSafeInteger || kv.Int64() < jsMinSafeInteger { |
model/converter/json/from_domain.go
Outdated
var jsflag bool = false | ||
if kv.Int64() > jsMaxSafeInteger || kv.Int64() < jsMinSafeInteger { | ||
jsflag = true | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
var jsflag bool = false | |
if kv.Int64() > jsMaxSafeInteger || kv.Int64() < jsMinSafeInteger { | |
jsflag = true | |
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Commited
Codecov ReportBase: 97.18% // Head: 97.16% // Decreases project coverage by
Additional details and impacted files@@ Coverage Diff @@
## main #4023 +/- ##
==========================================
- Coverage 97.18% 97.16% -0.03%
==========================================
Files 295 295
Lines 17390 17393 +3
==========================================
- Hits 16901 16900 -1
- Misses 394 397 +3
- Partials 95 96 +1
Flags with carried forward coverage won't be shown. Click here to find out more.
Help us with your feedback. Take ten seconds to tell us how you rate us. Have a feature suggestion? Share it here. ☔ View full report at Codecov. |
[Bug]: span tags of type int64 may lose precision
Thanks! |
Do I need to make more changes? I saw that some tests related to docker are failing. |
probably spurious failures. I have the auto-merge enabled, will keep an eye on the CI |
ah, I just realized the issue - your PR is opened from the |
replaced by #4034 |
Pull request was closed
### Avoid value precision loss Signed-off-by: Shubham Sawaiker [sawaikershubham@gmail.com](mailto:sawaikershubham@gmail.com) ### Which problem is this PR solving? - Resolves: #3958 ### Short description of the changes - avoid display value precision loss in case of value overflow Number.MAX_VALUE Previous PR was made from main branch because of which CI jobs were failing. First PR link : #4023 Signed-off-by: Shubham Sawaiker <sawaikershubham@gmail.com> Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Avoid value precision loss
Signed-off-by: Shubham Sawaiker sawaikershubham@gmail.com
Which problem is this PR solving?
Short description of the changes