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

KVL-914 Add unit test and fix trace context propagation from config management service #9694

Merged
merged 2 commits into from
May 17, 2021

Conversation

hubert-da
Copy link
Collaborator

Pull Request Checklist

  • Read and understand the contribution guidelines
  • Include appropriate tests
  • Set a descriptive title and thorough description
  • Add a reference to the issue this PR will solve, if appropriate
  • Include changelog additions in one or more commit message bodies between the CHANGELOG_BEGIN and CHANGELOG_END tags
  • Normal production system change, include purpose of change in description

NOTE: CI is not automatically run on non-members pull-requests for security
reasons. The reviewer will have to comment with /AzurePipelines run to
trigger the build.

hubert-da added 2 commits May 14, 2021 18:36
…rvice

Fix invalid telemetry context
CHANGELOG_BEGIN
CHANGELOG_END
@@ -64,7 +64,7 @@ class KeyValueParticipantStateWriter(writer: LedgerWriter, metrics: Metrics) ext
val submission =
keyValueSubmission
.configurationToSubmission(maxRecordTime, submissionId, writer.participantId, config)
commit(submissionId, submission)(NoOpTelemetryContext)
commit(submissionId, submission)
Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Not sure why it's been working so far:
image

Copy link
Contributor

Choose a reason for hiding this comment

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

And is it still working after this change? 😄

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

I will have to test it e2e from the oem integration kit 😄

Copy link
Collaborator Author

@hubert-da hubert-da May 17, 2021

Choose a reason for hiding this comment

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

I think it works, as we do not create any new spans and attributes between this place and next gRPC calls.

Copy link
Contributor

@fabiotudone-da fabiotudone-da left a comment

Choose a reason for hiding this comment

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

LGTM but better to also wait for participant people reviews.

Comment on lines +72 to +97
private def mockIndexConfigManagementService() = {
val mockIndexConfigManagementService = mock[IndexConfigManagementService]
when(mockIndexConfigManagementService.lookupConfiguration()(any[LoggingContext]))
.thenReturn(Future.successful(None))
when(
mockIndexConfigManagementService.configurationEntries(any[Option[Absolute]])(
any[LoggingContext]
)
).thenReturn(configurationEntries)
mockIndexConfigManagementService
}

private object TestWriteConfigService extends WriteConfigService {
override def submitConfiguration(
maxRecordTime: Time.Timestamp,
submissionId: SubmissionId,
config: Configuration,
)(implicit telemetryContext: TelemetryContext): CompletionStage[SubmissionResult] = {
telemetryContext.setAttribute(
anApplicationIdSpanAttribute._1,
anApplicationIdSpanAttribute._2,
)
CompletableFuture.completedFuture(SubmissionResult.Acknowledged)
}
}
}
Copy link
Contributor

Choose a reason for hiding this comment

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

Not hugely important but, since you already have a twin object, it looks like you could move these two definitions to it.

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Sadly I can't because:

  • mockIndexConfigManagementService uses mock from MockitoSugar
  • TestWriteConfigService uses anApplicationIdSpanAttribute from the spec base

