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

[Self-service error codes] Enabled by default [DPP-691] #11685

Merged

Conversation

tudor-da
Copy link
Contributor

@tudor-da tudor-da commented Nov 13, 2021

This PR enables self-service error codes by default in the Ledger API.
The existing enable-self-service-error-codes flag is replaced by use-pre-1.18-error-codes.

CHANGELOG_BEGIN
[Ledger API Specification] The Ledger API returns enriched error codes (see https://docs.daml.com/error-codes/self-service/index.html)
For backwards-compatibility, a new API flag --use-pre-1.18-error-codes is introduced for preserving the legacy behavior for clients that want to migrate incrementally to the changed gRPC status code responses and error details format.
CHANGELOG_END

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
  • If you mean to change the status of a component, please make sure you keep the Component Status page up to date.

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.

@tudor-da tudor-da force-pushed the tudor/dpp-691-self-service-error-codes-enabled-by-default branch 5 times, most recently from 62990ca to 08a1e58 Compare November 16, 2021 20:58
@tudor-da tudor-da marked this pull request as ready for review November 16, 2021 20:58
@tudor-da tudor-da force-pushed the tudor/dpp-691-self-service-error-codes-enabled-by-default branch from 08a1e58 to aa2db55 Compare November 16, 2021 21:13
@tudor-da tudor-da requested a review from S11001001 as a code owner November 16, 2021 22:11
@@ -1149,8 +1149,8 @@ abstract class AbstractHttpServiceIntegrationTest
val exerciseJson: JsValue = encodeExercise(encoder)(iouExerciseTransferCommand(contractId))
postJsonRequest(uri.withPath(Uri.Path("/v1/exercise")), exerciseJson)
.flatMap { case (status, output) =>
status shouldBe StatusCodes.Conflict
assertStatus(output, StatusCodes.Conflict)
status shouldBe StatusCodes.NotFound
Copy link
Contributor Author

Choose a reason for hiding this comment

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

@tudor-da tudor-da force-pushed the tudor/dpp-691-self-service-error-codes-enabled-by-default branch from 232a4ae to 842773d Compare November 18, 2021 10:29
@tudor-da tudor-da force-pushed the tudor/dpp-691-self-service-error-codes-enabled-by-default branch from 8079e09 to 287ff45 Compare November 18, 2021 13:50
@tudor-da tudor-da force-pushed the tudor/dpp-691-self-service-error-codes-enabled-by-default branch 3 times, most recently from 7b2ed8f to 85c5907 Compare November 18, 2021 20:41
@tudor-da tudor-da marked this pull request as draft November 18, 2021 21:18
@tudor-da
Copy link
Contributor Author

Changed to draft until the compatibility test resolution is implemented.

@tudor-da tudor-da force-pushed the tudor/dpp-691-self-service-error-codes-enabled-by-default branch from b7c091e to 61f9723 Compare November 19, 2021 14:19
@tudor-da tudor-da force-pushed the tudor/dpp-691-self-service-error-codes-enabled-by-default branch from 571dbab to 2ff8c8c Compare November 22, 2021 10:21
@@ -329,6 +329,9 @@ final class CommandServiceIT extends LedgerTestSuite {
}
})

// TODO fix this test: This test is not asserting that an interpretation error is returning a stack trace.
Copy link
Contributor

Choose a reason for hiding this comment

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

Can we rather create a ticket for this, please? We'll have a better chance of fixing it.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Created ticket for it

}

it should "disable error codes v2 flag by default" in {
it should "enable self-service error codes by default" in {
Copy link
Contributor

Choose a reason for hiding this comment

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

👍

@tudor-da tudor-da force-pushed the tudor/dpp-691-self-service-error-codes-enabled-by-default branch from 2ff8c8c to 810520c Compare November 22, 2021 10:50
tudor-da and others added 15 commits November 22, 2021 11:51
* Flag changed to `use-pre-1.18-error-codes` (disabled by default)

CHANGELOG_BEGIN
[Ledger API Specification] The Ledger API returns enriched error codes (see https://docs.daml.com/error-codes/self-service/index.html)
For backwards-compatibility, a new API flag `--use-pre-1.18-error-codes` is introduced for preserving the legacy behavior for
clients that want to migrate incrementally to the changed gRPC status code responses and error details format.
CHANGELOG_END
changelog_begin
changelog_end
changelog_begin
changelog_end
changelog_begin
changelog_end
 Please enter the commit message for your changes. Lines starting
* Flag name changed to `grpc-status-codes-compatibility-mode`
* Created 2 deprecated test suites that have the more generic assertions as returned
by the deprecated in-memory backend
* Fixes compilation issue with the deprecated exceptionsIT class for Sandbox-classic in-memory
@tudor-da tudor-da force-pushed the tudor/dpp-691-self-service-error-codes-enabled-by-default branch from 810520c to 903a904 Compare November 22, 2021 10:52
Co-authored-by: Miklos <57664299+miklos-da@users.noreply.github.com>
@tudor-da tudor-da changed the title [Self-service error codes] Enabled by default [Self-service error codes] Enabled by default [DPP-691] Nov 22, 2021
@mergify mergify bot merged commit 8e31e8e into main Nov 22, 2021
@mergify mergify bot deleted the tudor/dpp-691-self-service-error-codes-enabled-by-default branch November 22, 2021 12:26
tudor-da added a commit that referenced this pull request Nov 22, 2021
* [Self-service error codes] Enabled by default
* Flag changed to `use-pre-1.18-error-codes` (disabled by default)

CHANGELOG_BEGIN
[Ledger API Specification] The Ledger API returns enriched error codes (see https://docs.daml.com/error-codes/self-service/index.html)
For backwards-compatibility, a new API flag `--use-pre-1.18-error-codes` is introduced for preserving the legacy behavior for
clients that want to migrate incrementally to the changed gRPC status code responses and error details format.
CHANGELOG_END

* Adapted HttpServiceIntegrationTest

* Renamed `Feature Flag` to `Configuration` in docs

* Fix Daml Script tests

changelog_begin
changelog_end

* Fix Repl functests

changelog_begin
changelog_end

* Fix haskell binding tests

changelog_begin
changelog_end

* Fix CommandClientIT test

* Fixed Sandbox and CommandServiceBackpressureIT tests
 Please enter the commit message for your changes. Lines starting

* Adapt //compiler/damlc/tests:repl-functests again

* Fix more tests and address Miklos' comments
* Flag name changed to `grpc-status-codes-compatibility-mode`

* Remove useless flags sandbox-classic

* Sandbox-classic tests fix for ContractKeysIT and ExceptionsIT
* Created 2 deprecated test suites that have the more generic assertions as returned
by the deprecated in-memory backend

* More fixes for CommandServiceIT
* Fixes compilation issue with the deprecated exceptionsIT class for Sandbox-classic in-memory

* Compatibility mode for old test tools

* Change flag name to `use-pre-1.18-error-codes`

* Apply suggestions from code review

Co-authored-by: Miklos <57664299+miklos-da@users.noreply.github.com>

Co-authored-by: Moritz Kiefer <moritz.kiefer@purelyfunctional.org>
Co-authored-by: Miklos <57664299+miklos-da@users.noreply.github.com>
tudor-da added a commit that referenced this pull request Nov 22, 2021
* [Self-service error codes] Enabled by default
* Flag changed to `use-pre-1.18-error-codes` (disabled by default)

CHANGELOG_BEGIN
[Ledger API Specification] The Ledger API returns enriched error codes (see https://docs.daml.com/error-codes/self-service/index.html)
For backwards-compatibility, a new API flag `--use-pre-1.18-error-codes` is introduced for preserving the legacy behavior for
clients that want to migrate incrementally to the changed gRPC status code responses and error details format.
CHANGELOG_END

* Adapted HttpServiceIntegrationTest

* Renamed `Feature Flag` to `Configuration` in docs

* Fix Daml Script tests

changelog_begin
changelog_end

* Fix Repl functests

changelog_begin
changelog_end

* Fix haskell binding tests

changelog_begin
changelog_end

* Fix CommandClientIT test

* Fixed Sandbox and CommandServiceBackpressureIT tests
 Please enter the commit message for your changes. Lines starting

* Adapt //compiler/damlc/tests:repl-functests again

* Fix more tests and address Miklos' comments
* Flag name changed to `grpc-status-codes-compatibility-mode`

* Remove useless flags sandbox-classic

* Sandbox-classic tests fix for ContractKeysIT and ExceptionsIT
* Created 2 deprecated test suites that have the more generic assertions as returned
by the deprecated in-memory backend

* More fixes for CommandServiceIT
* Fixes compilation issue with the deprecated exceptionsIT class for Sandbox-classic in-memory

* Compatibility mode for old test tools

* Change flag name to `use-pre-1.18-error-codes`

* Apply suggestions from code review

Co-authored-by: Miklos <57664299+miklos-da@users.noreply.github.com>

Co-authored-by: Moritz Kiefer <moritz.kiefer@purelyfunctional.org>
Co-authored-by: Miklos <57664299+miklos-da@users.noreply.github.com>
mergify bot pushed a commit that referenced this pull request Nov 22, 2021
)

* [Self-service error codes] Enabled by default
* Flag changed to `use-pre-1.18-error-codes` (disabled by default)

CHANGELOG_BEGIN
[Ledger API Specification] The Ledger API returns enriched error codes (see https://docs.daml.com/error-codes/self-service/index.html)
For backwards-compatibility, a new API flag `--use-pre-1.18-error-codes` is introduced for preserving the legacy behavior for
clients that want to migrate incrementally to the changed gRPC status code responses and error details format.
CHANGELOG_END

* Adapted HttpServiceIntegrationTest

* Renamed `Feature Flag` to `Configuration` in docs

* Fix Daml Script tests

changelog_begin
changelog_end

* Fix Repl functests

changelog_begin
changelog_end

* Fix haskell binding tests

changelog_begin
changelog_end

* Fix CommandClientIT test

* Fixed Sandbox and CommandServiceBackpressureIT tests
 Please enter the commit message for your changes. Lines starting

* Adapt //compiler/damlc/tests:repl-functests again

* Fix more tests and address Miklos' comments
* Flag name changed to `grpc-status-codes-compatibility-mode`

* Remove useless flags sandbox-classic

* Sandbox-classic tests fix for ContractKeysIT and ExceptionsIT
* Created 2 deprecated test suites that have the more generic assertions as returned
by the deprecated in-memory backend

* More fixes for CommandServiceIT
* Fixes compilation issue with the deprecated exceptionsIT class for Sandbox-classic in-memory

* Compatibility mode for old test tools

* Change flag name to `use-pre-1.18-error-codes`

* Apply suggestions from code review

Co-authored-by: Miklos <57664299+miklos-da@users.noreply.github.com>

Co-authored-by: Moritz Kiefer <moritz.kiefer@purelyfunctional.org>
Co-authored-by: Miklos <57664299+miklos-da@users.noreply.github.com>

Co-authored-by: Moritz Kiefer <moritz.kiefer@purelyfunctional.org>
Co-authored-by: Miklos <57664299+miklos-da@users.noreply.github.com>
azure-pipelines bot pushed a commit that referenced this pull request Nov 24, 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.

@nickchapman-da is in charge of this release.

Commit log:
```
bd2a685 Make ACS reader parameters configurable (#11732)
329e609 [Self-service error codes] Group explanations (#11715)
32e9c4b Bump go rules (#11829)
6df7af7 update compat versions for 1.18.0-snapshot.20211117.8399.0.a05a40ae (#11743)
9461702 [DPP-673][Self-service error codes] Split one narrow migration table into multiple narrower ones to fit in the generated pdf's pages. (#11803)
5519184 [DPP-673][Self-service error-codes] Generate error code directory compatible with both pdf and html docs (#11794)
5a2c070 Skip append-only migration tests on each PR (#11816)
e6c8229 port #11798 documentation changes to json-api HTTP codes documentation (#11823)
1610d97 LF: parsing interface primitives (#11825)
f2aa09c Allow encoded server key files to be in base64 [DPP-761] (#11796)
cc3f551 update NOTICES file (#11824)
1bfcbc9 Refactoring for Canton compatibility on PackageServiceErrors (#11812)
c4b6a17 [Self-service error codes] Update existing error code references [DPP-593] (#11798)
addb2ed Drop Scala 2.13 version guards from Bazel definitions (#11819)
5785bbf Drop LF < 1.14 from supported damlc output versions (#11701)
ae8391e LF Parser: handle interface (#11797)
faddba4 Increase range for excluded snapshots in compatilbility tests (#11802)
f8933d1 Make lookupTemplateChoice return only choices in the template. (#11808)
3e0ac71 update NOTICES file (#11801)
8e31e8e [Self-service error codes] Enabled by default [DPP-691] (#11685)
ab520fb Fix es (#11784)
350ad98 Bump Windows postgres (#11804)
2d60ae8 update NOTICES file (#11799)
2d9ee20 [ledger-api-client] - Do not account for deduplication_time as timeout [KVL-1172] (#11791)
f334861 LF: Simplify LF Syntax (#11795)
cbe9c92 LF: Clean up Ast (#11786)
25e5bbb kvutils - Removed unused setting from conformance tests [KVL-1174] (#11785)
cd52f13 Remove `@aherrmann-da` from `CODEOWNERS` (#11792)
9bb12d0 update NOTICES file (#11787)
d23d113 Restructure interface desugaring (#11555)
1bb2fc2  LF: Simplify transaction versionning for interface (#11744)
4b59c57 Move select DB logic to JVM [DPP-760] (#11777)
5fb5784 Limit the number of parallel Bazel actions (#11779)
a9754fe Write exception reports into the logfile in case of ssl misconfiguration (#11776)
4a8e110 Add missing export of deleteBy from DA.NonEmpty (#11716)
51f646c Add engine tests for interfaces. (#11773)
ac57355 Drop Scala 2.12 compatibility layer from //daml-lf/data (#11758)
3b5f8a7 Remove precondition field from TemplateImplements (#11763)
2e789dd [DPP-417][Self-service error codes][Docs] Add more complete information for forking gRPC status codes. (#11739)
4ebdaf5 kvutils - Deprecate deduplicate_until [kvl-1174] (#11765)
f5a6302 [participant-integration-api] - Use internal CommandCompletionService [KVL-1172] (#11741)
39a38d3 Update to Java 11 (#11512)
91b4fb9 Backport: Skip protobuf compatibility check for PRs to non-main (#11772)
a3556a5 Retry release signature checks (#11771)
8f458d8 [ledger-api] Include the completion offset in the command_service.proto responses [KVL-1171] (#11658)
e891180 participant-state: Remove the v1 API. (#11553)
869b805 Bump sandbox acquisition timeout of trigger service tests to 1m (#11764)
4106222 Fix docs regarding deduplication periods [KVL-1194] (#11738)
186ba10 Fix missing encoding of nested maps in typescript bindings (#11746)
dd88ba2 kvutils - Backwards looking command deduplication [KVL-1174] (#11634)
43438c6 sandbox: Remove PostgreSQL conformance tests. (#11434)
b0a1bf7 More missing error codes (#11749)
3366413 Delete empty scala test library (#11747)
85979b3 Upgrade to Postgres 10 (#11751)
39c5966 Drop aherrman-da from release rotation (#11756)
c8ace8b Factor kind projector target into a variable (#11759)
e78bfc7 update NOTICES file (#11757)
fa76631 Drop 2.12 versioned_scala_deps (#11748)
c77e150 [JSON-API] ContractDao JMH benchmarks against PG (#11718)
d60cf70 rotate release duty after 1.18.0-snapshot.20211116.8395.0.ccbf7140 (#11734)
bb19c0d Drop Scala 2.12 support (#11619)
c2d4ea4 Add separate commands for create/fetch/exercise by template/interface. (#11724)
7e4acf9 link to doc detailing gRPC-to-HTTP code mapping (#11742)
7974427 release 1.18.0-snapshot.20211117.8399.0.a05a40ae (#11740)
```
Changelog:
```

- [Daml Compiler] Damlc can only produce Daml-LF 1.14 or
  newer. Passing aynthing older to `--target` is an error. If you
  need to produce older versions, use an older SDK.

[Ledger API Specification] The Ledger API returns enriched error codes (see https://docs.daml.com/error-codes/self-service/index.html)
For backwards-compatibility, a new API flag `--use-pre-1.18-error-codes` is introduced for preserving the legacy behavior for
clients that want to migrate incrementally to the changed gRPC status code responses and error details format.
ledger-api-client - The default command tracking timeout is no longer influenced by the deprecated deduplication_time as a deduplication period. Previously if no timeout was being set in the command and deduplication_time was set as the deduplication period then the command tracking timeout was the minimum between the deduplication_time and max tracking timeout.
[ledger-api] - Include the completion offset in the responses from the command_service.proto
- [Integration Kit] v1 of the participant state API is no longer
  supported. You will need to upgrade to v2.

- [Typescript Bindings] Fix an issue where nested maps did not get
  encoded properly before sent to the JSON API which caused requests
  to fail with a decoding error on the JSON API.

kvutils - The deduplication duration passed in the command is now used for command deduplication, and is no longer always overwritten with the max deduplication duration. The command deduplication duration can still be extended by the committer to account for time skews.
```

CHANGELOG_BEGIN
CHANGELOG_END
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.

5 participants