span.end()
}
.map { _ =>
spanExporter.finishedSpanAttributes should contain(anApplicationIdSpanAttribute)
Copy link
Contributor

Choose a reason for hiding this comment

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

For the sake of curiosity: was this test working with the NoOp?

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

The ApiConfigManagementService uses DefaultTelemetry by default, so hard to tell, TBH. The setAttribute method wouldn't work in the NoOp. Not sure if this answers your question.

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Or you're asking about the change from KeyValueParticipantStateWriter? Then yes, as this test doesn't go that far.

@hubert-da hubert-da merged commit 3666cf2 into main May 17, 2021
@hubert-da hubert-da deleted the hubert-da/tracing-unit-tests-2 branch May 17, 2021 11:44
azure-pipelines bot pushed a commit that referenced this pull request May 19, 2021
This PR has been created by a script, which is not very smart
and does not have all the context. Please do double-check that
the version prefix is correct before merging.

@SamirTalwar-DA is in charge of this release.

Commit log:
```
a6c7b86 LF: Drop support of TO_QUOTED_TEXT_PARTY (#9721)
9d23b43 Split DA.Internal.Exception.Types into three packages. (#9709)
66d039e Upgrade gatling to version 3.5.1 (#9714)
ac9b8ad TODO Cleanup: store.backend package (#9693)
679ce3b LF: Release LF 1.13 (#9705)
73c4793 update NOTICES file (#9711)
f249eec drop per-commit compatibility_macos (#9730)
55c36cc Compiler: drop BEToTextBigNumeric in favor of BEToText (#9728)
2a2c745 Implement name collision check for type synonyms. (#9723)
c7cc1bf KVL-914 Add more unit tests for tracing (#9708)
e63e0cf Upgrade canton to 0.24.0 (#9722)
0a1d00d Canonicalize junit output path (#9710)
d4fca03 LF: Change error exception for Arithmetic builtins (#9692)
1e56640 Release: Switch Andreas and me around in the release rotation. (#9719)
e50885c Dpp 388 todo cleanup parallel indexer (#9690)
fc745f2 LF: clean shifting BigNumeric builtin (#9704)
7a97d88 DA.BigNumeric: Split shift, add roundToNumeric. (#9702)
b1738c7 Switch Scala default to 2.13 (#9699)
1edb110 Fix simplifier safety for AnyExceptionMessage (#9707)
0ab37b3 Use new exception builtins in stdlib. (#9703)
7d472e1 Optimistically increase Patience for fixing flakiness in MutableCacheBackedContractStoreSpec (#9697)
69f51e4 speedy: Compile new AnyException primitives (#9700)
3666cf2 KVL-914 Add unit test and fix trace context propagation from config management service (#9694)
4e63299 Simplify kvutils contract keys validation (#9628)
010e2b1 Fix client_server_build/test with port file (#9701)
6d9490c Never create a rollback node containing pre-exception descendants. (#9679)
b19c8f2 Drop sanitize, add MagicHash in data-dependencies. (#9698)
c669a00 Release SDK 1.13.1 (#9696)
395ff58 Damlification of Bazel files (#9670)
9b53251 Differentiate between negative inputs & errors in contractKeyInputs (#9683)
cd99333 runtime: Damlification of Scala files (#9668)
fb0551b Fix blackduck flag names (#9695)
4b3b9ef Add race condition tests for exceptions (#9688)
927242b KVL-914 Add and rework unit tests for tracing (#9686)
6568336 Lift constraint tuples up to a type synonym in data-dependencies. (#9687)
80f65b4 LF: clean compilation of SToTextXXX builtins (#9682)
ed14f97 Move race condition utilities to test tool infrastructure (#9685)
e5646a9 update compat versions for 1.13.1-snapshot.20210512.6834.1.5f532380 (#9681)
6629aab DEL-8479 tag LF libs for SDK 1.13 release (#9680)
55abd0b Add a data-dependencies test for user-defined exceptions (#9659)
142767c Split daml test-script code into a separate library (#9674)
d436686 Rerelease 1.13.1 snapshot (#9678)
5d181c6 Throw on internal errors instead of setting ptx to aborted (#9654)
ac2e285 Release 1.13.1 snapshot (#9675)
af7f88f restore natural join and avoid table aliasing in participant contracts queries (#9671)
625592e Rename CorrelationID to InstanceUUID as it has been used wrongly. (#9672)
638547f rotate release duty after 1.13.0-snapshot.20210511.6892.0.ca9e89b3 (#9648)
c282a09 KVL-914 Expose metrics-test-lib for the oem integration kit (#9662)
cc01e93 Update error message in interface reader. (#9657)
2dc8b8f Remove version field from rollback node. (#9627)
b58d30b skip Windows tests on release (#9656)
40f69ee fix release PR notifications (#9658)
6919153 Fix update metrics population in parallel indexer (#9655)
931274a Drop version check from TransactionPreprocessor (#9651)
4620851 release 1.14.0-snapshot.20210511.6892.0.ca9e89b3 (#9647)
0d09db5 Update date on code owners in RELEASE.md (#9652)
e61e6b2 Release SDK 1.13.0 (#9650)
9e6d6f7 Support append-only schema in Sandbox migration tests (#9637)
fb9a196 update NOTICES file (#9649)
58d4281 Document web socket event handlers of TS Stream type. (#9634)
111e1d3 Fix sandbox classic package upload (#9633)
```
Changelog:
```

- LF: make LF 1.13 stable
   Add support for BigNumeric

- Ledger API: Bump Ledger API version for LF 1.12

- [Daml Standard Library] `DA.BigNumeric.shift` has been split into
  `DA.BigNumeric.shiftLeft` and `DA.BigNumeric.shiftRight`.
  `DA.BigNumeric.roundToNumeric` is introduced, for rounding and
  converting a BigNumeric to a Numeric in a single move.

- [Daml Compiler] Fixed a data-dependencies bug where functions in a data-dependency that used a constraint tuple constraint (e.g. `Template t`) could not be directly invoked.

```

CHANGELOG_BEGIN
CHANGELOG_END
mergify bot pushed a commit that referenced this pull request May 19, 2021
This PR has been created by a script, which is not very smart
and does not have all the context. Please do double-check that
the version prefix is correct before merging.

@SamirTalwar-DA is in charge of this release.

Commit log:
```
a6c7b86 LF: Drop support of TO_QUOTED_TEXT_PARTY (#9721)
9d23b43 Split DA.Internal.Exception.Types into three packages. (#9709)
66d039e Upgrade gatling to version 3.5.1 (#9714)
ac9b8ad TODO Cleanup: store.backend package (#9693)
679ce3b LF: Release LF 1.13 (#9705)
73c4793 update NOTICES file (#9711)
f249eec drop per-commit compatibility_macos (#9730)
55c36cc Compiler: drop BEToTextBigNumeric in favor of BEToText (#9728)
2a2c745 Implement name collision check for type synonyms. (#9723)
c7cc1bf KVL-914 Add more unit tests for tracing (#9708)
e63e0cf Upgrade canton to 0.24.0 (#9722)
0a1d00d Canonicalize junit output path (#9710)
d4fca03 LF: Change error exception for Arithmetic builtins (#9692)
1e56640 Release: Switch Andreas and me around in the release rotation. (#9719)
e50885c Dpp 388 todo cleanup parallel indexer (#9690)
fc745f2 LF: clean shifting BigNumeric builtin (#9704)
7a97d88 DA.BigNumeric: Split shift, add roundToNumeric. (#9702)
b1738c7 Switch Scala default to 2.13 (#9699)
1edb110 Fix simplifier safety for AnyExceptionMessage (#9707)
0ab37b3 Use new exception builtins in stdlib. (#9703)
7d472e1 Optimistically increase Patience for fixing flakiness in MutableCacheBackedContractStoreSpec (#9697)
69f51e4 speedy: Compile new AnyException primitives (#9700)
3666cf2 KVL-914 Add unit test and fix trace context propagation from config management service (#9694)
4e63299 Simplify kvutils contract keys validation (#9628)
010e2b1 Fix client_server_build/test with port file (#9701)
6d9490c Never create a rollback node containing pre-exception descendants. (#9679)
b19c8f2 Drop sanitize, add MagicHash in data-dependencies. (#9698)
c669a00 Release SDK 1.13.1 (#9696)
395ff58 Damlification of Bazel files (#9670)
9b53251 Differentiate between negative inputs & errors in contractKeyInputs (#9683)
cd99333 runtime: Damlification of Scala files (#9668)
fb0551b Fix blackduck flag names (#9695)
4b3b9ef Add race condition tests for exceptions (#9688)
927242b KVL-914 Add and rework unit tests for tracing (#9686)
6568336 Lift constraint tuples up to a type synonym in data-dependencies. (#9687)
80f65b4 LF: clean compilation of SToTextXXX builtins (#9682)
ed14f97 Move race condition utilities to test tool infrastructure (#9685)
e5646a9 update compat versions for 1.13.1-snapshot.20210512.6834.1.5f532380 (#9681)
6629aab DEL-8479 tag LF libs for SDK 1.13 release (#9680)
55abd0b Add a data-dependencies test for user-defined exceptions (#9659)
142767c Split daml test-script code into a separate library (#9674)
d436686 Rerelease 1.13.1 snapshot (#9678)
5d181c6 Throw on internal errors instead of setting ptx to aborted (#9654)
ac2e285 Release 1.13.1 snapshot (#9675)
af7f88f restore natural join and avoid table aliasing in participant contracts queries (#9671)
625592e Rename CorrelationID to InstanceUUID as it has been used wrongly. (#9672)
638547f rotate release duty after 1.13.0-snapshot.20210511.6892.0.ca9e89b3 (#9648)
c282a09 KVL-914 Expose metrics-test-lib for the oem integration kit (#9662)
cc01e93 Update error message in interface reader. (#9657)
2dc8b8f Remove version field from rollback node. (#9627)
b58d30b skip Windows tests on release (#9656)
40f69ee fix release PR notifications (#9658)
6919153 Fix update metrics population in parallel indexer (#9655)
931274a Drop version check from TransactionPreprocessor (#9651)
4620851 release 1.14.0-snapshot.20210511.6892.0.ca9e89b3 (#9647)
0d09db5 Update date on code owners in RELEASE.md (#9652)
e61e6b2 Release SDK 1.13.0 (#9650)
9e6d6f7 Support append-only schema in Sandbox migration tests (#9637)
fb9a196 update NOTICES file (#9649)
58d4281 Document web socket event handlers of TS Stream type. (#9634)
111e1d3 Fix sandbox classic package upload (#9633)
```
Changelog:
```

- LF: make LF 1.13 stable
   Add support for BigNumeric

- Ledger API: Bump Ledger API version for LF 1.12

- [Daml Standard Library] `DA.BigNumeric.shift` has been split into
  `DA.BigNumeric.shiftLeft` and `DA.BigNumeric.shiftRight`.
  `DA.BigNumeric.roundToNumeric` is introduced, for rounding and
  converting a BigNumeric to a Numeric in a single move.

- [Daml Compiler] Fixed a data-dependencies bug where functions in a data-dependency that used a constraint tuple constraint (e.g. `Template t`) could not be directly invoked.

```

CHANGELOG_BEGIN
CHANGELOG_END

Co-authored-by: Azure Pipelines DAML Build <support@digitalasset.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants